粒子效果

粒子效果(復(fù)制層)

  • 開(kāi)始

  • 重繪

  • 自定義一個(gè)DrawView

    • 綁定控制器的view

    • awakeFromNib中添加手勢(shì)pan

    • 創(chuàng)建粒子

      • CALayer * dotLayer
      • cornerRadius
      • frame x 設(shè)置為負(fù)值,就能達(dá)到隱藏的效果
    • drawView中提供兩個(gè)方法,作為接口

      • 開(kāi)始

        • 創(chuàng)建幀動(dòng)畫(huà)CAKeyFrameAnimation
        • 根據(jù)路徑做移動(dòng)keyPath
        • .path = self.path.CGPath;
        • 把動(dòng)畫(huà)加給粒子,定義一個(gè)粒子的成員屬性
        • duration
        • repeatCount
        • 讓當(dāng)前的view成為復(fù)制層,復(fù)制其子層
          • layerClass
          • CAReplicatorLayer
          • instanceCount = 50;
          • 設(shè)置延遲執(zhí)行時(shí)間,instanceDelay = 0.25;
      • 重繪

        • 移除所有的動(dòng)畫(huà)
          • [self.dotLayer removeAllAnimation]
        • 刪除路徑
          • 刪除路徑當(dāng)中所有的點(diǎn)
          • removeAllPoints
          • setNeedsDisplay
    • pan手勢(shì)里

      • curP = [pan locationInView:self]
      • 開(kāi)始:
        • 創(chuàng)建路徑
        • moveToPoint:
        • self.path = path
      • 改變:
        • 定義一個(gè)成員屬性path
        • addLineToPoint:
        • setNeedsDisplay
    • drawRect方法里面

      • stroke
  • 注意:一個(gè)路徑可以畫(huà)多條線

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容