UIStepper

在iOS5中增加了一个UIStepper的新控件,UIStepper可以连续增加或减少一个数值。控件的外观是两个水平并排的按钮构成,一个显示为“+”,一个显示为“-”。如下图所示:



该控件一个有趣的特征是当用户按住“+”“-”按钮时,根据按住的时间长度,控件值的数字也以不同的数字改变。按住的时间越长,数值改变的越快。可以为UIStepper设定一个数值范围,比如0-99。

下面是UIStepper应用范例代码:

01 // Create a label to show the value in the stepper
02 label = [[UILabel alloc] initWithFrame:CGRectMake(10, 20, 100,30)];   
03 [label setTextColor:[UIColor whiteColor]];
04 [label setBackgroundColor:[UIColor clearColor]];
05 [label setTextAlignment:UITextAlignmentLeft];
06 [label setText: @"Quantity:"];
07 [[self view] addSubview:label];
08  
09 // Frame defines location, size values are ignored
10 UIStepper *stepper = [[UIStepper alloc]initWithFrame:CGRectMake(120, 20, 0,0)];   
11  
12 // Set action target and action for a particular value changedevent
13 [stepper addTarget:self action:@selector(stepperPressed:)forControlEvents:UIControlEventValueChanged];
14  
15 // Set min and max
16 [stepper setMinimumValue:0];
17 [stepper setMaximumValue:99];
18  
19 // Value wraps around from minimum to maximum
20 [stepper setWraps:YES];
21  
22 // If continuos (default), changes are sent for each change instepper,
23 // otherwise, change event occurs once user lets up onbutton
24 [stepper setContinuous:NO];
25  
26 // To change the increment value for each step
27 // (default is 1)
28 [stepper setStepValue:10];


UIStepper是一个类似UISwitch的控件,但是左右两边是一个加号和一个减号
这是iOS 5新增的控件

文档中的一些属性和方法:

配置 Stepper

  •   continuous  属性 BOOL类型,默认YES,YES时表示当用户交互时会立刻发送ValueChange事件,NO则是只有等用户交互
  • 结束时才发送ValueChange事件
  •   autorepeat  属性 BOOL类型,默认YES,YES时表示按住加号或减号不松手,数字会持续变化
  •   wraps  属性 BOOL类型,默认NO,YES时当value加的超过maximumValue,value将变成minimumValue的值,当减的
  • 比minimumValue还小,则value变成maximum的值。如果设成NO,这value不会超过最大和最小值
  •   minimumValue  属性 Double型 默认为0,最小值,当设置值大于或等于maximumValue时会报一个NSInvalidArgumentException异常
  •   maximumValue  属性 Double型 默认为100,是Stepper的最大值,当设置小于或等于minimumValue时会报一个
  • NSInvalidArgumentException异常
  •   stepValue  属性 Double型默认为1,Stepper的增量或者步数(例如stepValue 是10,则点一下加就加10,减也是减10),
  • 必须大于0,否则会报一个NSInvalidArgumentException异常
  • 访问 Stepper的值
  •   value  属性 Double型默认是0,上限是maximumValue 下限是minimumValue,当数值改变时,会发送
  • UIControlValueEventChanged给目标
  • 定制化外观
  •   tintColor  属性 UIColor型,默认是nil,iOS6新增

例子:
testStepper.stepValue = 10;
testStepper.minimumValue = 0;
testStepper.maximumValue = 55;
testStepper.value = 10;
testStepper.tintColor = [UIColor redColor];
testStepper.wraps = YES;
一开始就一直点加,则值的变化为 20 30 40 50 55
一开始就一直点减,则值的变化为 0 
当到达上限或下限时,且wraps没有设置成YES,则相应的加或减的按钮会disable
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了安卓应用、小程序、Python应用和Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。
UIKit是iOS开发中的重要框架之一,其中包括了许多用于构建应用程序的组件和工具。UIKit提供了一些常用的板块,这些板块涉及到了iOS应用程序的各个方面,如UI界面的设计、用户交互、数据管理、多媒体处理等等。 其中,UI界面设计板块是UIKit中最重要的部分之一。它提供了许多视图和控件,可以帮助开发人员快速构建出漂亮、易于使用的应用程序界面。这些视图和控件包括UILabel、UITextField、UITextView、UIButton、UISwitch、UIStepper等等,涵盖了文本、图像、输入、输出、按钮、滑块、分段控制等常用UI元素。 在用户交互板块中,UIKit提供了一些常用的手势识别器,如UITapGestureRecognizer、UIPanGestureRecognizer、UISwipeGestureRecognizer等等,可以帮助开发人员捕捉用户的手势操作,并进行相应的处理。此外,UIKit还提供了一些常用的界面元素,如UIAlertController、UIActionSheet等等,用于展示和管理应用程序的警告、提示、菜单等信息。 在数据管理板块中,UIKit提供了一些常用的数据存储和处理组件,如NSUserDefaults、NSFileManager、CoreData等等,可以帮助开发人员管理应用程序中的数据。此外,UIKit还提供了一些用于处理网络请求和访问外部资源的组件,如NSURLRequest、NSURLConnection、NSURLSession等等。 最后,在多媒体处理板块中,UIKit提供了一些常用的音频和视频处理组件,如AVFoundation、AVPlayer、AVAudioPlayer等等,可以帮助开发人员在应用程序中添加音频和视频播放功能。 总之,UIKit提供了丰富的组件和工具,可以帮助开发人员快速构建出漂亮、易于使用的iOS应用程序。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值