I'm using Cappuccino 0.9.6 with XcodeCapp. I have a CPCollectionView populated with CPImageView subtype items (ThumbnailView). Now I want the items to be draggable.
I adapted the instructions in the Scrapbook #2 - Drag and Drop example to my xcode interface (the drag destination is not yet implemented), However, the items aren't selectable, let alone draggable. Any ideas about what's wrong?
AppController.j
@import <Foundation/CPObject.j>
@import "MediaController.j"
@implementation AppController : CPObject
{
CPWindow theWindow; //this "outlet" is connected automatically by the Cib
@outlet MediaController mediaController; // connected to AppController
}
- (void)applicationDidFinishLaunching:(CPNotification)aNotification
{
// load media
[mediaController loadMedia];
}
- (void)awakeFromCib
{
[theWindow setFullPlatformWindow:YES];
}
@end
MediaController.j
ThumbnailDragType = @"ThumbnailDragType";
@implementation MediaController : CPObject
{
CPArray images;
// outlets
@outlet CPCollectionView thumbnailCollectionView; // connected to CPCollectionView in interface builder
}
- (id)loadMedia
{
[thumbnailCollectionView setAutoresizingMask:CPViewWidthSizable];
[thumbnailCollectionView setMinItemSize:CGSizeMake(150, 150)];
[thumbnailCollectionView setMaxItemSize:CGSizeMake(150, 150)];
[thumbnailCollectionView setDelegate:self];
var itemPrototype = [[CPCollectionViewItem alloc] init];
[itemPrototype setView:[[ThumbnailView alloc] initWithFrame:CGRectMakeZero()]];
[thumbnailCollectionView setItemPrototype:itemPrototype];
image1 = [[CPImage alloc] initWithContentsOfFile:@"Resources/sample.jpg" size:CGSizeMake(500.0, 430.0)];
[image1 setName:'bla'];
image2 = [[CPImage alloc] initWithContentsOfFile:@"Resources/sample2.jpg" size:CGSizeMake(500.0, 389.0)];
[image2 setName:'asdfsadfdf'];
image3 = [[CPImage alloc] initWithContentsOfFile:@"Resources/sample3.jpg" size:CGSizeMake(413.0, 400.0)];
[image3 setName:'asdfadsggewa'];
image4 = [[CPImage alloc] initWithContentsOfFile:@"Resources/sample4.jpg" size:CGSizeMake(500.0, 375.0)];
[image4 setName:'aisdfiojf'];
image5 = [[CPImage alloc] initWithContentsOfFile:@"Resources/sample5.jpg" size:CGSizeMake(500.0, 375.0)];
[image5 setName:'oiajdf'];
image6 = [[CPImage alloc] initWithContentsOfFile:@"Resources/sample6.jpg" size:CGSizeMake(500.0, 375.0)];
[image6 setName:'aidsoifsd'];
images = [image1, image2, image3, image4, image5, image6];
[thumbnailCollectionView setContent:images];
return self;
}
- (CPData)collectionView:(CPCollectionView)aCollectionView dataForItemsAtIndexes:(CPIndexSet)indices forType:(CPString)aType
{
return [CPKeyedArchiver archivedDataWithRootObject:[images objectAtIndex:[indices firstIndex]]];
}
- (CPArray)collectionView:(CPCollectionView)aCollectionView dragTypesForItemsAtIndexes:(CPIndexSet)indices
{
return [ThumbnailDragType];
}
@end
@implementation ThumbnailView : CPImageView
{
CPImageView imageView;
CPView labelView;
CPTextField label;
}
- (void)setSelected:(BOOL)isSelected
{
[self setBackgroundColor:isSelected ? [CPColor grayColor] : nil];
}
- (void)setRepresentedObject:(id)anObject
{
if (!imageView)
{
var frame = CGRectInset([self bounds], 5.0, 5.0);
// make imageView
imageView = [[CPImageView alloc] initWithFrame:frame];
[imageView setImageScaling:CPScaleProportionally];
[imageView setAutoresizingMask:CPViewWidthSizable | CPViewHeightSizable];
[self addSubview:imageView];
// make label view
labelView = [[CPView alloc] initWithFrame:CGRectMake(
5.0,
125.0,
140.0,
20.0
)];
[labelView setBackgroundColor:[CPColor blackColor]];
// make label
label = [[CPTextField alloc] initWithFrame:CGRectInset([labelView bounds], 3.0, 3.0)];
[label setTextColor:[CPColor whiteColor]];
[labelView addSubview:label];
[self addSubview:labelView];
}
[imageView setImage:anObject];
[label setStringValue:[anObject name]];
}
@end
In Xcode, make sure the collection view is marked as "selectable" (see attached image).