UInavgationControlの背景色、任意のボタンの追加、スタイルの変更など

1683 ワード

テーマを見て、これは技術的な文章だと思わないでください.実は、これはテクニックです.
navの背景色や背景図の追加は面倒ではありませんが、常に行う効果は理想的ではないかもしれません.特に純色制御の面です.
ボタンの位置など、ボタンの追加も制御しにくい.
次に、navを通常設定する方法について説明します.
1.色の設定
これは比較的簡単で、tintColorを使って直接色を設定すればいいです
2.画像の設定
#define kSCNavBarImageTag 10
    if ([navBar respondsToSelector:@selector(setBackgroundImage:forBarMetrics:)])
    { 
        //if iOS 5.0 and later 
        [navBar setBackgroundImage:[UIImage imageNamed:@"nav_bg.png"] forBarMetrics:UIBarMetricsDefault];
    } 
    else 
    { 
        UIImageView *imageView = (UIImageView *)[navBar  viewWithTag:kSCNavBarImageTag];
        if (imageView == nil) 
        { 
            imageView = [[UIImageView alloc] initWithImage: 
                         [UIImage imageNamed:@"nav_bg.png"]];
            [imageView setTag:kSCNavBarImageTag]; 
            [navBar insertSubview:imageView atIndex:0];
            [imageView release]; 
        } 
    }
3.画像ボタンの追加
UIButton *rightBtn = [[UIButton alloc] initWithFrame:CGRectMake(0, 0, 47, 30)];
    [rightBtn setBackgroundImage:[UIImage imageNamed:@"news_topBtn_reload.png"] forState:UIControlStateNormal]; 
    [rightBtn addTarget:self action:@selector(reloadInfo) forControlEvents:UIControlEventTouchUpInside];
    UIBarButtonItem *rightBarItem = [[UIBarButtonItem alloc] initWithCustomView:rightBtn];
    [rightBtn release];
    self.navigationItem.rightBarButtonItem = rightBarItem;
以上の方法は完全に実現できる.しかし、実際の制御は難しい.特に純粋な色の設定ではグラデーション効果がありますが、必要ない場合があります.ボタンの位置などもあります
別の方法
delegateにNAVを追加すると、それを隠すことができます.後でNAVで直接上部に320*44のviewを追加します.そしてこのビューで勝手に操作すればいいです.やりたいことをやる