Android开发笔记(十八)书籍翻页动画PageAnimation

前面几节的动画都算简单,本文就介绍一个复杂点的动画——书籍翻页动画。Android有自带的翻页动画ViewPager,不过ViewPager只实现了平移效果。即便使用补间组合动画或者属性动画,也只是把平移、深浅、缩放、旋转这四种动画组合起来,却无法实现书籍翻页那种页面弯折以及页缘阴影等效果。


书籍翻页动画除了要精通Android编码,还得精通数学算法。这难题博主愚笨弄不来,还是多亏了网络大牛实现了翻页代码,那我们还是继续发扬拿来主义好了。算法核心是PageWidget.java,对于码农来说,里面贝塞尔曲线等等术语不必深入研究,只需了解Android相关类的用法。除了之前已经提到的图形类,该源码重点使用了如下类,我们可以了解一下:Path、Matrix、ColorMatrix、GradientDrawable。


GradientDrawable其实就是shape图形的代码表示,有关shape的xml定义参见《 Android开发笔记(八)神奇的shape》。下面是GradientDrawable的常用方法说明:
setGradientType : 设置渐变类型。LINEAR_GRADIENT表示线性渐变,RADIAL_GRADIENT表示放射渐变,SWEEP_GRADIENT表示滚动渐变。
setGradientCenter : 设置渐变的圆心坐标。LINEAR_GRADIENT时不可用。
setGradientRadius : 设置渐变的半径。RADIAL_GRADIENT时才需设置。
setOrientation : 设置渐变的方向。TOP_BOTTOM表示从上到下,TR_BL表示从右上到左下,RIGHT_LEFT表示从右到左,BR_TL表示从右下到左上,BOTTOM_TOP表示从下到上,BL_TR表示从左下到右上,LEFT_RIGHT表示从左到右,TL_BR表示从左上到右下。
setColor : 设置颜色。
setAlpha : 设置灰度。
setCornerRadius : 设置圆角的半径。
setStroke : 设置描边。
setSize : 设置大小。
setShape : 设置图形的形状。RECTANGLE表示矩形(默认),OVAL表示椭圆,LINE表示线条,RING表示圆环。


调用的代码如下
import com.example.exmturn.ui.PageWidget;
import com.example.exmturn.ui.PageWidgetAdapter;
import com.example.exmturn.ui.PageWidgetAdapter1;

import android.app.Activity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.Window;

public class MainActivity extends Activity {

	private PageWidget pageWidget;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		requestWindowFeature(Window.FEATURE_NO_TITLE);
		setContentView(R.layout.activity_main);

        pageWidget = (PageWidget) findViewById(R.id.pageWidget);
//		PageWidgetAdapter adapter = new PageWidgetAdapter(this);
//		pageWidget.setAdapter(adapter);
		PageWidgetAdapter1 adapter = new PageWidgetAdapter1(this);
		pageWidget.setAdapter(adapter);
	}

}



下面是书籍翻页动画的效果图




点击下载本文用到的书籍翻页动画代码




点此查看Android开发笔记的完整目录


你可能感兴趣的:(android开发,Android开发笔记)