mirror of
https://github.com/gnustep/libs-gui.git
synced 2025-05-30 02:40:38 +00:00
Added more of the implementation for toolbar/toolbaritem. Added check in GSClassSwapper to prevent an error case.
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gui/trunk@17532 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
parent
577c9532e6
commit
a32c4a14df
8 changed files with 173 additions and 40 deletions
|
@ -335,7 +335,8 @@ IMLoading.h \
|
|||
GSLayoutManager.h \
|
||||
GSLayoutManager_internal.h \
|
||||
GSTypesetter.h \
|
||||
GSHorizontalTypesetter.h
|
||||
GSHorizontalTypesetter.h \
|
||||
GSToolbarView.h
|
||||
|
||||
libgnustep-gui_HEADER_FILES = ${GUI_HEADERS}
|
||||
|
||||
|
|
|
@ -380,9 +380,10 @@ static const int currentVersion = 1; // GSNibItem version number...
|
|||
{
|
||||
if((self = [self init]) != nil)
|
||||
{
|
||||
NSLog(@"Created template %@ -> %@",NSStringFromClass([self class]), className);
|
||||
NSDebugLog(@"Created template %@ -> %@",NSStringFromClass([self class]), className);
|
||||
ASSIGN(_object, object);
|
||||
ASSIGN(_className, className);
|
||||
NSAssert(![className isEqualToString: superClassName], NSInvalidArgumentException);
|
||||
_superClass = NSClassFromString(superClassName);
|
||||
if(_superClass == nil)
|
||||
{
|
||||
|
|
|
@ -38,19 +38,12 @@
|
|||
#include "AppKit/NSView.h"
|
||||
#include "AppKit/NSButton.h"
|
||||
#include "AppKit/NSNibLoading.h"
|
||||
#include "GNUstepGUI/GSToolbarView.h"
|
||||
|
||||
// internal
|
||||
static NSNotificationCenter *nc = nil;
|
||||
static const int current_version = 1;
|
||||
|
||||
@interface GSToolbarView : NSView
|
||||
{
|
||||
NSToolbar *_toolbar;
|
||||
}
|
||||
- (void) setToolbar: (NSToolbar *)toolbar;
|
||||
- (NSToolbar *) toolbar;
|
||||
@end
|
||||
|
||||
@implementation GSToolbarView
|
||||
- (void) dealloc
|
||||
{
|
||||
|
@ -61,6 +54,7 @@ static const int current_version = 1;
|
|||
- (void) setToolbar: (NSToolbar *)toolbar
|
||||
{
|
||||
ASSIGN(_toolbar, toolbar);
|
||||
|
||||
}
|
||||
- (NSToolbar *) toolbar
|
||||
{
|
||||
|
@ -69,7 +63,23 @@ static const int current_version = 1;
|
|||
|
||||
- (void) drawRect: (NSRect)aRect
|
||||
{
|
||||
NSArray *items = [_toolbar items];
|
||||
NSEnumerator *en = [items objectEnumerator];
|
||||
id item = nil;
|
||||
float x = 0;
|
||||
|
||||
[super drawRect: aRect];
|
||||
while((item = [en nextObject]) != nil)
|
||||
{
|
||||
NSView *itemView = [item view];
|
||||
NSRect itemFrame = [itemView frame];
|
||||
|
||||
// now we need to draw the items...
|
||||
itemFrame.origin.x = x; // start at x
|
||||
itemFrame.origin.y = 0; // reset to top of view.
|
||||
[itemView drawRect: itemFrame];
|
||||
x += NSWidth(itemFrame) + 2; // move over by the frame width plus 2 pixels.
|
||||
}
|
||||
}
|
||||
@end
|
||||
|
||||
|
@ -101,13 +111,12 @@ static const int current_version = 1;
|
|||
@end
|
||||
|
||||
@implementation NSToolbar (GNUstepPrivate)
|
||||
- (GSToolbarView *) _toolbarView
|
||||
- (id) _toolbarView
|
||||
{
|
||||
return _toolbarView;
|
||||
}
|
||||
@end
|
||||
|
||||
|
||||
@implementation NSToolbar
|
||||
// Initialize the class when it is loaded
|
||||
+ (void) initialize
|
||||
|
@ -309,5 +318,3 @@ static const int current_version = 1;
|
|||
return _visibleItems;
|
||||
}
|
||||
@end /* interface of NSToolbar */
|
||||
|
||||
|
||||
|
|
|
@ -42,7 +42,11 @@
|
|||
|
||||
- (NSImage *)image
|
||||
{
|
||||
return _image;
|
||||
if(_flags.viewRespondsToImage)
|
||||
{
|
||||
return [_view image];
|
||||
}
|
||||
return nil;
|
||||
}
|
||||
|
||||
- (id)initWithItemIdentifier: (NSString *)itemIdentifier
|
||||
|
@ -53,7 +57,11 @@
|
|||
|
||||
- (BOOL)isEnabled
|
||||
{
|
||||
return _enabled;
|
||||
if(_flags.viewRespondsToIsEnabled)
|
||||
{
|
||||
return [_view isEnabled];
|
||||
}
|
||||
return NO;
|
||||
}
|
||||
|
||||
- (NSString *)itemIdentifier
|
||||
|
@ -88,17 +96,26 @@
|
|||
|
||||
- (void)setAction: (SEL)action
|
||||
{
|
||||
_action = action;
|
||||
if(_flags.viewRespondsToSetAction)
|
||||
{
|
||||
[_view setAction: action];
|
||||
}
|
||||
}
|
||||
|
||||
- (void)setEnabled: (BOOL)enabled
|
||||
{
|
||||
enabled = _enabled;
|
||||
if(_flags.viewRespondsToSetEnabled)
|
||||
{
|
||||
[_view setEnabled: enabled];
|
||||
}
|
||||
}
|
||||
|
||||
- (void)setImage: (NSImage *)image
|
||||
{
|
||||
ASSIGN(_image, image);
|
||||
if(_flags.viewRespondsToSetImage)
|
||||
{
|
||||
[_view setImage: image];
|
||||
}
|
||||
}
|
||||
|
||||
- (void)setLabel: (NSString *)label
|
||||
|
@ -128,12 +145,18 @@
|
|||
|
||||
- (void)setTag: (int)tag
|
||||
{
|
||||
_tag = tag;
|
||||
if(_flags.viewRespondsToTag)
|
||||
{
|
||||
[_view setTag: tag];
|
||||
}
|
||||
}
|
||||
|
||||
- (void)setTarget: (id)target
|
||||
{
|
||||
ASSIGN(_target, target);
|
||||
{
|
||||
if(_flags.viewRespondsToTarget)
|
||||
{
|
||||
[_view setTarget: target];
|
||||
}
|
||||
}
|
||||
|
||||
- (void)setToolTip: (NSString *)toolTip
|
||||
|
@ -144,11 +167,27 @@
|
|||
- (void)setView: (NSView *)view
|
||||
{
|
||||
ASSIGN(_view, view);
|
||||
// gets
|
||||
_flags.viewRespondsToIsEnabled = [_view respondsToSelector: @selector(isEnabled)];
|
||||
_flags.viewRespondsToTag = [_view respondsToSelector: @selector(tag)];
|
||||
_flags.viewRespondsToAction = [_view respondsToSelector: @selector(action)];
|
||||
_flags.viewRespondsToTarget = [_view respondsToSelector: @selector(target)];
|
||||
_flags.viewRespondsToImage = [_view respondsToSelector: @selector(image)];
|
||||
// sets
|
||||
_flags.viewRespondsToSetEnabled = [_view respondsToSelector: @selector(setEnabled:)];
|
||||
_flags.viewRespondsToSetTag = [_view respondsToSelector: @selector(setTag:)];
|
||||
_flags.viewRespondsToSetAction = [_view respondsToSelector: @selector(setAction:)];
|
||||
_flags.viewRespondsToSetTarget = [_view respondsToSelector: @selector(setTarget:)];
|
||||
_flags.viewRespondsToSetImage = [_view respondsToSelector: @selector(setImage:)];
|
||||
}
|
||||
|
||||
- (int)tag
|
||||
{
|
||||
return _tag;
|
||||
if(_flags.viewRespondsToTag)
|
||||
{
|
||||
return [_view tag];
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
- (NSString *)toolTip
|
||||
|
@ -165,7 +204,6 @@
|
|||
{
|
||||
// validate by default, we know that all of the
|
||||
// "standard" items are correct.
|
||||
_enabled = YES;
|
||||
}
|
||||
|
||||
- (NSView *)view
|
||||
|
@ -176,12 +214,20 @@
|
|||
// NSValidatedUserInterfaceItem protocol
|
||||
- (SEL)action
|
||||
{
|
||||
return _action;
|
||||
if(_flags.viewRespondsToAction)
|
||||
{
|
||||
return [_view action];
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
- (id)target
|
||||
{
|
||||
return _target;
|
||||
if(_flags.viewRespondsToTarget)
|
||||
{
|
||||
return [_view target];
|
||||
}
|
||||
return nil;
|
||||
}
|
||||
|
||||
// NSCopying protocol
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue