Bru*_*sso 5 macos cocoa modal-dialog toolbar
我正在考虑这种奇怪的行为.当应用等待某些信息时,我正在使用带有文本的面板向用户显示.此面板以模态显示以防止用户单击某些内容.
隐藏加载面板时,工具栏上的所有项都将被禁用,并且validateToolbarItem
不会调用该方法.
我正以这种方式展示小组:
- (void)showInWindow:(NSWindow *)mainWindow {
sheetWindow = [self window];
[self sheetWillShow];
[NSApp beginSheet:sheetWindow modalForWindow:mainWindow modalDelegate:nil didEndSelector:nil contextInfo:nil];
[NSApp runModalForWindow:sheetWindow];
[NSApp endSheet:sheetWindow];
[sheetWindow orderOut:self];
}
- (void)dismissModal {
[sheetWindow close];
[NSApp stopModal];
}
Run Code Online (Sandbox Code Playgroud)
在这种情况下,如何强制工具栏进行验证?
评论后编辑:
我已经尝试过了:
[[[NSApp mainWindow] toolbar] validateVisibleItems]
[[NSApp mainWindow] update];
[NSApp updateWindows];
[NSApp setWindowsNeedUpdate:YES];
所有电话结束后dismissModal
.我在想其他问题......
问题是NSToolbar只向NSToolbarItem发送验证消息,这些消息是Image类型的,我的都没有.为了验证任何或所有NSToolbarItems,创建NSToolBar的自定义子类并覆盖validateVisibleItems:方法.这将向所有可见的NSToolbarItem发送验证消息.唯一真正的区别是,不需要让Toolbar类使用返回的BOOL启用或禁用该项,您需要在验证方法本身中启用或禁用该项.
@interface CustomToolbar : NSToolbar
@end
@implementation CustomToolbar
-(void)validateVisibleItems
{
for (NSToolbarItem *toolbarItem in self.visibleItems)
{
NSResponder *responder = toolbarItem.view;
while ((responder = [responder nextResponder]))
{
if ([responder respondsToSelector:toolbarItem.action])
{
[responder performSelector:@selector(validateToolbarItem:) withObject:toolbarItem];
}
}
}
}
@end
Run Code Online (Sandbox Code Playgroud)
现在,假设您有一个带有IBAction方法的控制器,该方法处理工具栏中NSSegmentedControl的操作:
- (IBAction)backButton:(NSSegmentedControl*)sender
{
NSInteger segment = sender.selectedSegment;
if (segment == 0)
{
// Action for first button segment
}
else if (segment == 1)
{
// Action for second button segment
}
}
Run Code Online (Sandbox Code Playgroud)
将以下内容放在处理工具栏项操作的同一控制器中:
-(BOOL)validateToolbarItem:(NSToolbarItem *)toolbarItem
{
SEL theAction = [toolbarItem action];
if (theAction == @selector(backButton:))
{
[toolbarItem setEnabled:YES];
NSSegmentedControl *backToolbarButton = (NSSegmentedControl *)toolbarItem.view;
[backToolbarButton setEnabled:YES forSegment:0];
[backToolbarButton setEnabled:NO forSegment:1];
}
return NO;
}
Run Code Online (Sandbox Code Playgroud)
结果是您可以完全控制启用或禁用的段.
只要项目的Received Action由响应者链中的控制器处理,该技术应该适用于几乎任何其他类型的NSToolbarItem.
我希望这有帮助.
NSToolbar *toolbar; //Get this somewhere. If you have the window it is in, call [window toolbar];
[toolbar validateVisibleItems];
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2866 次 |
最近记录: |