项目里面有一个接受消息然后将消息内容以翻页的形式展现给用户,返回的数据就是简单的文字没有图片,所以我就简单的用了textView接收然后在view上设置了翻页效果的切换动画,这个翻页切换也比较简单,就是用了一下系统的动画.

效果如图:

PageBlurTestGif.gif

大体思路:

在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"];

}

//2 添加启动页和手势控制的翻页效果实现,添加swipe手势后画面切换更生动.

效果图:

PageBlurTestGif.gif

#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 分支中.

ios动态效果实现翻页_iOS实现翻页效果动画相关推荐

  1. ios 添加浮动效果_IOS 实现3D 浮动效果动画

    涉及到的技术点 catransform3drotate 转换坐标系 整体视图的层级结构 tvoscardview cardimageview cardparallaxview 转换坐标系的代码 cgf ...

  2. mysql+翻页性能,mysql 翻页优化

    mysql翻页优化 对于翻页,我们通常是用 select fields from table limit 100,10 但是当要越翻后面的页数之后,耗时变得很长 select fields from ...

  3. Py:利用pyautogui实现自动将pdf文件(需手动设定pdf总页数)自动翻页并截取另存为图片形式,或自动隔0.1秒自动截笔记本全屏保存到指定文件夹

    Py:利用pyautogui实现自动将pdf文件(需手动设定pdf总页数)自动翻页并截取另存为图片形式,或自动隔0.1秒自动截笔记本全屏保存到指定文件夹 目录 实现步骤和结果 核心代码 实现步骤和结果 ...

  4. android 日历翻页动画,Android 仿日历翻页、仿htc时钟翻页、数字翻页切换效果

    废话不多说,效果图: 自定义控件找自网络,使用相对简单,具体还没有来得及深入研究,只是先用笨方法大概实现了想要的效果,后续有空会仔细研究再更新文章, 本demo切换方法是用的笨方法,也就是由新数字和旧 ...

  5. Python+Selenium自动化测试之页码,前一页、后一页、翻页

    思路:获取当前的总记录数,每页大小,算出总的页数,然后根据总页数实现翻页,在翻页时,可以获取每一页的内容存在列表中,为后面的模糊匹配做准备. BasePage中封装 # 页面的页码信息,记录总数.分页 ...

  6. 全屏时钟软件Linux,翻页时钟下载-翻页时钟安卓版下载v1.2.3-Linux公社

    翻页时钟中有很丰富的时钟样式可以供用户随心切换,这上面的时间也是十分的准确哦,支持横屏.竖屏两种方式展现,更有酷炫的背景等着用户来更换,也能够自定义喜欢的图片进行背景设置,非常人性化的功能,翻页时钟中 ...

  7. 抖音短视频APP开发逻辑翻页与物理翻页

    逻辑翻页与物理翻页的区别 逻辑分页-假分页:将数据全部加载到内存,根据rowBound里面的偏移量,和条数,将偏移量之前的都去掉,只去从偏移量开始后指定数量的那一部分: 物理分页- 真分页:将分页信息 ...

  8. 上一页,下一页的翻页制作`

    前言 提示:上一页,下一页的翻页制作 一.逻辑 1.获取数据,存到arrList 2.封装函数getDataList(),把数据存到arrList中 3.编写函数,上一页,下一页: 二.代码 代码如下 ...

  9. android listview左右滑动动画效果,Android基于ListView实现类似QQ空间的滚动翻页与滚动加载效果...

    本文实例讲述了Android基于ListView实现类似QQ空间的滚动翻页与滚动加载效果.分享给大家供大家参考,具体如下: 1. 滚动加载 listView.setOnScrollListener(n ...

  10. elasticsearch翻页与深度翻页,以及获取全部数据

    我们通常会有需求:根据指定条件,查询数据.并分页展示.甚至还有可能要导出全部的数据. 在工作中,经常会有需求,将指定条件的数据导出(这个数据量多数在2亿以上,有一次是18亿).导出数据的速度是挺慢的, ...

最新文章

  1. 【问题收录】Ubuntu Starting LightDM Display Manager fail
  2. python基因差异分析_差异基因
  3. source insight搜不到关联代码
  4. 搜索功能:洞悉产品的绝佳入口
  5. 怎么把一台华为路由器配置为FTP服务器?
  6. oracle 中least,ORACLE 内置函数之GREATEST和LEAST
  7. python去停用词用nltk_使用nltk删除英文停用词
  8. mysql如何导出word_SQL导出为Word
  9. 快看这里,如何卸载windows11自动更新下载的文件还你C盘空间
  10. 【Linux操作系统基础】第一章 Linux命令行使用技巧
  11. 利用Python scapy爬取起点小说网小说
  12. How to choose the number oftopics/partitions in a Kafka cluster?
  13. linux Guest账户下如何更新默认的python版本
  14. 电脑没有“立体声混音”设备怎么办,虚拟声卡安装教程
  15. 计算机二级ms在线模拟,2018年全国计算机二级在线自测模拟考场/网页版:MS Office高级应用(含真题及答案)...
  16. Java批量下载并打成压缩包zip格式
  17. 蓝牙BQB 认证流程
  18. 代码:吃货联盟订餐系统
  19. 深度:养老康复器械龙头即将上市,美的、新松进军养老康复机器人,老龄化加速千亿康复市场到来!
  20. Flex入门学习教程

热门文章

  1. 申清企业微信需要什么条件
  2. 谷歌colab平台简单使用及读取自己的数据集
  3. 在代码里设置view的android:layout_marginTop
  4. 魔兽地图编辑器插件YDWE的使用与基本设置
  5. 【DOORS】如何基于DOORS实施需求管理
  6. Linux系统管理(一)基础管理
  7. 7654劫持火狐解决办法
  8. java中如何插入表格_Java如何向Word文档中添加表格?
  9. td超过的文字设置省略号
  10. error: undefined reference to __write_chk错误