Hi Josh,

I would echo Andreas' advice and tell you to not use NSViews to accomplish this task.

I would suggest that you take a closer look at the problem domain and re-factor along the lines of the data you manage and the drawn representation of that data. NSViews are great containers for drawing, but at what point does your program need to display 60,000 things on the screen at once? Does the user actually perceive the drawing as 60,000 objects or as one object? If, most of the time, a user will only see a subset of the 60,000 objects, then perhaps you should rethink how you are doing your drawing.

My suggestion is that you keep your 60,000 objects in some "datasource- like" object that can be queried by the Custom View that actually does the drawing. Let your custom view draw only those objects that are visible. If the objects you are drawing can be handled by an existing NSCell type ( e.g., an image cell or text cell), then use a copy of that cell type to do your drawing, otherwise just do the drawing yourself.

regards,

douglas

On Jan 24, 2009, at 5:29 PM, Twisted Theory wrote:

Hi,

I am constructing an application that draws rooted trees (graphs with a distinguished 'first' node) by creating an NSView subclass for each node and
adding them as subviews of the graph view.

There is a big problem when the number of nodes in the tree is large: adding
the subviews takes a very long time.  For example, one of my trees has
around 60,000 nodes.  It takes about 1.5 seconds to create all of the
objects, and about 200 seconds to add them as subviews.

Can anyone suggest a way to speed the process up? Multithreading didn't
really improve matters.

Each node keeps track of its child nodes in an NSArray, and the subview
addition is recursive:

- (void) add
{
NSAutoreleasePool *autoreleasepool = [[NSAutoreleasePool alloc] init];

   [[parent superview] addSubview:self];
   for (Vertex * child in children)
[child performSelectorOnMainThread:@selector(add) withObject:nil
waitUntilDone:NO];
       //[child add];

   [autoreleasepool release];
}

Thanks,

Josh
_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
http://lists.apple.com/mailman/options/cocoa-dev/douglas_welton%40earthlink.net

This email sent to douglas_wel...@earthlink.net

_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
http://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com

This email sent to arch...@mail-archive.com

Reply via email to