国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

iOS實現翻頁效果動畫實例代碼

2020-07-26 02:48:36
字體:
來源:轉載
供稿:網友

大體思路:

在self.view 上放置一個label,label.text從數組中獲得,當點擊上下頁按鈕的時候,改變label.text,并且執行翻頁效果動畫.

效果如圖:

主要代碼:

#pragma mark - 下一頁按鈕響應事件- (void)nextPage:(UIButton *)btn {  _forwardBtn.enabled = YES;  if (_count<_arr.count-1) {    btn.enabled = YES;    _label.text = [_arr objectAtIndex:_count+1];    NSString *subtypeString;    subtypeString = kCATransitionFromRight;    [self transitionWithType:@"pageCurl" WithSubtype:subtypeString ForView:self.view];    _count = _count + 1;  } else {    _count = _arr.count - 1;    btn.enabled = NO;    [self showAlert:@"已經是最后一頁咯,親(づ ̄ 3 ̄)づ"];  }  NSLog(@"%ld", (long)_count);}#pragma CATransition動畫實現/** * 動畫效果實現 * * @param type  動畫的類型 在開頭的枚舉中有列舉,比如 CurlDown//下翻頁,CurlUp//上翻頁,FlipFromLeft//左翻轉,FlipFromRight//右翻轉 等... * @param subtype 動畫執行的起始位置,上下左右 * @param view  哪個view執行的動畫 */- (void) transitionWithType:(NSString *) type WithSubtype:(NSString *) subtype ForView : (UIView *) view {  CATransition *animation = [CATransition animation];  animation.duration = 0.7f;  animation.type = type;  if (subtype != nil) {    animation.subtype = subtype;  }  animation.timingFunction = UIViewAnimationOptionCurveEaseInOut;  [view.layer addAnimation:animation forKey:@"animation"];}

主要就是熟悉一下簡單動畫的實現了

本項目gitHub地址:https://github.com/iOSJason/PageBlurDemo.git

2 添加啟動頁和手勢控制的翻頁效果實現,添加swipe手勢后畫面切換更生動.

效果圖:


#pragma mark - 手勢- (void)configTapGes {  _fromRightSwip = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(nextPage:)];  _fromRightSwip.direction = UISwipeGestureRecognizerDirectionLeft;  [self.view addGestureRecognizer:_fromRightSwip];  _fromLeftSwip = [[UISwipeGestureRecognizer alloc] initWithTarget:self action:@selector(forwardPage:)];  _fromLeftSwip.direction = UISwipeGestureRecognizerDirectionRight;  [self.view addGestureRecognizer:_fromLeftSwip];}//判斷是否是第一次進入程序if (![[[NSUserDefaults standardUserDefaults] objectForKey:@"isFirst"] isEqualToString:@"yes"]) {      //顯示提示    UIAlertView *alert = [[UIAlertView alloc]initWithTitle:@"tishi" message:@"" delegate:self cancelButtonTitle:@"曉得了" otherButtonTitles: nil];    [alert show];    [[NSUserDefaults standardUserDefaults]setObject:@"yes" forKey:@"isFirst"];  }

動畫效果和上一個是一種效果,具體代碼請看我的gibHub,和上一個項目在一個地址里面,這個在 SwipeGesturePageBlurDemo 分支中.

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 美姑县| 岳池县| 内乡县| 大田县| 思南县| 阿巴嘎旗| 怀安县| 巩义市| 洛扎县| 恩平市| 通道| 天祝| 子洲县| 雷山县| 彭山县| 京山县| 正阳县| 常山县| 饶阳县| 乐业县| 赣榆县| 湟源县| 滨海县| 绥芬河市| 南靖县| 明星| 灌云县| 丁青县| 平阳县| 金堂县| 库尔勒市| 云和县| 沅江市| 蒙城县| 朝阳市| 房山区| 常山县| 阿拉善右旗| 寻甸| 孝昌县| 济阳县|