iOS学习(UI)知识点整理

一、UINavigationBar 的介绍

1)概念:UINavigationBar 是用于定义导航栏按钮的一个类对象

2)在使用UINavigationBar之前必须先初始化导航栏 实例代码:

 //初始化导航栏
FirstViewController *firstVC = [[FirstViewController alloc] init];
UINavigationController *nav = [[UINavigationController alloc] initWithRootViewController:firstVC];
self.window.rootViewController = nav; //appearance一定要在初始化之前使用
//修改默认的UINavigationBar的导航条背景颜色,
[[UINavigationBar appearance] setBarTintColor:[UIColor yellowColor]]; //修改默认的导航栏文字即图标颜色
[[UINavigationBar appearance] setTintColor:[UIColor blackColor]]; //设置导航栏背景图片
[[UINavigationBar appearance] setBackgroundImage:[UIImage imageNamed:@"icon"] forBarMetrics:UIBarMetricsDefault];

3)setNavigationBarHidden 设置隐藏导航栏  例如:

 [self.navigationController setNavigationBarHidden:YES];

4)title 设置导航栏标题  例如:

 self.title = @“First View”;
//注意:在一处做此设置后,后面的视图控制器如未作设置也会使用此标题

5)titleView 用于设置导航栏中间的视图 例如:

    UIView *navBarView = [[UIView alloc] init];
navBarView.frame = CGRectMake(, , , );
navBarView.backgroundColor = [UIColor clearColor];
navBarView.layer.cornerRadius = 8.0f;
navBarView.clipsToBounds = YES; UIButton *btn1 = [[UIButton alloc] init];
btn1.frame = CGRectMake(, , , );
btn1.backgroundColor = [UIColor blueColor];
[btn1 setTitle:@"消息" forState:UIControlStateNormal];
[btn1 addTarget:self action:@selector(btn1Tapped:) forControlEvents:UIControlEventTouchUpInside];
btn1.tag = ;
[navBarView addSubview:btn1]; UIButton *btn2 = [[UIButton alloc] init];
btn2.frame = CGRectMake(, , , );
btn2.backgroundColor = [UIColor blueColor];
[btn2 setTitle:@"电话" forState:UIControlStateNormal];
[btn2 addTarget:self action:@selector(btn1Tapped:) forControlEvents:UIControlEventTouchUpInside];
btn2.tag = ;
[navBarView addSubview:btn2]; //在导航栏中的中间位置加入我们自定义的view,
//程序会把我们设置的view自动居中
self.navigationItem.titleView = navBarView;

6)UIBarButtonItem 导航栏上的按钮元素  常用的系统自带的Bar有

/*
* UIBarButtonSystemItemDone  按钮样式为文字Done、
* UIBarButtonSystemItemAdd 按钮样式为图片的加号
*UIBarButtonSystemItemCamera 按钮样式是图片的照相机
     
*UIBarButtonSystemItemFixedSpace 是一个占位符 ,可以设置width
*UIBarButtonSystemItemFlexibleSpace 是一个占位符,固定宽度,导航栏上单独一个按钮
*/

例如:

 //系统自带照相机按钮
UIBarButtonItem *button1 = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemCamera
target:self action:@selector(barButtonTapped:)]; //占位符按钮
UIBarButtonItem *button2 = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace
target:self action:@selector(barButtonTapped:)];

7)rightBarButtonItem 设置导航栏右侧单个按钮 例如:

 self.navigationItem.rightBarButtonItem = button1;

8)rightBarButtonItems 设置导航栏右侧多个按钮 例如:

 self.navigationItem.rightBarButtonItems = @[button2, button1];

9)edgesForExtendedLayout 设置view的坐标都是从导航栏左下点开始计算 防止导航栏遮挡内容区域
例如:

 self.edgesForExtendedLayout = UIRectEdgeNone;

10)initWithTitle 使用文字作为导航栏按钮 例如:

 UIBarButtonItem *barButtonItem = [[UIBarButtonItem alloc] initWithTitle:@"返回" style:UIBarButtonItemStylePlain
target:self action:@selector(back)];

11)initWithImage 使用图片作为导航栏按钮 例如:

 UIBarButtonItem *barButtonItem = [[UIBarButtonItem alloc] initWithImage:[UIImage imageNamed:@"st_logout"] 
style:UIBarButtonItemStylePlain target:self action:@selector(back)];
self.navigationItem.leftBarButtonItem = barButtonItem;

12)setToolbarHidden 设置导航栏显示与隐藏 例如:

  [self.navigationController setToolbarHidden:NO];

13)动画效果实现 代码:

 - (void)viewDidLoad {
[super viewDidLoad];
self.view.backgroundColor=[UIColor whiteColor]; firstView=[[UIView alloc]init];
firstView.frame=CGRectMake(, , , );
firstView.backgroundColor=[UIColor blackColor];
[self.view addSubview:firstView];
for (int i=; i<; i++) {
UIButton *btn=[[UIButton alloc]init];
btn.frame=CGRectMake(,, CGRectGetWidth(self.view.frame), );
}
[self moveFirstViewToRight];
} -(void)moveFirstViewToRight{
//UIview 动画
[UIView animateWithDuration:.f animations:^{
firstView.frame=CGRectMake(self.view.frame.size.width-firstView.frame.size.width, , , );
}];
}
 

iOS阶段学习第31天笔记(UINavigationBar介绍)的更多相关文章

  1. iOS 阶段学习第11天笔记(OC基础知识)

    iOS学习(OC语言)知识点整理 一.OC基础知识 1)#import  用于导入头文件,预处理阶段加载引用,只加载一次. 2)OC 依赖于Foundation框架下的头文件Foundation.h, ...

  2. iOS 阶段学习第七天笔记(函数、递归)

     iOS学习(C语言)知识点整理笔记 一.函数 1)概念:具有特定功能的代码块的封装 2)函数的定义: 函数类型+函数名(形参列表) 函数类型 函数名(形参类型1  形参名1,形参类型2   形参名2 ...

  3. iOS阶段学习第四天笔记(循环)

    iOS学习(C语言)知识点整理笔记 一.分支结构 1.分支结构分为单分支 即:if( ){ } ;多分支 即:if( ){ }else{ }  两种 2.单分支 if表达式成立则执行{ }里的语句:双 ...

  4. iOS阶段学习第三天笔记(运算符)

    iOS学习(C语言)知识点整理笔记 1.运算符 一.算术运算符 1)表达式由变量.常量.运算符构成,有确定的类型和值 2)算术运算符包括: +(加),-(减),*(乘),/(除),%(模) 3)算术运 ...

  5. iOS 阶段学习第四天笔记(循环)

    iOS学习(C语言)知识点整理笔记 一.分支结构 1.分支结构分为单分支 即:if( ){ } ;多分支 即:if( ){ }else{ }  两种 2.单分支 if表达式成立则执行{ }里的语句:双 ...

  6. iOS 阶段学习第三天笔记(运算符)

    iOS学习(C语言)知识点整理笔记 1.运算符 一.算术运算符 1)表达式由变量.常量.运算符构成,有确定的类型和值 2)算术运算符包括: +(加),-(减),*(乘),/(除),%(模) 3)算术运 ...

  7. iOS阶段学习第34天笔记(UI小组件 UISegment-UISlider-UIStepper-UIProgressView-UITextView介绍)

    iOS学习(UI)知识点整理 一.UI小组件 1.UISegmentedControl 分段选择器  实例代码 - (void)viewDidLoad { [super viewDidLoad]; / ...

  8. iOS阶段学习第33天笔记(自定义标签栏(UITabBar)介绍)

    iOS学习(UI)知识点整理 一.自定义标签栏 1.方法一 单个创建标签栏 #import "AppDelegate.h" #import "SecondViewCont ...

  9. iOS阶段学习第32天笔记(页面传值方法介绍)

    iOS学习(UI)知识点整理 一.界面传值方法 1.方法一  Block传值  通过SubView视图的Block向View视图传值改变View视图的背景色 实例代码: 1)SubViewContro ...

随机推荐

  1. Vue.js2.0从入门到放弃---入门实例

    最近,vue.js越来越火.在这样的大浪潮下,我也开始进入vue的学习行列中,在网上也搜了很多教程,按着教程来做,也总会出现这样那样的问题(坑啊,由于网上那些教程都是Vue.js 1.x版本的,现在用 ...

  2. DDD~基础设施层~续

    回到目录 在之前写的DDD~基础设施层文章中,提到了UnitOfWork,它里面有一些方法,但经过项目证明,不应该有Save和IsExplicitSubmit,而这个工作单元只起到了数据上下文统一的作 ...

  3. WebApi系列~实际项目中如何使用HttpClient向web api发异步Get和Post请求并且参数于具体实体类型

    回到目录 本讲比较实际,在WEB端有一个Index和Create方法,用来从web api显示实体列表数据和向api插入实体对象,这就是以往的网站,只不过是把数据持久化过程放到了web pai上面,它 ...

  4. Atitit prj 项目管理与行政管理(1)------项目环境的概览与建立

    Atitit prj 项目管理与行政管理(1)------项目环境的概览与建立 1. 环境的4大特点 (1)多样性与复杂性. (2)差异性.(3)变异性.(4)关联性.2 2. 环境的分类,最常用使用 ...

  5. Android笔记——我的Android课的开始

    android 最底层的是什么?  硬件 介于硬件与软件之间的一个交互,你猜猜需要什么? 软件的上面一层便是各种的类库 硬件与软件之间的交互,就是需要驱动的进行. 1.android系统架构 1.Li ...

  6. How Google Tests Software - The Life of a TE

    By James WhittakerThe Test Engineer is a newerrole within Google than either SWEs or SETs. As such, ...

  7. IDE:Eclipse查看接口实现类快捷键

    1.打开接口类 2.双击接口名选中 3.Ctrl+T,打开接口实现类

  8. css多行文本省略号问题

    已知,单行文本溢出内容用省略号代替,css代码如下: text-overflow: ellipsis; 溢出部分用...代替 white-space: nowrap; //强制在一行显示 overfl ...

  9. KendoUI系列:ComboBox

    1.基本使用 1>.创建Input <input id="color" placeholder="Select Color..." /> &l ...

  10. javase基础复习攻略《八》

    进入第八篇,我们开始讨论JAVA的IO初步.在JAVA程序中,对数据的输入\输出操作以"流"(stream)方式进行,J2SDK提供了各种各样的"流"类,用于获 ...