Note 19 控件,手势,PickerView与AlertController

控件

一.都是继承UIControl ,可以addTarget()

forControlEvents: .ValueChanged
1.UISegmentedControl分段控件

提供单选能力
momentary(Bool) 是否记录状态

2.UISlide滑动条

maxmumValue/min....最大值,最小值
value 当前值
continuous 是否连续触发

3.Switch 开关

on (Bool) 是否是开启的状态

4.UIPageControl 分页
与上面的类似

二.PickerView :

与tableview类似

      let pickerView = UIPickerView(frame: CGRect(x: 0, y: 100, width: self.view.bounds.size.width, height: 200))
        pickerView.dataSource = self
        pickerView.delegate = self
        self.view.addSubview(pickerView)

pickerView:
1.pickerViewDatasource
func 多少comp
func 多少row
2.pickerViewDelegate
func title
func pickerView view可以重用

方法有的不是必须实现

    //列数
    func numberOfComponentsInPickerView(pickerView: UIPickerView) -> Int {
        return 3
    }

    func pickerView(pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        return 4
    }
    
//    func pickerView(pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
//        return "a"
//    }
    
    //可以重用
    func pickerView(pickerView: UIPickerView, viewForRow row: Int, forComponent component: Int, reusingView view: UIView?) -> UIView {
        if let v = view {
            print("reusing")
            v.backgroundColor = UIColor.redColor()
            return v
        }
        else {
            print("no reuse")
            let greenView = UIView()
            greenView.backgroundColor = UIColor.greenColor()
            return greenView
        }
    }
    
    func pickerView(pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
        print("\(component): \(row)")
    }

UIDatePicker 与 pickerview类似,但是实现起来简单

        let datePicker = UIDatePicker(frame: CGRect(x: 0, y: 300, width: self.view.bounds.size.width, height: 200))
//        datePicker.datePickerMode = .Date
        datePicker.datePickerMode = .Time
        datePicker.addTarget(self, action: #selector(didChange(_:)), forControlEvents: .ValueChanged)
        self.view.addSubview(datePicker)
        
         func didChange(sender: UIDatePicker) {
        print(sender.date) //NSDate
    }
DatePick:
        let datePick = UIDatePicker(frame: CGRect(x: 0, y: 300, width: self.view.frame.width, height: 100))
        datePick.addTarget(self, action: #selector(didDate(_:)), forControlEvents: .ValueChanged)
        datePick.datePickerMode = .DateAndTime
        //.Time//时:分:上午/下午
        //.Date//日期:时:分//.DateAndTime
        //日期:时:分:上午/下午 
        //.CountDownTimer //小时:分钟

三.UIWebView

        let webView = UIWebView(frame: self.view.bounds)
        webView.delegate = self
        
//        let url = NSURL(string: "http://ifeng.com")
//        let request = NSURLRequest(URL: url!)
//        webView.loadRequest(request)
        
//        let htmlStr = "

这是一个标题

" // webView.loadHTMLString(htmlStr, baseURL: nil) //1. 加载本地网页 let url = NSBundle.mainBundle().URLForResource("index", withExtension: "html") // let request = NSURLRequest(URL: url!) // webView.loadRequest(request) //2. let data = NSData(contentsOfURL: url!) webView.loadData(data!, MIMEType: "text/html", textEncodingName: "utf-8", baseURL: NSURL()) self.view.addSubview(webView)
    //1. 开始加载的时机
    //2. 可以过滤网址
    func webView(webView: UIWebView, shouldStartLoadWithRequest request: NSURLRequest, navigationType: UIWebViewNavigationType) -> Bool {
        let path = request.URL?.absoluteString
        
        print(path!)
        if path!.containsString("baidu.com") {
            return false
        }
        
        return true
    }
    
    func webViewDidStartLoad(webView: UIWebView) {
        //
    }
    
    func webViewDidFinishLoad(webView: UIWebView) {
        //如果需要操作网页,必须等加载完成
        let res = webView.stringByEvaluatingJavaScriptFromString("document.getElementsByTagName('img')")
        print(res)
        
        //w3school.com.cn
    }
    
    func webView(webView: UIWebView, didFailLoadWithError error: NSError?) {
        
    }

这个控件还没怎么使用暂时先mark下来

四UI( )GestureRecognizer

tap,screenEdgePanges,swipe,longPress等

        let tap = UITapGestureRecognizer(target: self, action: #selector(didTap(_:)))
        self.view.addGestureRecognizer(tap)
       
        let screenGes = UIScreenEdgePanGestureRecognizer(target: self, action: #selector(scGes(_:)))
        self.view.addGestureRecognizer(screenGes)
        screenGes.edges = UIRectEdge.Left
        
        let tapGesture = UITapGestureRecognizer(target: self, action: #selector(tap(_:)))
        self.view.addGestureRecognizer(tapGesture)
        
        let swipe1 = UISwipeGestureRecognizer(target: self, action: #selector(swipe01(_:)))
        swipe1.direction = .Down
        self.view.addGestureRecognizer(swipe1)
        
        let longPress = UILongPressGestureRecognizer(target: self, action: #selector(swipe02(_:)))
        self.view.addGestureRecognizer(longPress)

五UIAlertController

继承ViewController,也是一个页面,所以显示可以用present

        let alCtrl = UIAlertController(title: "警告", message: "别瞎点", preferredStyle: .Alert)
        let action1 = UIAlertAction(title: "返回", style: .Cancel) { (action) in
            let textfield = alCtrl.textFields![0]
            print(textfield.text)
        }
        alCtrl.addAction(action1)
        alCtrl.addTextFieldWithConfigurationHandler { (textf) in
        }
        self.presentViewController(alCtrl, animated: true, completion: nil)

AlertController页面里的输入框输入的文字可以通过Action的闭包传回来,这是使用输入文字的一个时机

你可能感兴趣的:(Note 19 控件,手势,PickerView与AlertController)