iOS專案開發實戰——自定義圓形進度提示控制元件

乞力馬紮羅的雪CYF發表於2015-08-18

       iOS中預設的進度條是水平方向的進度條,這往往不能滿足我們的需求。但是我們可以自定義類似的圓形的進度提示控制元件,主要使用iOS中的繪圖機制來實現。這裡我們要實現一個通過按鈕點選然後圓形進度提示不斷增加的效果。

(1)新建一個Cocoa Touch Class,注意要繼承自UIView。這個是繪製圖形的類,繪製一個圓形的背景和扇形的進度。具體實現如下:

import UIKit

class ProgressControl: UIView {

    
    override init(frame: CGRect) {
        super.init(frame: frame)
        
        self.backgroundColor = UIColor(white: 1, alpha: 0)//初始化繪圖背景為白色;
    }
    
    required init(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
    }

    private var _progressValue:CGFloat = 0//這個就是當前的進度;
    
    func getProgressValue()->CGFloat{
    
        return _progressValue
    }
    
    func setProgressvalue(value:CGFloat){//設定進度;
    
        _progressValue = value
        
        setNeedsDisplay()
    }

    
    override func drawRect(rect: CGRect) {//繪製圓形背景和扇形進度;
        
        var context = UIGraphicsGetCurrentContext()
        
        var r = rect.width/2
        
        CGContextAddArc(context, r, r, r, 0, 3.1415926 * 2 , 0)
        CGContextSetRGBFillColor(context, 0.5, 0.5, 0.5, 1)
        CGContextFillPath(context)
        
        CGContextAddArc(context, r, r, r, 0, 3.1415926 * 2 * _progressValue, 0)
        CGContextAddLineToPoint(context, r, r)
        CGContextSetRGBFillColor(context, 0, 0, 1, 1)
        CGContextFillPath(context)
        
    }
    
}

(2)介面中拖入一個按鈕,拖拽Action事件。在ViewController中實現如下:

import UIKit

class ViewController: UIViewController {

    var progressControl:ProgressControl!
    
    override func viewDidLoad() {
        super.viewDidLoad()

        
        progressControl = ProgressControl(frame:CGRect(x: 100, y: 100, width: 100, height: 100))
        self.view.addSubview(progressControl)
        
    }
    
    //點選按鈕,增加進度
    @IBAction func addProgressValuePressed(sender: UIButton) {
        
        progressControl.setProgressvalue(progressControl.getProgressValue()+0.1)
        
    }
    
    

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


}

(3)最後的實現效果如下:



      對於其他的觸發事件,也可以使用這個自定義圓形進度控制元件來進行提示。


github主頁:https://github.com/chenyufeng1991  。歡迎大家訪問!

相關文章