UInavgationControlの背景色、任意のボタンの追加、スタイルの変更など
テーマを見て、これは技術的な文章だと思わないでください.実は、これはテクニックです.
navの背景色や背景図の追加は面倒ではありませんが、常に行う効果は理想的ではないかもしれません.特に純色制御の面です.
ボタンの位置など、ボタンの追加も制御しにくい.
次に、navを通常設定する方法について説明します.
1.色の設定
これは比較的簡単で、tintColorを使って直接色を設定すればいいです
2.画像の設定
別の方法
delegateにNAVを追加すると、それを隠すことができます.後でNAVで直接上部に320*44のviewを追加します.そしてこのビューで勝手に操作すればいいです.やりたいことをやる
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を追加します.そしてこのビューで勝手に操作すればいいです.やりたいことをやる