macOS/iOS API解説

iOS , Mac アプリケーション開発のために使われる主要フレームワークの日本語情報です。2010年代に書かれた内容です。今後更新はありません。

目次

insertItemWithTitle:action:keyEquivalent:atIndex:

メニューに、タイトル・代替キー・番号でメニュー項目を追加します
-(id <NSMenuItem>)insertItemWithTitle:(NSString *)aString:
             action:(SEL)aSelector:
             keyEquivalent:(NSString *)keyEquiv:
             atIndex:(unsigned int)index:

解説

メニューに、タイトル・代替キー・番号でメニュー項目を追加します。
代替キーが不要ならば、keyEquivを空の文字列(@"")とします。

返り値

( id <NSMenuItem> )

メニュー項目

引数

( NSString * )aString

タイトル文字列

( SEL )aSelector

アクションセレクタ

( NSString * )keyEquiv

代替キー

( unsigned int )index

番号

フレームワーク

ApplicationKit

クラス

NSMenu

Instance Methods

使用可能

10.0

参照

例文

#import "MyObject.h"

@implementation MyObject

- (IBAction)myAction:(id)sender
{
/*
Localizable.stringsのJapaneseに記入してあります。
"menu_open"="開く";
"menuItem_1"="メニュー項目1";
"menuItem_2"="メニュー項目2";
"menuItem_3"="メニュー項目3";
*/
        NSMenuItem	*menuItem = [[[NSMenuItem alloc] init] autorelease];
        NSMenu *menu = [[[NSMenu alloc] init] autorelease];
        
        [menuItem setTitle:NSLocalizedString(@"menu_open",@"")];
        [menu setTitle: NSLocalizedString(@"menu_open",@"")];
        
        [menu addItemWithTitle: NSLocalizedString(@"menuItem_1",@"")
            action: @selector(mItem1) keyEquivalent: @"A"];
        [menu addItemWithTitle: NSLocalizedString(@"menuItem_2",@"")
            action: @selector( mItem2: ) keyEquivalent: @"B"];
        [menu addItem: [NSMenuItem separatorItem]];
        [menu addItemWithTitle: NSLocalizedString(@"menuItem_3",@"")
            action: @selector( mItem3: ) keyEquivalent: @"E"];
        [menuItem setSubmenu: menu];
        
        [menu setAutoenablesItems:NO];
        [menuItem setEnabled:YES];
        
        [[NSApp mainMenu] insertItem: menuItem atIndex: 2];
        [menuItem setTarget:self];
}

-(void)mItem1:(id)sender
{
NSLog(@"item1");
}
-(void)mItem2:(id)sender
{
NSLog(@"item2");
}
-(void)mItem3:(id)sender
{
NSLog(@"item3");
}
@end