本文介绍Android中实现翻页功能原理及示例。

第一种翻页效果如下:

实现原理:

当前手指触摸点为a,则 a点坐标为(ax,ay), 由三角形acb与三角形cmb为对称三角形并且直线cp为am垂直平分线,则 B点坐标为(ax/2,ay/2)。

作gf垂直于om且cb垂直于am, 三角形cfg与gfm相似,则 cf:gf = gf:mf cf=(gf * gf) / mf gf长度为g点纵坐标 mf长度为g点横坐标

cf长度可求 c点坐标可求 由c点、g点可确定过两点间的直线, 当该直线中x=0时求出与y足交点。

第二种翻页效果

实现原理:

使用贝赛尔曲线。曲线有四个点:起始点、终止点(也称锚点)以及两个相互分离的中间点。滑动两个中间点,贝塞尔曲线的形状会发生变化。

根据第一种翻页效果原理可以确定a、e、h、f、g ,由eh平行于cj且af垂直于eh,则 af垂直于cj则三角形egf相似于三角形cnf 则有ef:cf = gf:nf 。

设n为ag中点 则有cf=(3/2)*ef ,则c点坐标可求 由c点、k点坐标已知可知过两点间的直线

由该直线可计算与y轴相交点j 由a、e、c、j可计算两条直线的相交点b 同理可求点k。

在Android中的具体实现步骤:

起始页展示

1.创建屏幕尺寸的bmp

2.将图片转化为canvas

3.获取起始页面数据

4.在canvas中绘制起始页数据

5.在当前视图中复写onDraw进行重绘出bmp对象

翻页处理

1.初始化时创建两个bmp(bmp1、bmp2)并将其转换为canvas(canvas1、canvas2)

2.获取手势首次触摸的区域 (例:当首次点击屏幕的位置x<50&&y<50则为左上角)

3.根据首次点击区域判断需要展示的数据(例:首次点击处于左侧区域【左上、左下】的则判断操作为下一页操作)

4.获取下一页中数据并绘制出来在canvas2中

5.根据1中获取的区域位置调用起始动画使视图移动到手势首次点击位置

6.获取手势每次移动的坐标并根据移动坐标计算绘制的各个点的坐标

7.每次移动刷新视图

源码示例下载1

源码示例下载2

完毕。 ^_^

更多相关文章

  1. [Android]使用achartengine开发曲线图相关的Android应用程序
  2. 动画 -- View动画 -- 缩放动画
  3. SuperMap iMobile for Android定位实现
  4. 【Android应用实例之二】跟随手指的小球——自定义View应用
  5. Android读书笔记---View基础
  6. Android(安卓)SVG矢量图/矢量动画、Vector和VectorDrawable矢量
  7. 2014-11-8Android学习------Android(安卓)仿真翻页效果实现原理
  8. Android(安卓)仿网易云鲸云音效动效
  9. Android(安卓)OpenGL ES(二)绘制三角形

随机推荐

  1. andorid ANR keyDispatchingTimedOut的原
  2. Android怎样绕开Camera打开手电筒的LED
  3. android导入外部已存在的数据库大于1M的
  4. Android高级界面组件之拖动条和评星条的
  5. 联发科联姻Android意义深远
  6. Android中Xposed框架篇—修改系统位置信
  7. Android(安卓)高仿微信6.0主界面 带你玩
  8. Android(安卓)性能优化5 - 内存优化
  9. Android(安卓)Developers:简单的拍照
  10. Android动态布局小结