日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

iOS 实现加载转圈效果

發布時間:2025/7/14 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 iOS 实现加载转圈效果 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

1、思路:

新建一個view,添加shape,給予一個動畫實現。

?

2、效果圖:

效果1:

?

效果2:

?

?

gif有點卡,代碼運行不會這樣。

?

3、源碼(整個類放進來的)

效果1源碼:

// // YJDownloadingCircle.swift // k12_sl_iOS // // Created by liyajun on 2017/7/13. // // import UIKitclass YJDownloadingCircle: UIView {var loadingLayer:CAShapeLayer! = niloverride init(frame: CGRect) {super.init(frame: frame)initViews()}required init?(coder aDecoder: NSCoder) {super.init(coder: aDecoder)initViews()}override func awakeFromNib() {initViews()}func initViews() {backgroundColor = UIColor.white}func drawHalfCircle() {loadingLayer = self.drawCircle()loadingLayer.strokeStart = 0.0loadingLayer.strokeEnd = 0.75let basicAni = CABasicAnimation(keyPath: "transform.rotation.z")basicAni.fromValue = 0.0basicAni.toValue = M_PI*2basicAni.duration = 0.5basicAni.repeatCount = MAXFLOATbasicAni.autoreverses = falsebasicAni.fillMode = kCAFillModeForwardsself.layer.add(basicAni, forKey: nil)}private func drawCircle() -> CAShapeLayer {let circleLayer = CAShapeLayer()let rect = CGRect(x: 0, y: 0, width: self.frame.size.width, height: self.frame.size.height)circleLayer.frame = rectcircleLayer.position = CGPoint(x: self.frame.size.width/2, y: self.frame.size.height/2)circleLayer.fillColor = UIColor.clear.cgColorcircleLayer.lineWidth = 1circleLayer.strokeColor = UIColor.colorWithHex(hex: "FF3B30").cgColorlet bezier = UIBezierPath(ovalIn: rect)circleLayer.path = bezier.cgPathself.layer.addSublayer(circleLayer)return circleLayer} } View Code

使用方法

//定義屬性var circle:YJDownloadingCircle! = nil override func viewDidLoad() {super.viewDidLoad()view.backgroundColor = UIColor.whitecircle = YJDownloadingCircle(frame: CGRect(x: 100, y: 100, width: 36, height: 36))circle.drawHalfCircle()self.view.addSubview(circle)}

?

效果2源碼:

// // LoginLoadingView.swift // k12_sl_iOS // // Created by liyajun on 2018/5/30. // import UIKitclass LoginLoadingView: UIView {var bgShape:CAShapeLayer! = nilvar runShape:CAShapeLayer! = nilvar lblShape:CAShapeLayer! = nillet startAngle:CGFloat = 0;let endAngle:CGFloat = CGFloat(0.67 * M_PI);let lineWidth:CGFloat = 5;override init(frame: CGRect) {super.init(frame: frame)setup()}required init?(coder aDecoder: NSCoder) {super.init(coder: aDecoder)setup()}func setup() {bgShape = CAShapeLayer()let bgPath = CGMutablePath()bgPath.addEllipse(in: CGRect(x: 0, y: 0, width: self.width, height: self.height))bgShape.fillColor = UIColor.clear.cgColorbgShape.strokeColor = UIColor.colorWithHex("4CD964").withAlphaComponent(0.5).cgColorbgShape.lineWidth = lineWidthbgShape.lineJoin = kCALineJoinRoundbgShape.lineDashPattern = [NSNumber(value: 4),NSNumber(value:4)]bgShape.path = bgPathself.layer.addSublayer(bgShape)runShape = CAShapeLayer()let runPath = UIBezierPath(arcCenter: CGPoint(x: 0, y: 0), radius: self.width/2, startAngle: startAngle, endAngle: endAngle, clockwise: false)runShape.fillColor = UIColor.clear.cgColorrunShape.strokeColor = UIColor.colorWithHex("4CD964").cgColorrunShape.lineWidth = lineWidthrunShape.lineJoin = kCALineJoinRoundrunShape.path = runPath.cgPathrunShape.position = CGPoint(x: self.width/2, y: self.width/2)self.layer.addSublayer(runShape)let anima = CABasicAnimation(keyPath: "transform.rotation.z")anima.fromValue = 0anima.toValue = M_PI*2anima.repeatCount = MAXFLOATanima.duration = 2.0anima.isRemovedOnCompletion = falserunShape.add(anima, forKey: "rotationAnnimation")lblShape = CAShapeLayer()let gouPath = UIBezierPath()gouPath.move(to: CGPoint(x: self.width/2-10, y: self.width/2-1))gouPath.addLine(to: CGPoint(x: self.width/2, y: self.width/2+10))gouPath.addLine(to: CGPoint(x: self.width/2+15, y: self.width/2-10))lblShape.fillColor = UIColor.clear.cgColorlblShape.strokeColor = UIColor.colorWithHex("4CD964").cgColorlblShape.lineWidth = lineWidthlblShape.lineJoin = kCALineJoinRoundlblShape.path = gouPath.cgPathself.layer.addSublayer(lblShape)}} View Code

使用時,直接init出來就是了

?

以上的效果都是只有一個類文件(UIView),使用時直接拷貝即可。

其中,關于轉圈的前景色、背景色等參數,我沒抽出來,大家如果有這需求,可以改一下。

?

代碼是Swift實現加載轉圈效果。

如果是OC,參考代碼思路即可。

?

?

enjoy~

?

轉載于:https://www.cnblogs.com/yajunLi/p/7159607.html

總結

以上是生活随笔為你收集整理的iOS 实现加载转圈效果的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 99精品区 | 一区二区三区四区高清视频 | 孕妇毛片 | 91官网在线 | 欧美三级一区二区 | 九七伦理电影 | 欧美视频自拍偷拍 | 91久久精品日日躁夜夜躁欧美 | 91免费黄| 一个人在线免费观看www | 韩国黄色片网站 | www,四虎 | 无码日韩精品一区二区 | 欧美综合色区 | 综合色在线视频 | 操你妹影院 | 成人性生交大片免费看中文 | 黄色在线免费视频 | 国产96在线 | 亚洲 | 九九精品视频免费 | 精品日韩av| 制服 丝袜 综合 日韩 欧美 | 国产精品传媒一区二区 | 欧美日韩生活片 | 精东影业一区二区三区 | jizzjizzjizz亚洲| 在线播放av片| 在线视频亚洲色图 | 国产 日韩 一区 | 日韩av高清无码 | 韩国三级bd高清中字2021 | 免费黄网在线观看 | 超碰狠狠操 | 成人第一页 | 久久久久成人网 | 日本黄色三级网站 | 波多野结衣成人在线 | 日韩欧美三级视频 | 久久夜精 | 一级淫片免费看 | 国产精品自拍视频 | 成人两性视频 | 瑟瑟视频在线免费观看 | 精品人妻无码一区二区三区换脸 | 天天夜夜人人 | 无码国精品一区二区免费蜜桃 | 免费看日韩毛片 | 日本不卡一 | 大奶子网站 | 黄色三级网站在线观看 | 国产一区二区视频在线 | 欧美专区在线播放 | 国产妞干网 | 尤物国产在线 | 精品一区二区久久久久久久网站 | 北条麻妃一区二区三区 | 精品国产18久久久久久 | 国产免费成人在线视频 | av色欲无码人妻中文字幕 | 日本在线视频免费 | 欧美日韩亚洲色图 | 成人做爰69片免费 | 日日操操 | 91国产丝袜播放在线 | 国产在线操 | 爱情岛论坛成人av | 成人涩涩| 九一在线观看免费高清视频 | 国产第9页 | 久久国产精品免费观看 | 尤物视频免费观看 | 国产视频你懂得 | 色丁香久久| 黄色中文字幕在线观看 | 91在线精品视频 | 在线中文字幕视频 | 国产超碰97| 成年人黄视频 | 五月亚洲| 91丝袜国产在线播放 | 欧美大喷水吹潮合集在线观看 | 成人公开免费视频 | 成人动漫一区二区三区 | 久久婷婷五月国产色综合激情 | 日韩精品久久久久久久酒店 | 黑人玩弄人妻一区二区三区影院 | 欧美极品一区二区 | 伊人久久国产精品 | 亚洲天堂国产 | 欧美精品亚洲精品日韩精品 | 国产成人精品无码播放 | 少妇2做爰hd韩国电影 | 天天尻逼 | 成人av在线资源 | 国产黄在线免费观看 | 国产一区视频在线播放 | 日韩亚洲精品在线 | 亚洲天堂资源 | 欧美激情性做爰免费视频 |