用Animation實現(xiàn)iphone動畫效果
來源:易賢網(wǎng) 閱讀:1075 次 日期:2014-11-04 11:09:15
溫馨提示:易賢網(wǎng)小編為您整理了“用Animation實現(xiàn)iphone動畫效果”,方便廣大網(wǎng)友查閱!

1、寫了一個小Demo,實現(xiàn)上下移動的效果圖:

名單1

名單2

名單3

主要代碼如下:

- (IBAction)upChange:(id)sender {

if (typeView == down) {

[self.downBtn setHidden:NO];

[self.upBtn setHidden:NO];

[UIView animateWithDuration:0.5 animations:^{

self.upView.center = CGPointMake(self.upView.center.x, 0);

self.downView.center = CGPointMake(self.downView.center.x, (self.upView.frame.size.height+self.downView.frame.size.height)/2);

}];

typeView = middle;

}else if(typeView == middle){

[self.downBtn setHidden:NO];

[self.upBtn setHidden:YES];

[UIView animateWithDuration:0.5 animations:^{

self.upView.center = CGPointMake(self.upView.center.x, -(self.upView.frame.size.height/2));

self.downView.center = CGPointMake(self.downView.center.x, self.downView.frame.size.height/2);

}];

typeView = up;

}

}

- (IBAction)downChange:(id)sender {

if (typeView == middle) {

[self.downBtn setHidden:YES];

[self.upBtn setHidden:NO];

[UIView animateWithDuration:0.5 animations:^{

self.upView.center = CGPointMake(self.upView.center.x, self.upView.frame.size.height/2);

self.downView.center = CGPointMake(self.downView.center.x, self.upView.frame.size.height+self.downView.frame.size.height/2);

}];

typeView = down;

}else if(typeView == up)

{

[self.downBtn setHidden:NO];

[self.upBtn setHidden:NO];

[UIView animateWithDuration:0.5 animations:^{

self.upView.center = CGPointMake(self.upView.center.x, 0);

self.downView.center = CGPointMake(self.downView.center.x, (self.upView.frame.size.height+self.downView.frame.size.height)/2);

}];

typeView = middle;

}

}

這是主要的代碼,另外還有一些需要注意的一些小細,如你的兩個view的大小,需要計算出精確位置。

下面開始學習[UIView animateWithDuration]方法的使用:

函數(shù)原型:

+ (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_4_0); // delay = 0.0, options = 0, completion = NULL

duration:動畫持續(xù)時間

animations:該代碼兒塊中是所有view要完成的動畫的所有屬性的定義;

還有另外兩個函數(shù):

+ (void)animateWithDuration:(NSTimeInterval)duration delay:(NSTimeInterval)delay options:(UIViewAnimationOptions)options animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion __OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_4_0);

+ (void)animateWithDuration:(NSTimeInterval)duration animations:(void (^)(void))animations completion:(void (^)(BOOL finished))completion__OSX_AVAILABLE_STARTING(__MAC_NA,__IPHONE_4_0);// delay = 0.0, options = 0

options:是動畫執(zhí)行的選項

completion:是動畫完成以后所要執(zhí)行的代碼塊兒。

更多信息請查看IT技術(shù)專欄

更多信息請查看技術(shù)文章
易賢網(wǎng)手機網(wǎng)站地址:用Animation實現(xiàn)iphone動畫效果
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65317125(9:00—18:00) 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)