zoukankan      html  css  js  c++  java
  • UINavigationController基本使用

    1、创建空iOS项目,名称为UINavigationItem Test:

    2、其次,要使得程序运行时能够显示Navigation Bar:

    2.1 单击AppDelegate.h,向其中添加属性:

    @property (strong, nonatomic) UINavigationController *navController;

    2.2 打开AppDelegate.m,在@synthesize viewController = _viewController;之后添加代码:

    @synthesize navController; #pragma mark - #pragma mark Application lifecycle

    2.3 修改didFinishLaunchingWithOptions方法代码如下:

    - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]]; // Override point for customization after application launch. self.viewController = [[ViewController alloc] initWithNibName:@"ViewController" bundle:nil]; self.navController = [[UINavigationController alloc] initWithRootViewController:self.viewController]; [self.window addSubview:navController.view]; [self.window makeKeyAndVisible]; return YES; }

    此时运行程序,会发现出现了Navigation Bar:

    下面讲一下关于NavigationItem的简单设置。

    3、设置标题:

    打开ViewController.m,在viewDidLoad方法中[super viewDidLoad];之后添加代码:

    self.navigationItem.title = @"标题";

    运行:

    4、自定义标题,设置titleView:

    如果我们想改变标题的颜色和字体,就需要自己定义一个UILabel,并且已经设置好这个Label的内容,可以设置自己想要的字体、大小和颜色等。然后执行self.navigationItem.titleView = myLabel;就可以看到想要的效果。

    4.1 打开ViewController.h,向其中添加属性:

    @property (strong, nonatomic) UILabel *titleLabel;

    4.2 打开ViewController.m,在@implementation ViewController下面一行添加代码:

    @synthesize titleLabel;

    4.3 在viewDidLoad方法中,去掉self.navigationItem.title = @"标题";,并添加代码:

    //自定义标题 titleLabel = [[UILabel alloc] initWithFrame:CGRectMake(0, 0 , 100, 44)]; titleLabel.backgroundColor = [UIColor clearColor]; //设置Label背景透明 titleLabel.font = [UIFont boldSystemFontOfSize:20]; //设置文本字体与大小 titleLabel.textColor = [UIColor colorWithRed:(0.0/255.0) green:(255.0 / 255.0) blue:(0.0 / 255.0) alpha:1]; //设置文本颜色 titleLabel.textAlignment = UITextAlignmentCenter; titleLabel.text = @"自定义标题"; //设置标题 self.navigationItem.titleView = self.titleLabel;

    运行:

    实际上,不仅仅可以将titleView设置成Label,只要是UIView的对象都可以设为titleView,例如,将4.3中的代码改成:

    UIButton *button = [UIButtonbuttonWithType: UIButtonTypeRoundedRect]; [button setTitle: @"按钮" forState: UIControlStateNormal]; [button sizeToFit]; self.navigationItem.titleView = button;

    则运行起来效果如下:

    5、为Navigation Bar添加左按钮

    以下是进行leftBarButtonItem设置的代码:

    self.navigationItem.leftBarButtonItem = (UIBarButtonItem *) self.navigationItem.leftBarButtonItems = (UIBarButtonItem *) self.navigationItemsetLeftBarButtonItem:(UIBarButtonItem *) self.navigationItemsetLeftBarButtonItem:(UIBarButtonItem *) animated:(BOOL) self.navigationItemsetLeftBarButtonItems:(NSArray *) self.navigationItemsetLeftBarButtonItems:(NSArray *) animated:(BOOL)

    其实很简单,只要定义好一个UIBarButtonItem,然后执行上述某行代码就行了。

    5.1 为了使得运行时不出错,我们在ViewController.m中添加一个空方法,由将要创建的左右按钮使用:

    //空方法 -(void)myAction { }

    5.2 添加一个左按钮:

    在ViewDidLoad方法最后添加代码:

    //添加左按钮 UIBarButtonItem *leftButton = [[UIBarButtonItem alloc] initWithTitle:@"左按钮" style:UIBarButtonItemStylePlain target:self action:@selector(myAction)]; [self.navigationItem setLeftBarButtonItem:leftButton];

    运行效果如下:

    创建一个UIBarButtonItem用的方法主要有:

    [UIBarButtonItemalloc]initWithTitle:(NSString *) style:(UIBarButtonItemStyle) target:(id) action:(SEL) [UIBarButtonItemalloc]initWithBarButtonSystemItem:(UIBarButtonSystemItem) target:(id) action:(SEL)

    在第一个方法中,我们可以使用的按钮样式有:

    UIBarButtonItemStyleBordered UIBarButtonItemStyleDone UIBarButtonItemStylePlain

    效果分别如下:

              

    看上去第一个和第三个样式效果是一样的。

    6、添加一个右按钮

    在ViewDidLoad方法最后添加代码:

    //添加右按钮 UIBarButtonItem *rightButton = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemUndo target:self action:@selector(myAction)]; self.navigationItem.rightBarButtonItem = rightButton;

    运行如下:

    这里创建UIBarButtonItem用的方法是

    [UIBarButtonItemalloc]initWithBarButtonSystemItem:(UIBarButtonSystemItem) target:(id) action:(SEL)

    用了系统自带的按钮样式,这些样式的标签和效果如下:

                      标签       效果                        标签          效果
     UIBarButtonSystemItemAction        UIBarButtonSystemItemPause     
     UIBarButtonSystemItemAdd        UIBarButtonSystemItemPlay      
     UIBarButtonSystemItemBookmarks        UIBarButtonSystemItemRedo      
     UIBarButtonSystemItemCamera        UIBarButtonSystemItemRefresh        
     UIBarButtonSystemItemCancel        UIBarButtonSystemItemReply      
     UIBarButtonSystemItemCompose       UIBarButtonSystemItemRewind      
     UIBarButtonSystemItemDone        UIBarButtonSystemItemSave      
     UIBarButtonSystemItemEdit       UIBarButtonSystemItemSearch      
     UIBarButtonSystemItemFastForward         UIBarButtonSystemItemStop      
     UIBarButtonSystemItemOrganize        UIBarButtonSystemItemTrash      
     UIBarButtonSystemItemPageCurl       UIBarButtonSystemItemUndo      

    注意,UIBarButtonSystemItemPageCurl只能在Tool Bar上显示。

    7、添加多个右按钮

    在ViewDidLoad方法中最后添加代码:

    //添加多个右按钮 UIBarButtonItem *rightButton1 = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemDone target:self action:@selector(myAction)]; UIBarButtonItem *rightButton2 = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFixedSpace target:nil action:nil]; UIBarButtonItem *rightButton3 = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemEdit target:self action:@selector(myAction)]; UIBarButtonItem *rightButton4 = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:nil action:nil]; UIBarButtonItem *rightButton5 = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemOrganize target:self action:@selector(myAction)]; NSArray *buttonArray = [[NSArray alloc] initWithObjects:rightButton1,rightButton2, rightButton3,rightButton4,rightButton5, nil]; self.navigationItem.rightBarButtonItems = buttonArray;

    为了更好的显示效果,把设置titleView以及设置leftBarButtonItem的代码注释掉,运行效果如下:

    上面的UIBarButtonSystemItemFixedSpace和UIBarButtonSystemItemFlexibleSpace都是系统提供的用于占位的按钮样式。

    8、设置Navigation Bar背景颜色

    在viewDidLoad方法后面添加代码:

    //设置Navigation Bar颜色 self.navigationController.navigationBar.tintColor = [UIColor colorWithRed:(218.0/255.0) green:(228.0 / 255.0) blue:(250.0 / 255.0) alpha:1];

    运行如下:

    9、设置Navigation Bar背景图片

    首先将准备好作为背景的图片拖到工程中,我用的图片名称是title_bg.png。

    将上面的代码改成:

    //设置Navigation Bar背景图片 UIImage *title_bg = [UIImage imageNamed:@"title_bg.png"]; //获取图片 CGSize titleSize = self.navigationController.navigationBar.bounds.size; //获取Navigation Bar的位置和大小 title_bg = [self scaleToSize:title_bg size:titleSize];//设置图片的大小与Navigation Bar相同 [self.navigationController.navigationBar setBackgroundImage:title_bg forBarMetrics:UIBarMetricsDefault]; //设置背景

    之后,在ViewController.m中添加一个方法用于调整图片大小:

    //调整图片大小 - (UIImage *)scaleToSize:(UIImage *)img size:(CGSize)size{ UIGraphicsBeginImageContext(size); [img drawInRect:CGRectMake(0, 0, size.width, size.height)]; UIImage* scaledImage = UIGraphicsGetImageFromCurrentImageContext(); UIGraphicsEndImageContext(); return scaledImage; }

    运行:

    navigationItem自定义风格

    UIButton *rightButton = [[UIButton alloc]initWithFrame:CGRectMake(002525)];

        [rightButton setBackgroundImage:[UIImageimageNamed:@"home_button_search"]forState:UIControlStateNormal];

        UIBarButtonItem *rightItem = [[UIBarButtonItem alloc]initWithCustomView:rightButton];

        self.navigationItem.rightBarButtonItem = rightItem;

  • 相关阅读:
    Selenium WebDriver
    Xpath常用语法
    firefox插件
    Echarts图中datazoom的相关配置
    js获取当前年月日
    echarts饼图角度起始角度位置和生长方向
    jS获取table表格任意单元格值
    jquery中 cache: true和false的区别
    Ajax请求中的async:false/true的作用 、cache: true和false的区别
    Cocos Creator set get
  • 原文地址:https://www.cnblogs.com/ranger-cc/p/3521455.html
Copyright © 2011-2022 走看看