用swift开发仪表盘控件(二)

时间:2021-02-09 08:34:11

二、代码分析

这个控件本质就是从UIView继承的一个类而已。所以整个代码事实上就是一个定制的UIView类。

依据UIView的规则进行例如以下初始化:

required init(coder aDecoder: NSCoder) {

super.init(coder: aDecoder)

}

override init(frame: CGRect) {

self.pointer = UIImageView(image: UIImage(named:"pointer2.png"))

self.gaugeView = UIImage(named: "gaugeback.png")

self.frameCurr = frame

self.gv = GaugeParam(frame: frame)

super.init(frame: frame)

self.setFrameInit(frame)

}

构造函数没啥好说的。解释一下required init。假设继承了init(),就必须实现Required Initializers。

为了初始化类的參数设计了一个结构

struct GaugeParam{

var maxNum: Float = MAXVALUE

var minNum: Float = 0.00

var maxAngle: Float = MAXOFFSETANGLE

var minAngle: Float = -MAXOFFSETANGLE

var gaugeValue: Float = 0.00

var gaugeAngle: Float = -MAXOFFSETANGLE

var frame: CGRect

var angleperValue: Float{

get{

return (self.maxAngle - self.minAngle)/(self.maxNum- self.minNum)

}

}

var scaleNum: Float{

get{

return (Float(DEFLUATSIZE)/Float(self.frame.size.width))

}

}

init(frame:CGRect){

self.frame = frame

}

}

上面这个结构体挺简单的,没啥好解释的。

以下是重头戏了,GaugePanel是主类。全部操作都是在当中完毕的。

代码结构例如以下:

用swift开发仪表盘控件(二)

个别算法解释一下(老鸟请绕行):

func parseToX(radius: CGFloat,angle: CGFloat) -> CGFloat{

let temp = self.transToRadian(angle)

return radius*cos(temp)

}

初中平面几何的知识,知道半径和角度求X和Y坐标。

对pointToAngle(duration: CGFloat,angle: CGFloat)中的代码进行一下解释:

CATransform3DRotate(CATransform3DIdentity,self.transToRadian(CGFloat(gv.gaugeAngle) + distance*CGFloat(i)), 0, 0, 1)

这个是产生一个3D旋转,由于是平面旋转所以是环绕Z轴进行的,最后一个參数设置为1,self.transToRadian(CGFloat(gv.gaugeAngle)+ distance*CGFloat(i))是计算出一系列的角度。

values.addObject(NSValue(CATransform3D:v)),事实上CATransform3DRotate并不会马上产生旋转,而是加入到一个NSMutableArray数组中,NSMutableArray的元素不是AnyObject,须要用NSValue函数包装一下,真正发生旋转是在pointer.layer.addAnimation(ani,forKey: "any")进行的,ani包括了Values的内容。

override func drawRect(rect: CGRect)这个函数并没有显式的调用,是在containView.addSubview(panel)的时候被自己主动触发的。

好了。我要歇息了。希望这偏文章给swift的刚開始学习的人(事实上大家都是刚開始学习的人。老鸟也就是几个月的经验)有所帮助。对这个控件的谬误之处和改进意见能够和我联系.QQ:脐林 32819362。