Swift基础之常用的UI控件(三)

在前两篇中介绍了UILabel、UIControl、UIButton和UITextField,在本篇文章中会介绍一下UIImageView、UITextView等等

UIImagevIew-图像视图

1.图像视图的创建

  let imageView = UIImageView(image:UIImage(named:"icon"))
  imageView.frame = CGRect(x: 10, y: 10, width: 100, height: 100)
  self.view.addSubview(imageView)
  //修改图片
  imageView.image = UIImage(named:"icon2")
  //保持图片比例
  imageView.contentMode = .scaleAspectFit

2.从文件目录中获取图片

  let path = Bundle.main.path(forResource: "apple", ofType: "png")
  let newImage = UIImage(contentsOfFile: path!)
  let imageView = UIImageView(image:newImage)
  self.view.addSubview(imageView)

3.从网络地址获取图片

 //定义NSURL对象
 let url = NSURL(string: "http://hangge.com/blog/images/logo.png")
 //从网络获取数据流
 let data = NSData(contentsOf: url! as URL)
 //通过数据流初始化图片
 let newImage = UIImage(data: data! as Data)
 let imageView = UIImageView(image:newImage);
 self.view.addSubview(imageView)

4.实现动画效果

  class ViewController: UIViewController {
 
       var imageView:UIImageView!
       override func viewDidLoad() {
       super.viewDidLoad()

       imageView=UIImageView()
       imageView.frame = CGRect(x: 10, y: 10, width: 100, height: 100)
       //设置动画图片
       imageView.animationImages=[UIImage(named:"icon")!,UIImage(named:"icon2")!]
       //设置每隔0.5秒变化一次
       imageView.animationDuration=0.5
       self.view.addSubview(imageView)
 }
 
 override func viewWillAppear(_ animated: Bool) {
    super.viewWillAppear(animated)
    imageView.startAnimating()
 }
 
 override func viewWillDisappear(_ animated: Bool) {
    super.viewWillAppear(animated)
    imageView.stopAnimating()
 }  
}

UITextView-多行文本输入框

1.UITextView的创建

    let textview = UITextView(frame:CGRect(x: 10, y: 10, width: 100, height: 100))
    textview.layer.borderWidth=1  //边框粗细
    textview.layer.borderColor=UIColor.gray.cgColor //边框颜色
    textview.backgroundColor = UIColor.clear //背景颜色
    textview.backgroundColor = UIColor.clear
    textview.isEditable = true //设置为可编辑状态
    //可选范围
    textview.selectedRange = NSRange(location: 0, length: Int.max)
    //内容是否可选
    textview.isSelectable=false
    self.view.addSubview(textview)

2.UITextView的代理方法

UITextView的代理方法与UITextField的代理方法非常类似,在这里就不过多介绍了。大家千万不要忘记设置代理哦。{{{(>_<)}}}

   func textViewShouldBeginEditing(_ textView: UITextView) -> Bool {
        print("开始输入")
        return true
   }
   func textViewDidBeginEditing(_ textView: UITextView) {
        print("已经开始输入")
   }
   func textViewShouldEndEditing(_ textView: UITextView) -> Bool {
        print("输入结束")
        return true
   }
   func textViewDidEndEditing(_ textView: UITextView) {
        print("已经输入结束")
   } 
   func textViewDidChange(_ textView: UITextView) {
        print("已经改变")
   }

UISwitch-开关按钮

    let switch1 = UISwitch()
    //设置开始位置
    switch1.center = CGPoint(x:100, y:100)
    //设置默认值
    switch1.isOn = true
    //添加事件
    switch1.addTarget(self, action: #selector(ViewController.switchDidChange), for: .ValueChanged)

UISegmentedControl-分段选择器

    //选项除了文字还可以是图片
    let items=["Hello" as AnyObject,"World" as AnyObject,UIImage(named: "star")!] as [AnyObject]
    let segmentedController=UISegmentedControl(items:items)
    segmentedController.center=self.view.center
    segmentedController.selectedSegmentIndex=1 //默认选中第二项
    segmentedController.addTarget(self, action: Selector("segmentDidchange:"),for: UIControlEvents.valueChanged)  //添加值改变监听
    self.view.addSubview(segmentedController)
定义点击事件方法
    func segmentDidchange(segmented:UISegmentedControl){
        //获得选项的索引
        print(segmented.selectedSegmentIndex)
        //获得选择的文字
        print(segmented.titleForSegmentAtIndex(segmented.selectedSegmentIndex))
    }
选择器中选项的添加、删除与修改
   //添加文字选项
   segmentedController.insertSegmentWithTitle("新增选项",atIndex:1,animated:true)
   //添加图片选项
   segmentedController.insertSegmentWithImage(UIImage(named:"icon")!,atIndex:1,animated: true)
   //移除选项
   segmentedController.removeSegmentAtIndex(1,animated:true)
   //修改选项颜色,包括图片
   segmentedController.tintColor=UIColor.blueColor()
   //修改选项文字
   segmentedController.setTitle("哎呦",forSegmentAtIndex:1)
   //修改选项图片
   segmentedController.setImage(UIImage(named:"icon"),forSegmentAtIndex:2)
   //修改选项内容偏移位置
   segmentedController.setContentOffset(CGSizeMake(10,7),forSegmentAtIndex:1)

UISlider-滑块

   let slider=UISlider(frame:CGRectMake(0,0,300,50))
   slider.center=self.view.center
   slider.minimumValue=0  //最小值
   slider.maximumValue=1  //最大值
   slider.value=0.5  //当前默认值
   //设置滑块的值,同时有动画
   slider.setValue(0.8,animated:true)
   slider.continuous=false  //滑块滑动停止后才触发ValueChanged事件
   slider.addTarget(self,action:"sliderDidchange:", forControlEvents:UIControlEvents.ValueChanged)
   self.view.addSubview(slider)

UIProgressView-进度条

  // 创建进度条
  var progressView=UIProgressView(progressViewStyle:UIProgressViewStyle.Default)
  progressView.center=self.view.center
  progressView.progress=0.5 //默认进度50%
  self.view.addSubview(progressView)
  //设置进度,同时有动画效果
  progressView.setProgress(0.8,animated:true)
  //改变进度条颜色
  progressView.progressTintColor=UIColor.greenColor()  //已有进度颜色
  progressView.trackTintColor=UIColor.blueColor()  //剩余进度颜色(即进度槽颜色)

UIStepper-微调器或叫步进器

    super.viewDidLoad()
    stepper=UIStepper()
    stepper.center=self.view.center
    //设置stepper的范围与初始值
    stepper.maximumValue=10
    stepper.minimumValue=1
    stepper.value=5.5
    //设置每次增减的值
    stepper.stepValue=0.5
    //设置stepper可以按住不放来连续更改值
    stepper.continuous=true
    //设置stepper是否循环(到最大值时再增加数值从最小值开始)
    stepper.wraps=true
    stepper.addTarget(self,action:"stepperValueIschanged",
    forControlEvents: UIControlEvents.ValueChanged)
    label=UILabel(frame:CGRectMake(100,100,300,30))
    label.text = "当前值为:\(stepper.value)"
使用tintColor属性可以设置微调器的颜色。 而加减符号图标,背景图片,中间分割线图片都可以替换成自己图片
//用自定义的图片替换“-”和“+”
stepper.setDecrementImage(UIImage(named: "sub.png"),forState: UIControlState.Normal)
stepper.setIncrementImage(UIImage(named: "add.png"), forState: UIControlState.Normal)

关于简单常用的UI控件今天就介绍到这里了,在接下来的文章中会继续介绍关于UIAlertView、UIActionSheet等控件,希望大家继续关注 O(∩_∩)O~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容