真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

iOS如何實(shí)現(xiàn)水波紋動(dòng)畫(huà)效果-創(chuàng)新互聯(lián)

這篇文章主要為大家展示了“iOS如何實(shí)現(xiàn)水波紋動(dòng)畫(huà)效果”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“iOS如何實(shí)現(xiàn)水波紋動(dòng)畫(huà)效果”這篇文章吧。

成都創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:網(wǎng)站設(shè)計(jì)制作、網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿(mǎn)足客戶(hù)于互聯(lián)網(wǎng)時(shí)代的長(zhǎng)順網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

,首先要知道以下幾點(diǎn)知識(shí):

1.正弦函數(shù):y = Asin(wx +b) + c。相信大家都比較熟悉。

2.CAShapeLayer的簡(jiǎn)單實(shí)用,相信看一下,就是知道其大概的用途了,形狀Layer層。和用戶(hù)顯示圖形的Layer,繼承于layer,好了,廢話(huà)不多說(shuō),直接上圖吧。

上面的知識(shí)點(diǎn),我會(huì)以代碼的方式,梳理上面的知識(shí)點(diǎn),不過(guò)首先我還是上傳效果圖吧,有圖有真相,才是事實(shí)嘛。

1.效果圖:

iOS如何實(shí)現(xiàn)水波紋動(dòng)畫(huà)效果

下面開(kāi)始上代碼。

2.創(chuàng)建變量

//這里的lazy:是懶加載 就是OC中重寫(xiě)get,set方法 
lazy var waveDisplaylink = CADisplayLink()//相比NSTimer下,這里用CADisplayLink主要是精確點(diǎn),其頻率:1/60 
lazy var firstWaveLayer = CAShapeLayer() 
lazy var secondWaveLayer = CAShapeLayer() 
/// 基礎(chǔ)描述 正弦函數(shù) 
///  y=Asin(ωx+φ)+ b 
///  A : wavaA 
///  w : 1/waveW 
///  φ : offsetφ 
///  b : b 
private var waveA: CGFloat = 0 
private var waveW: CGFloat = 0 
private var offsetX: CGFloat = 0 
private var b : CGFloat = 0 
//水紋的移動(dòng)的速度 
var waveSpeed : CGFloat = 0

上面的變量的,都有相關(guān)的注釋?zhuān)揖筒辉僮鼋忉屃恕?/p>

3.數(shù)據(jù)的初始化

//MARK: - 數(shù)據(jù)的初始化 
private func initData(){ 
  waveSpeed = 0.05 
  waveA = 8 
  // 設(shè)置周期 :( 2* M_PI)/waveW = bounds.size.width 。因?yàn)樯婕暗氖莑ayer,所以只談bounds,不說(shuō)frame 
  waveW = 2 * CGFloat(M_PI) / bounds.size.width 
  b = bounds.size.height / 2 
}

4.UI的初始化

private func configUI(){ 
   firstWaveLayer.fillColor = UIColor.init(colorLiteralRed: 69/255.0, green: 255/255.0, blue: 255/255.0, alpha: 0.5).cgColor 
   secondWaveLayer.fillColor = UIColor.init(colorLiteralRed: 69/255.0, green: 255/255.0, blue: 255/255.0, alpha: 0.5).cgColor 
   layer.addSublayer(firstWaveLayer) 
   layer.addSublayer(secondWaveLayer) 
   waveDisplaylink = CADisplayLink(target: self, selector: #selector(getCurrentWave)) 
   waveDisplaylink.add(to: RunLoop.current, forMode: .commonModes) 
 }

這里創(chuàng)建兩個(gè)shapeLayer,因?yàn)檫@樣的話(huà),可以才像水的波紋不是?,這里還有個(gè)要說(shuō)的是CADisplayLink,主要是他比NSTimer更精準(zhǔn),屏幕刷新頻率(FPS)是60,,iOS設(shè)備的刷新頻率是固定的,正常情況下回再每次刷新結(jié)束后都調(diào)用,也就是60次/s.所以選擇CADisplayLink。

5.下面的關(guān)鍵部分,代碼如下:

@objc private func getCurrentWave() { 
  offsetX += waveSpeed 
  setCurrentStatusWavePath() 
} 
//MARK: - 關(guān)鍵部分 
private func setCurrentStatusWavePath() { 
  // 創(chuàng)建一個(gè)路徑 
  let firstPath = CGMutablePath() 
  var firstY = bounds.size.width/2 
  firstPath.move(to: CGPoint(x: 0, y: firstY)) 
  for i in 0...Int(bounds.size.width) { 
    firstY = waveA * sin(waveW * CGFloat(i) + offsetX) + b 
    firstPath.addLine(to: CGPoint(x: CGFloat(i), y: firstY)) 
  } 
   
  firstPath.addLine(to: CGPoint(x: bounds.size.width, y: bounds.size.height)) 
  firstPath.addLine(to: CGPoint(x: 0, y: bounds.size.height)) 
  firstPath.closeSubpath() 
  firstWaveLayer.path = firstPath 
   
  // 創(chuàng)建一個(gè)路徑 
  let secondPath = CGMutablePath() 
  var secondY = bounds.size.width/2 
  secondPath.move(to: CGPoint(x: 0, y: secondY)) 
   
  for i in 0...Int(bounds.size.width) { 
    secondY = waveA * sin(waveW * CGFloat(i) + offsetX - bounds.size.width/2 ) + b 
    secondPath.addLine(to: CGPoint(x: CGFloat(i), y: secondY)) 
  } 
  secondPath.addLine(to: CGPoint(x: bounds.size.width, y: bounds.size.height)) 
  secondPath.addLine(to: CGPoint(x: 0, y: bounds.size.height)) 
  secondPath.closeSubpath() 
  secondWaveLayer.path = secondPath 
}

這里創(chuàng)建都是通過(guò)for循環(huán)創(chuàng)建路徑,其路徑是通過(guò)正弦函數(shù),記得不錯(cuò)的話(huà),是在初中的時(shí)候?qū)W的,哈哈。同時(shí),創(chuàng)建好路徑后,要給layer,這樣的話(huà),shapeLayer才能知道要繪制什么樣的路徑和圖形。同時(shí)這兩個(gè)要有個(gè)角度的差值,這樣的話(huà),才能產(chǎn)生相應(yīng)的效果。

以上是“iOS如何實(shí)現(xiàn)水波紋動(dòng)畫(huà)效果”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線(xiàn),公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性?xún)r(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專(zhuān)為企業(yè)上云打造定制,能夠滿(mǎn)足用戶(hù)豐富、多元化的應(yīng)用場(chǎng)景需求。


本文名稱(chēng):iOS如何實(shí)現(xiàn)水波紋動(dòng)畫(huà)效果-創(chuàng)新互聯(lián)
瀏覽路徑:http://weahome.cn/article/csjdpj.html

其他資訊

在線(xiàn)咨詢(xún)

微信咨詢(xún)

電話(huà)咨詢(xún)

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部