Swift基礎(chǔ)之常用的UI控件(三)

在前兩篇中介紹了UILabel、UIControl、UIButton和UITextField,在本篇文章中會(huì)介紹一下UIImageView佳恬、UITextView等等

UIImagevIew-圖像視圖

1.圖像視圖的創(chuàng)建

  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.從網(wǎng)絡(luò)地址獲取圖片

 //定義NSURL對(duì)象
 let url = NSURL(string: "http://hangge.com/blog/images/logo.png")
 //從網(wǎng)絡(luò)獲取數(shù)據(jù)流
 let data = NSData(contentsOf: url! as URL)
 //通過數(shù)據(jù)流初始化圖片
 let newImage = UIImage(data: data! as Data)
 let imageView = UIImageView(image:newImage);
 self.view.addSubview(imageView)

4.實(shí)現(xiàn)動(dòng)畫效果

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

       imageView=UIImageView()
       imageView.frame = CGRect(x: 10, y: 10, width: 100, height: 100)
       //設(shè)置動(dòng)畫圖片
       imageView.animationImages=[UIImage(named:"icon")!,UIImage(named:"icon2")!]
       //設(shè)置每隔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的創(chuàng)建

    let textview = UITextView(frame:CGRect(x: 10, y: 10, width: 100, height: 100))
    textview.layer.borderWidth=1  //邊框粗細(xì)
    textview.layer.borderColor=UIColor.gray.cgColor //邊框顏色
    textview.backgroundColor = UIColor.clear //背景顏色
    textview.backgroundColor = UIColor.clear
    textview.isEditable = true //設(shè)置為可編輯狀態(tài)
    //可選范圍
    textview.selectedRange = NSRange(location: 0, length: Int.max)
    //內(nèi)容是否可選
    textview.isSelectable=false
    self.view.addSubview(textview)

2.UITextView的代理方法

UITextView的代理方法與UITextField的代理方法非常類似毁葱,在這里就不過多介紹了。大家千萬不要忘記設(shè)置代理哦倾剿。{{{(>_<)}}}

   func textViewShouldBeginEditing(_ textView: UITextView) -> Bool {
        print("開始輸入")
        return true
   }
   func textViewDidBeginEditing(_ textView: UITextView) {
        print("已經(jīng)開始輸入")
   }
   func textViewShouldEndEditing(_ textView: UITextView) -> Bool {
        print("輸入結(jié)束")
        return true
   }
   func textViewDidEndEditing(_ textView: UITextView) {
        print("已經(jīng)輸入結(jié)束")
   } 
   func textViewDidChange(_ textView: UITextView) {
        print("已經(jīng)改變")
   }

UISwitch-開關(guān)按鈕

    let switch1 = UISwitch()
    //設(shè)置開始位置
    switch1.center = CGPoint(x:100, y:100)
    //設(shè)置默認(rèn)值
    switch1.isOn = true
    //添加事件
    switch1.addTarget(self, action: #selector(ViewController.switchDidChange), for: .ValueChanged)

UISegmentedControl-分段選擇器

    //選項(xiàng)除了文字還可以是圖片
    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 //默認(rèn)選中第二項(xiàng)
    segmentedController.addTarget(self, action: Selector("segmentDidchange:"),for: UIControlEvents.valueChanged)  //添加值改變監(jiān)聽
    self.view.addSubview(segmentedController)
定義點(diǎn)擊事件方法
    func segmentDidchange(segmented:UISegmentedControl){
        //獲得選項(xiàng)的索引
        print(segmented.selectedSegmentIndex)
        //獲得選擇的文字
        print(segmented.titleForSegmentAtIndex(segmented.selectedSegmentIndex))
    }
選擇器中選項(xiàng)的添加前痘、刪除與修改
   //添加文字選項(xiàng)
   segmentedController.insertSegmentWithTitle("新增選項(xiàng)",atIndex:1,animated:true)
   //添加圖片選項(xiàng)
   segmentedController.insertSegmentWithImage(UIImage(named:"icon")!,atIndex:1,animated: true)
   //移除選項(xiàng)
   segmentedController.removeSegmentAtIndex(1,animated:true)
   //修改選項(xiàng)顏色芹缔,包括圖片
   segmentedController.tintColor=UIColor.blueColor()
   //修改選項(xiàng)文字
   segmentedController.setTitle("哎呦",forSegmentAtIndex:1)
   //修改選項(xiàng)圖片
   segmentedController.setImage(UIImage(named:"icon"),forSegmentAtIndex:2)
   //修改選項(xiàng)內(nèi)容偏移位置
   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  //當(dāng)前默認(rèn)值
   //設(shè)置滑塊的值,同時(shí)有動(dòng)畫
   slider.setValue(0.8,animated:true)
   slider.continuous=false  //滑塊滑動(dòng)停止后才觸發(fā)ValueChanged事件
   slider.addTarget(self,action:"sliderDidchange:", forControlEvents:UIControlEvents.ValueChanged)
   self.view.addSubview(slider)

UIProgressView-進(jìn)度條

  // 創(chuàng)建進(jìn)度條
  var progressView=UIProgressView(progressViewStyle:UIProgressViewStyle.Default)
  progressView.center=self.view.center
  progressView.progress=0.5 //默認(rèn)進(jìn)度50%
  self.view.addSubview(progressView)
  //設(shè)置進(jìn)度示罗,同時(shí)有動(dòng)畫效果
  progressView.setProgress(0.8,animated:true)
  //改變進(jìn)度條顏色
  progressView.progressTintColor=UIColor.greenColor()  //已有進(jìn)度顏色
  progressView.trackTintColor=UIColor.blueColor()  //剩余進(jìn)度顏色(即進(jìn)度槽顏色)

UIStepper-微調(diào)器或叫步進(jìn)器

    super.viewDidLoad()
    stepper=UIStepper()
    stepper.center=self.view.center
    //設(shè)置stepper的范圍與初始值
    stepper.maximumValue=10
    stepper.minimumValue=1
    stepper.value=5.5
    //設(shè)置每次增減的值
    stepper.stepValue=0.5
    //設(shè)置stepper可以按住不放來連續(xù)更改值
    stepper.continuous=true
    //設(shè)置stepper是否循環(huán)(到最大值時(shí)再增加數(shù)值從最小值開始)
    stepper.wraps=true
    stepper.addTarget(self,action:"stepperValueIschanged",
    forControlEvents: UIControlEvents.ValueChanged)
    label=UILabel(frame:CGRectMake(100,100,300,30))
    label.text = "當(dāng)前值為:\(stepper.value)"
使用tintColor屬性可以設(shè)置微調(diào)器的顏色芝硬。 而加減符號(hào)圖標(biāo),背景圖片绍绘,中間分割線圖片都可以替換成自己圖片
//用自定義的圖片替換“-”和“+”
stepper.setDecrementImage(UIImage(named: "sub.png"),forState: UIControlState.Normal)
stepper.setIncrementImage(UIImage(named: "add.png"), forState: UIControlState.Normal)

關(guān)于簡單常用的UI控件今天就介紹到這里了皮官,在接下來的文章中會(huì)繼續(xù)介紹關(guān)于UIAlertView、UIActionSheet等控件藻丢,希望大家繼續(xù)關(guān)注 O(∩_∩)O~~~

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末摄乒,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子馍佑,更是在濱河造成了極大的恐慌,老刑警劉巖茵臭,帶你破解...
    沈念sama閱讀 212,454評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件舅世,死亡現(xiàn)場(chǎng)離奇詭異奇徒,居然都是意外死亡缨硝,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,553評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門胖笛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來宜岛,“玉大人,你說我怎么就攤上這事之斯∏猜粒” “怎么了?”我有些...
    開封第一講書人閱讀 157,921評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵瘫絮,是天一觀的道長填硕。 經(jīng)常有香客問我麦萤,道長,這世上最難降的妖魔是什么壮莹? 我笑而不...
    開封第一講書人閱讀 56,648評(píng)論 1 284
  • 正文 為了忘掉前任姻檀,我火速辦了婚禮,結(jié)果婚禮上胶台,老公的妹妹穿的比我還像新娘杂抽。我一直安慰自己,他們只是感情好缩麸,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,770評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著愚屁,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上梦谜,一...
    開封第一講書人閱讀 49,950評(píng)論 1 291
  • 那天,我揣著相機(jī)與錄音闭树,去河邊找鬼荒澡。 笑死,一個(gè)胖子當(dāng)著我的面吹牛单山,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播昼接,決...
    沈念sama閱讀 39,090評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼悴晰,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了漂辐?” 一聲冷哼從身側(cè)響起棕硫,我...
    開封第一講書人閱讀 37,817評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎饲帅,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體育八,經(jīng)...
    沈念sama閱讀 44,275評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡赦邻,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,592評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了按声。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,724評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡须床,死狀恐怖渐裂,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情柒凉,我是刑警寧澤,帶...
    沈念sama閱讀 34,409評(píng)論 4 333
  • 正文 年R本政府宣布坦刀,位于F島的核電站蔬咬,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏计盒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,052評(píng)論 3 316
  • 文/蒙蒙 一卜朗、第九天 我趴在偏房一處隱蔽的房頂上張望咕村。 院中可真熱鬧,春花似錦懈涛、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,815評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至拷呆,卻和暖如春疫粥,著一層夾襖步出監(jiān)牢的瞬間腰懂,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,043評(píng)論 1 266
  • 我被黑心中介騙來泰國打工慷彤, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留怖喻,地道東北人瞬欧。 一個(gè)月前我還...
    沈念sama閱讀 46,503評(píng)論 2 361
  • 正文 我出身青樓,卻偏偏與公主長得像唉侄,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子恬叹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,627評(píng)論 2 350

推薦閱讀更多精彩內(nèi)容