POP縮放動畫

来源:http://www.cnblogs.com/YouXianMing/archive/2016/06/05/5560215.html
-Advertisement-
Play Games

POP縮放動畫 效果 源碼 https://github.com/YouXianMing/Animations 細節 1. 參數設置有技巧,可以參考如下所示(項目中的POPSpringParameterController): 2. 動畫效果是通過組合兩個動畫而來的,要註意設置代理: ...


POP縮放動畫

 

效果

 

源碼

https://github.com/YouXianMing/Animations

//
//  SpringScaleViewController.m
//  Animations
//
//  Created by YouXianMing on 16/6/3.
//  Copyright © 2016年 YouXianMing. All rights reserved.
//

#import "SpringScaleViewController.h"
#import "UIView+SetRect.h"
#import "UIFont+Fonts.h"
#import "GCD.h"
#import "POP.h"

@interface SpringScaleViewController ()

@property (nonatomic, strong) UIView *scaleView;

@end

@implementation SpringScaleViewController

- (void)setup {

    [super setup];
    
    // Label
    UILabel *label = [[UILabel alloc] init];
    label.text     = @"P   P";
    label.font     = [UIFont HYQiHeiWithFontSize:140];
    [label sizeToFit];
    label.center   = self.contentView.middlePoint;
    [self.contentView addSubview:label];
    
    // Circle
    self.scaleView                    = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 100, 100)];
    self.scaleView.backgroundColor    = [[UIColor colorWithRed:0.203  green:0.598  blue:0.859 alpha:1] colorWithAlphaComponent:0.95f];
    self.scaleView.layer.cornerRadius = self.scaleView.width / 2.f;
    self.scaleView.center             = self.contentView.middlePoint;
    [self.contentView addSubview:self.scaleView];
    
    // Start animation after 1 second.
    [GCDQueue executeInMainQueue:^{
        
        [self scaleAnimation];
        
    } afterDelaySecs:1.f];
}

- (void)scaleAnimation {

    POPBasicAnimation *scaleAnimation = [POPBasicAnimation animationWithPropertyNamed:kPOPViewScaleXY];
    
    scaleAnimation.name               = @"scaleSmallAnimation";
    scaleAnimation.delegate           = self;
    
    scaleAnimation.duration           = 0.15f;
    scaleAnimation.toValue            = [NSValue valueWithCGPoint:CGPointMake(1.25, 1.25)];\
    
    [self.scaleView pop_addAnimation:scaleAnimation forKey:nil];
}

- (void)pop_animationDidStop:(POPAnimation *)anim finished:(BOOL)finished {

    if ([anim.name isEqualToString:@"scaleSmallAnimation"]) {
        
        POPSpringAnimation *scaleAnimation = [POPSpringAnimation animationWithPropertyNamed:kPOPViewScaleXY];
        
        scaleAnimation.name                = @"SpringAnimation";
        scaleAnimation.delegate            = self;
        
        scaleAnimation.toValue             = [NSValue valueWithCGPoint:CGPointMake(1, 1)];
        scaleAnimation.velocity            = [NSValue valueWithCGPoint:CGPointMake(-2, -2)];
        scaleAnimation.springBounciness    = 20.f;
        scaleAnimation.springSpeed         = 10.f;
        scaleAnimation.dynamicsTension     = 700.f;
        scaleAnimation.dynamicsFriction    = 7.f;
        scaleAnimation.dynamicsMass        = 3.f;
        
        [self.scaleView pop_addAnimation:scaleAnimation forKey:nil];
        
    } else if ([anim.name isEqualToString:@"SpringAnimation"]) {
    
        [self performSelector:@selector(scaleAnimation) withObject:nil afterDelay:1];
    }
}

- (void)viewWillDisappear:(BOOL)animated {

    [super viewWillDisappear:animated];
    
    [[self class] cancelPreviousPerformRequestsWithTarget:self];
}

@end

 

細節

1. 參數設置有技巧,可以參考如下所示(項目中的POPSpringParameterController):

2. 動畫效果是通過組合兩個動畫而來的,要註意設置代理:

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文介紹android中使用pull來解析xml文件 先自己寫一個xml文件,存一些天氣信息 在定義一個City類 拿到xml文件 InputStream is = getClassLoader().getResourceAsStream("weather.xml"); 拿到pull解析器 XmlP ...
  • @property 後面可以有哪些修飾符? 1.線程安全的 aaomic、nonatomic 2.訪問許可權的 readonly、readwrite 3.記憶體管理(ARC) assign、strong、weak、copy 4.記憶體管理(MRC) assign、retain、release 5.指定方法 ...
  • 轉發:http://www.cnblogs.com/pruple/p/5523767.html 轉發:http://blog.csdn.net/sunnyboy9/article/details/50887413 問題描述:向AppStore提交app審核申請的時候報錯了,檢查證書發現好多證書都 顯 ...
  • 例如一個小項目:實現單詞本的添加單詞等功能 功能:不同的方式實現跨app之間數據的暴露與接收 暴露端app:實現單詞的添加(Word、Translate),增刪改查; 接收端app:模糊查詢,得到暴露端的數據。 暴露端主頁及佈局: 1、佈局: 主頁佈局:ListView、TextView(empty ...
  • 蜂鳴器的種類和工作原理 原理 蜂鳴器也成為PWM(脈衝寬度調製),基本原理是通過脈衝來控制蜂鳴器的打開和停止。它是利用微控制器的數字輸出來對模擬電路進行控制的一種非常有效的技術,廣泛應用於測量、通信、功率控制與變換等許多領域。所以,我們要對蜂鳴器進行操作,就是通過對TOUT[0]引腳的設置,即將其設 ...
  • 本文主要對 應用程式、庫、內核、驅動程式的關係 及 LED驅動的實現原理 進行簡要介紹 ...
  • 在《Android 生成xml文件》一文中使用流的形式寫入xml格式文件,但是存在一定的問題,那就是在簡訊內容中不能出現<>之類的括弧,本文使用xml序列化器來解決 xml序列化器對象 XmlSerializer xs = Xml.newSerializer();* 給序列化器設置輸出流 File ...
  • RISC(reduced instruction set computer)精簡指令集電腦 簡介 精簡指令集,是電腦中央處理器的一種設計模式,也被稱為RISC(Reduced Instruction Set Computer的縮寫)。[1] 這種設計思路對指令數目和定址方式都做了精簡,使其實現更 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...