代码讲解:(后面有额外代码讲解)

首页设计UIPickerView的样式设计:

leftArray = ["花朵","颜色","形状"];

        

        let array1 = ["茉莉","玫瑰","郁金香","紫罗兰"];

        let array2 = ["红色","黄色","黑色","白色","紫色"];

        let array3 = ["圆形","方形","椭圆形"];

        righArray = [array1,array2,array3];

        

        let pickerV = UIPickerView.init(frame: CGRectMake(0, 100, self.view.frame.size.width, 260));

        //pickerV.backgroundColor = UIColor.brownColor();

        //设置是否显示选中状态

        pickerV.showsSelectionIndicator = true;

        //设置代理

        pickerV.dataSource = self;

        pickerV.delegate = self;

        self.view.addSubview(pickerV);

        

        let btn = UIButton.init(frame: CGRectMake(40, 380, F_Device_W()-40*2, 40));

        btn.setTitle("时间选择器", forState: UIControlState.Normal);

        btn.backgroundColor = UIColor.cyanColor();

        btn.layer.cornerRadius = 5;

        self.view.addSubview(btn);

        btn.addTarget(self, action: #selector(btnClick), forControlEvents:.TouchUpInside);

添加代理,执行必要的代理方法:

//MARK:---必须要实现的UIPickerViewDatasource的方法

    //返回几个分区

    func numberOfComponentsInPickerView(pickerView: UIPickerView) -> Int {

        return 2;

    }

    //返回各分区行数

    func pickerView(pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {

        if (component == 0)

        {

            return leftArray.count;

        }

        else

        {

            //获取选中第0分区的哪一行

            let row1 = pickerView.selectedRowInComponent(0);

            //然后根据获取的行号获取第1分区所对应的数据

            let arrarY = righArray.objectAtIndex(row1);

            return arrarY.count;

        }

    }

时间选择器UIDatePicker

//UIDatePicker时间选择器,继承于UIControl

        let datePick = UIDatePicker.init(frame: CGRectMake(0, 80, self.view.frame.size.width, 300));

        //设置显示时间样式,中or英,默认英文显示样式

        datePick.locale = NSLocale.init(localeIdentifier: "zh_CN");//中文

        datePick.backgroundColor = UIColor.lightGrayColor();

        //设置显示类型

        datePick.datePickerMode = UIDatePickerMode.DateAndTime;//日期和时间

        //设置默认的日期

        datePick.date = NSDate.init();

        //设置可以选择的最小日期

        datePick.minimumDate = NSDate.init(timeIntervalSinceNow: -(60*60*24*7));

        //设置可以选择的最大日期

        datePick.maximumDate = NSDate.init(timeIntervalSinceNow: 60*60*24*7);

        //添加方法获取显示的日期值

        datePick.addTarget(self, action: #selector(changeValueDate), forControlEvents: .ValueChanged);

        self.view.addSubview(datePick);

        

        

        dateLabel = UILabel.init(frame: CGRectMake(40, 390, self.view.frame.size.width-80, 50));

        dateLabel.textColor = UIColor.blueColor();

        dateLabel.textAlignment = NSTextAlignment.Center;

        self.view.addSubview(dateLabel);

        

    }

    

    func changeValueDate(datePickerV:UIDatePicker) {

        //获取当前选中的时间

        let dateE = datePickerV.date;

        

        //转换时间格式

        let formatterR = NSDateFormatter.init();

        formatterR.dateFormat = "yyyy-MM-dd hh:mm:ss";

        

        let dateStr = formatterR.stringFromDate(dateE);

        

        dateLabel.text = dateStr;

    }

额外代码讲解:

//MARK:---值得注意的是,Swift中没有了宏定义define,可以将宏定义写成func 方法进行调用

    //如:获取屏幕的宽  高方法

    func F_Device_W() -> CGFloat {

        return UIScreen.mainScreen().bounds.size.width;

    }

    func F_Device_H() -> CGFloat {

        return UIScreen.mainScreen().bounds.size.height;

    }

    

    //设置RGBA宏方法

    func RGBA (r:CGFloat, g:CGFloat, b:CGFloat, a:CGFloat) -> UIColor {

        return UIColor (red: r/255.0, green: g/255.0, blue: b/255.0, alpha: a);

    }

    

    //判断系统版本方法,方法的使用:如:navBar = UIView(frame: CGRectMake(0, 0, 320, IS_IOS7() ? 64:44))//三元运算

    func IS_IOS7() ->Bool { return (UIDevice.currentDevice().systemVersion as NSString).doubleValue >= 7.0;

    }

    func IS_IOS8() -> Bool { return (UIDevice.currentDevice().systemVersion as NSString).doubleValue >= 8.0;

    }

结果显示:

        

源码下载Demo:http://download.csdn.net/detail/hbblzjy/9592406

Swift基础之PickerView(时间)选择器的更多相关文章

  1. Android零基础入门第57节:日期选择器DatePicker和时间选择器TimePicker

    原文:Android零基础入门第57节:日期选择器DatePicker和时间选择器TimePicker 在实际开发中,经常会遇见一些时间选择器.日期选择器.数字选择器等需求,那么从本期开始来学习And ...

  2. picker-view、微信小程序自定义时间选择器(非官方)

    picker-view自定义时间选择器 官网的自定义时间选择器比较简陋.日期不准 下面是我自己写的一个demo <view class="baseList"> < ...

  3. swift基础:第二部分:函数和闭包

    今天本来想利用上午的时间本来打算将swift基础部分学习完的,不巧的是,后台来和我讨论用户评价的接口,讨论过后,商讨出一种可行的方案,十几分钟时间过去了,我拿到将接口介入到已经完成的页面中,完美,终于 ...

  4. Android PickerView滚动选择器的使用方法

    手机里设置闹钟需要选择时间,那个选择时间的控件就是滚动选择器,前几天用手机刷了MIUI,发现自带的那个时间选择器效果挺好看的,于是就自己仿写了一个,权当练手.先来看效果: 效果还行吧?实现思路就是自定 ...

  5. iOS-自定义起始时间选择器视图

    概述 自定义起始时间选择器视图, 调起时间选择器, 传值(起始时间/截止时间), 两者时间均要合理, 不能超过未来时间, 并且起始时间不能大于截止时间. 点击取消或空白处收起时间选择器. 详细 代码下 ...

  6. 微信小程序中利用时间选择器和js无计算实现定时器(将字符串或秒数转换成倒计时)

    转载注明出处 改成了一个单独的js文件,并修改代码增加了通用性,点击这里查看 今天写小程序,有一个需求就是用户选择时间,然后我这边就要开始倒计时. 因为小程序的限制,所以直接选用时间选择器作为选择定时 ...

  7. 移动端lCalendar纯原生js日期时间选择器

    网上找过很多的移动端基于zepto或jquery的日期选择器,在实际产品中也用过一两种,觉得都不太尽如人意,后来果断选择了H5自己的日期input表单,觉得还可以,至少不用引用第三方插件了,性能也不错 ...

  8. swift基础:第六部分:类与对象

    http://reactnative.cn/docs/0.24/getting-started.html#content(react Native 开发文档) 互联网这个时代,你松懈一天,就会有很多很 ...

  9. Swift基础语法学习总结(转)

    Swift基础语法学习总结 1.基础  1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...

随机推荐

  1. web缓存之--http缓存机制

    一.web缓存可以分为数据库缓存.代理服务器缓存.浏览器缓存. 其中浏览器缓存又包含很多内容:http缓存.indexDb.cookie.localStorage等.本片只讨论http缓存相关内容. ...

  2. electron应用以管理员权限启动

    最近在用electron开发PC桌面应用,其中有个需求就是整个应用以管理员权限启动.很头痛,各种google,baidu. 最后终于解决了,可以分为三个步骤,做个总结分享. 一.如果没有manifes ...

  3. 剑指架构师系列-持续集成之Maven实现项目的编译、发布和部署

    Maven组织项目进行编译.部署 Maven项目基本的结构说明如下: mazhi  // 控制所有荐的编译.部署.发布 mazhi-app-parent  // 项目的父项目,有一些公共的设置可以被子 ...

  4. C++笔记002:VS2010报错:LINK fatal error LNK1123 转换到 COFF 期间失败文件无效或损坏

    原创笔记,转载请注明出处! 点击[关注],关注也是一种美德~ 错误描述: 1>------ 已启动生成: 项目: FirstCode, 配置: Debug Win32 ------ 1>生 ...

  5. String字符串的操作

    字符串的常用操作 # Author:nadech name = "my name is nadech" print(name.count("a")) print ...

  6. ACM Strange fuction

    现在,这里有一个功能:  F(x) = 6 * x^7+8*x^6+7*x^3+5*x^2-y*x (0 <= x <=100) 当x在0到100之间时,你能找到最小值吗? 输入 第一行包 ...

  7. linux找不到动态链接库 .so文件的解决方法(转自:http://www.cnblogs.com/xudong-bupt/p/3698294.html)

    linux找不到动态链接库 .so文件的解决方法 如果使用自己手动生成的动态链接库.so文件,但是这个.so文件,没有加入库文件搜索路劲中,程序运行时可能会出现找不到动态链接库的情形. 可以通过ldd ...

  8. Swift中方法闭包参数不能省略括号的一种情况

    大熊猫猪·侯佩原创或翻译作品.欢迎转载,转载请注明出处. 如果觉得写的不好请多提意见,如果觉得不错请多多支持点赞.谢谢! hopy ;) 我们知道在swift中,如果方法的最后一个参数是一个闭包类型, ...

  9. Dynamics CRM 自定义上传附件的图片悬浮层显示

    CRM中的附件是以流的形式保存在了数据库中,这样做的一个坏处是一旦系统运行时间久,附件上传的多了势必会导致数据库极速扩大,即影响系统的运行效率也对后期的迁移维护带来了不必要的麻烦.所以很多的客户都会要 ...

  10. android最新更新方法

    使用SDK Manager更新时出现问题Failed to fetch URL https://dl-ssl.google.com/android/repository/repository-6.xm ...