画面的构成
CocoaTouch编程中,一个应用程序里面可以包含多个画面。通过列表选择来显示,或者通过下方的标签来显示,等等。CocoaTouch中将这样一个一个的画面成为View。
如果只是创建一个View,不能实现一个完整的应用程序。这里,必须生成Outlet和Action,这样才能将程序与View连接起来。比如取得View中配置控件的信息,更改其内容等。像这样,加入View中程序称为Controller。或者针对与View的「ViewController」。InterfaceBuilder中的「ViewController」就是用在创建Outlet和Action的「File'sOwner」。
data:image/s3,"s3://crabby-images/c21ad/c21addd5979d30cbf6616318aa46297b65428de3" alt="ViewController"
View与Controller的关系
可以看出,多个View就要对于多个ViewController。简单起见,这里我们首先实现一个画面的应用程序。
控件调整
自动调整功能
data:image/s3,"s3://crabby-images/a0b5e/a0b5ecf7bb872787e260052aad2155f55226d754" alt="auto"
位置调节
用InterfaceBuilder配置控件的时候,如上图所示会显示蓝色的虚线。这是建议你放置的***位置。有效地利用IDE提供的机能,可以很好地设计出造作简便的View。
调整控件文字大小
选择想要更改的控件,在InterfaceBuilder菜单中选择「Font」→「ShowFonts」。如下图所示:
data:image/s3,"s3://crabby-images/7dfe8/7dfe80e0e9a07f991d4e5e2d5d6cd1ccd58f6f87" alt="fonts"
选择字体,大小
data:image/s3,"s3://crabby-images/75109/751095f0c2467e81cd686c0a272322e297f1c220" alt="fonts"
调整字体,大小
文字的大小不可能超过控件的大小。通过选择「Layout」→「SizeToFit」可以是字体大小匹配控件大小。
data:image/s3,"s3://crabby-images/98c5b/98c5b60590afc4a1b59a9ced085484f9dd5fe1de" alt="fonts"
SizeToFit
各种控件
这里介绍一些常用的控件。都是通过用户的操作会引起Action的控件。
RoundRectButton
RoundRectButton就是一般的按钮,只是四角为圆角。配置在View上,后可以输入文字。
data:image/s3,"s3://crabby-images/3322e/3322e5e2a16268053469ee7bfa60b59ff35fae2f" alt="Round Rect Button"
RoundRectButton的配置
选择Action的时候,「TouchDown」是当按钮被按下的时候发生的Action。
data:image/s3,"s3://crabby-images/44f8c/44f8c34dca96bb64b36b17be0c473b8bddae803e" alt="Round Rect Button"
RoundRectButton的Action
Switch
Switch就是一个开关控件。具有开和关两个状态,每次切换的时候都会产生Action。
data:image/s3,"s3://crabby-images/6f8a9/6f8a94eacfbfb317d35f3651f3acb646cfb2a881" alt="Switch"
Switch的配置
data:image/s3,"s3://crabby-images/5d87f/5d87f4a88fdb0bc84bfa5d546a8f0220f10c1f0e" alt="Switch"
初期状态设置
data:image/s3,"s3://crabby-images/67203/672039d4a15504e8127a4c542770adc93e8c6cf5" alt="Switch"
Switch的Action—ValueChanged
比如,当开关控件的Outlet为[outletisOn],其Action可以定义为:
-(IBAction)myAction1:(id)sender{
if([senderisOn]==YES){
...
//开关控件为ON时的处理
}
}
Slider
data:image/s3,"s3://crabby-images/fe29e/fe29e0bebf998c36323c99204ec782d3fe1613cc" alt="Slider"
Slider控件的配置
data:image/s3,"s3://crabby-images/f2443/f24433f980380d23e924e2593d39a5f17b44744a" alt="Slider"
Slider控件的范围设置
Slider的Action为「ValueChanged」,即是说当设定值变化的时候就会发生相应的Action。
data:image/s3,"s3://crabby-images/20bef/20bef78876fbaee4dc66fa3dd363c12ce204b276" alt="Slider"
Slider控件的Action
通过Slider控件的Outlet我们可以想下面的代码一样实现Action。
-(IBAction)myAction1:(id)sender{
if([(UISlider*)sendervalue]==0.5f){
...
//Slider的值为0.5时的处理
}
}