1. package xiaosi.GalleryFlow;
  2. import android.app.Activity;
  3. import android.os.Bundle;
  4. public class GalleryFlowActivity extends Activity {
  5. public void onCreate(Bundle savedInstanceState) {
  6. super.onCreate(savedInstanceState);
  7. setContentView(R.layout.main);
  8. Integer[] images = { R.drawable.a, R.drawable.b,
  9. R.drawable.c, R.drawable.d, R.drawable.e,
  10. };
  11. ImageAdapter adapter = new ImageAdapter(this, images);
  12. adapter.createReflectedImages();
  13. GalleryFlow galleryFlow = (GalleryFlow) findViewById(R.id.Gallery01);
  14. galleryFlow.setAdapter(adapter);
  15. }
  16. }

ImageAdapter.Java

  1. package xiaosi.GalleryFlow;
  2. import android.content.Context;
  3. import android.content.res.Resources;
  4. import android.graphics.Bitmap;
  5. import android.graphics.BitmapFactory;
  6. import android.graphics.Canvas;
  7. import android.graphics.LinearGradient;
  8. import android.graphics.Matrix;
  9. import android.graphics.Paint;
  10. import android.graphics.PorterDuffXfermode;
  11. import android.graphics.Bitmap.Config;
  12. import android.graphics.PorterDuff.Mode;
  13. import android.graphics.Shader.TileMode;
  14. import android.view.View;
  15. import android.view.ViewGroup;
  16. import android.widget.BaseAdapter;
  17. import android.widget.ImageView;
  18. import android.widget.ImageView.ScaleType;
  19. public class ImageAdapter extends BaseAdapter
  20. {
  21. int mGalleryItemBackground;
  22. private Context    mContext;
  23. private Integer[]  mImageIds;
  24. private ImageView[] mImages;
  25. public ImageAdapter(Context c, Integer[] ImageIds)
  26. {
  27. mContext  = c;
  28. mImageIds = ImageIds;
  29. mImages   = new ImageView[mImageIds.length];
  30. }
  31. public boolean createReflectedImages()
  32. {
  33. final int reflectionGap = 4;
  34. int index = 0;
  35. for (int imageId : mImageIds)
  36. {
  37. Bitmap originalImage = BitmapFactory.decodeResource(mContext.getResources(), imageId);
  38. int width  = originalImage.getWidth();
  39. int height = originalImage.getHeight();
  40. Matrix matrix = new Matrix();
  41. matrix.preScale(1, -1);
  42. Bitmap reflectionImage = Bitmap.createBitmap(originalImage, 0, height / 2, width, height / 2, matrix, false);
  43. Bitmap bitmapWithReflection = Bitmap.createBitmap(width, (height + height / 2), Config.ARGB_8888);
  44. Canvas canvas = new Canvas(bitmapWithReflection);
  45. canvas.drawBitmap(originalImage, 0, 0, null);
  46. Paint deafaultPaint = new Paint();
  47. canvas.drawRect(0, height, width, height + reflectionGap, deafaultPaint);
  48. canvas.drawBitmap(reflectionImage, 0, height + reflectionGap, null);
  49. Paint paint = new Paint();
  50. LinearGradient shader = new LinearGradient(0, originalImage.getHeight(), 0, bitmapWithReflection.getHeight()
  51. + reflectionGap, 0x70ffffff, 0x00ffffff, TileMode.CLAMP);
  52. paint.setShader(shader);
  53. paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN));
  54. canvas.drawRect(0, height, width, bitmapWithReflection.getHeight() + reflectionGap, paint);
  55. ImageView imageView = new ImageView(mContext);
  56. imageView.setImageBitmap(bitmapWithReflection);
  57. imageView.setLayoutParams(new GalleryFlow.LayoutParams(250, 340));
  58. imageView.setScaleType(ScaleType.FIT_XY);
  59. mImages[index++] = imageView;
  60. }
  61. return true;
  62. }
  63. private Resources getResources()
  64. {
  65. // TODO Auto-generated method stub
  66. return null;
  67. }
  68. public int getCount()
  69. {
  70. return mImageIds.length;
  71. }
  72. public Object getItem(int position)
  73. {
  74. return position;
  75. }
  76. public long getItemId(int position)
  77. {
  78. return position;
  79. }
  80. public View getView(int position, View convertView, ViewGroup parent)
  81. {
  82. return mImages[position];
  83. }
  84. public float getScale(boolean focused, int offset)
  85. {
  86. return Math.max(0, 1.0f / (float) Math.pow(2, Math.abs(offset)));
  87. }
  88. }

GalleryFlow.java

  1. package xiaosi.GalleryFlow;
  2. import android.content.Context;
  3. import android.graphics.Camera;
  4. import android.graphics.Matrix;
  5. import android.util.AttributeSet;
  6. import android.view.View;
  7. import android.view.animation.Transformation;
  8. import android.widget.Gallery;
  9. import android.widget.ImageView;
  10. public class GalleryFlow extends Gallery {
  11. private Camera mCamera = new Camera();
  12. private int mMaxRotationAngle = 60;
  13. private int mMaxZoom = -120;
  14. private int mCoveflowCenter;
  15. public GalleryFlow(Context context) {
  16. super(context);
  17. this.setStaticTransformationsEnabled(true);
  18. }
  19. public GalleryFlow(Context context, AttributeSet attrs) {
  20. super(context, attrs);
  21. this.setStaticTransformationsEnabled(true);
  22. }
  23. public GalleryFlow(Context context, AttributeSet attrs, int defStyle) {
  24. super(context, attrs, defStyle);
  25. this.setStaticTransformationsEnabled(true);
  26. }
  27. public int getMaxRotationAngle() {
  28. return mMaxRotationAngle;
  29. }
  30. public void setMaxRotationAngle(int maxRotationAngle) {
  31. mMaxRotationAngle = maxRotationAngle;
  32. }
  33. public int getMaxZoom() {
  34. return mMaxZoom;
  35. }
  36. public void setMaxZoom(int maxZoom) {
  37. mMaxZoom = maxZoom;
  38. }
  39. private int getCenterOfCoverflow() {
  40. return (getWidth() - getPaddingLeft() - getPaddingRight()) / 2
  41. + getPaddingLeft();
  42. }
  43. private static int getCenterOfView(View view) {
  44. return view.getLeft() + view.getWidth() / 2;
  45. }
  46. protected boolean getChildStaticTransformation(View child, Transformation t) {
  47. final int childCenter = getCenterOfView(child);
  48. final int childWidth = child.getWidth();
  49. int rotationAngle = 0;
  50. t.clear();
  51. t.setTransformationType(Transformation.TYPE_MATRIX);
  52. if (childCenter == mCoveflowCenter) {
  53. transformImageBitmap((ImageView) child, t, 0);
  54. } else {
  55. rotationAngle = (int) (((float) (mCoveflowCenter - childCenter) / childWidth) * mMaxRotationAngle);
  56. if (Math.abs(rotationAngle) > mMaxRotationAngle) {
  57. rotationAngle = (rotationAngle < 0) ? -mMaxRotationAngle
  58. : mMaxRotationAngle;
  59. }
  60. transformImageBitmap((ImageView) child, t, rotationAngle);
  61. }
  62. return true;
  63. }
  64. protected void onSizeChanged(int w, int h, int oldw, int oldh) {
  65. mCoveflowCenter = getCenterOfCoverflow();
  66. super.onSizeChanged(w, h, oldw, oldh);
  67. }
  68. private void transformImageBitmap(ImageView child, Transformation t,
  69. int rotationAngle) {
  70. mCamera.save();
  71. final Matrix imageMatrix = t.getMatrix();
  72. final int imageHeight = child.getLayoutParams().height;
  73. final int imageWidth = child.getLayoutParams().width;
  74. final int rotation = Math.abs(rotationAngle);
  75. // 在Z轴上正向移动camera的视角,实际效果为放大图片。
  76. // 如果在Y轴上移动,则图片上下移动;X轴上对应图片左右移动。
  77. mCamera.translate(0.0f, 0.0f, 100.0f);
  78. // As the angle of the view gets less, zoom in
  79. if (rotation < mMaxRotationAngle) {
  80. float zoomAmount = (float) (mMaxZoom + (rotation * 1.5));
  81. mCamera.translate(0.0f, 0.0f, zoomAmount);
  82. }
  83. // 在Y轴上旋转,对应图片竖向向里翻转。
  84. // 如果在X轴上旋转,则对应图片横向向里翻转。
  85. mCamera.rotateY(rotationAngle);
  86. mCamera.getMatrix(imageMatrix);
  87. imageMatrix.preTranslate(-(imageWidth / 2), -(imageHeight / 2));
  88. imageMatrix.postTranslate((imageWidth / 2), (imageHeight / 2));
  89. mCamera.restore();
  90. }
  91. }

源代码:点击打开链接

Android控件开发之Gallery3D效果的更多相关文章

  1. Android控件开发之Chronometer(转)

    (转自:http://blog.csdn.net/sun6255028/article/details/6688349) Chronometr是一个简单的定时器,你可以给它一个开始时间,并以此定时,或 ...

  2. 将开始我的WebForm控件开发之旅

    时间总是过得很快,一转眼三个月就过去了,三个月内发生了很多的事.因为学校的学习,离开了我入门WPF的公司:开发了第一个外包项目,做的是WebForm的:而且了马上要毕业了,毕业后的公司应该是专门用We ...

  3. Android Studio快速开发之道

    概述 现如今开发越来越追求效率和节奏,节省出时间做更多的事情,除了开发技术上的封装等,开发工具的使用技巧也是很重要的,今天就根据自己的经验来给大家介绍一下Android Studio快速开发之道. P ...

  4. [Android Pro] android控件ListView顶部或者底部也显示分割线

    reference to  :  http://blog.csdn.net/lovexieyuan520/article/details/50846569 在默认的Android控件ListView在 ...

  5. Android控件Gridview实现仿支付宝首页,Fragment底部按钮切换和登录圆形头像

    此案例主要讲的是Android控件Gridview(九宫格)完美实现仿支付宝首页,包含添加和删除功能:Fragment底部按钮切换的效果,包含四个模块,登录页面圆形头像等,一个小项目的初始布局. 效果 ...

  6. Android控件系列之RadioButton&RadioGroup(转)

    学习目的: 1.掌握在Android中如何建立RadioGroup和RadioButton 2.掌握RadioGroup的常用属性 3.理解RadioButton和CheckBox的区别 4.掌握Ra ...

  7. android控件的属性

    android控件的属性 本节描述android空间的位置,内容等相关属性及属性的含义 第一类:属性值为true或false android:layout_centerHrizontal 水平居中 ( ...

  8. Robotium之Android控件定位实践和建议(Appium/UIAutomator姊妹篇)

    本人之前以前撰文描写叙述Appium和UIAutomator框架是怎样定位Android界面上的控件的. UIAutomator定位Android控件的方法实践和建议 Appium基于安卓的各种Fin ...

  9. Android群英传笔记——第三章:Android控件架构与自定义控件讲解

    Android群英传笔记--第三章:Android控件架构与自定义控件讲解 真的很久没有更新博客了,三四天了吧,搬家干嘛的,心累,事件又很紧,抽时间把第三章大致的看完了,当然,我还是有一点View的基 ...

随机推荐

  1. Unity 获得Android Context上下文

    1.获取Context AndroidJavaObject context = new AndroidJavaClass ("com.unity3d.player.UnityPlayer&q ...

  2. 题解 P3372 【【模板】线段树 1】(珂朵莉树解法)

    这道题可以用珂朵莉树做,但是由于数据比较不随机,而我也没有手写一颗平衡树,所以就被卡掉了,只拿了70分. 珂朵莉树是一种基于平衡树的(伪)高效数据结构. 它的核心操作是推平一段区间. 简而言之,就是把 ...

  3. ECNUOJ 2619 询问

    询问 Time Limit:2000MS Memory Limit:65536KBTotal Submit:286 Accepted:70 Description  Pollux最近对字符串匹配很感兴 ...

  4. 【DevExpress】GridControl添加按钮列并添加按钮事件

    在GridControl中添加按钮列的步骤如下: 1. 把列的ColumnEdit属性设置为RepositoryItemButtonEdit 2. 把TextEditStyle属性设置为HideTex ...

  5. ArcGIS api for javascript——地理处理任务-瓶中信

    描述 如果在海洋中丢下一个瓶子,本例使用颗粒追踪模型显示指定的天数后瓶子在的地方.首先,输入一个追踪瓶子的天数.然后单击按钮并在海洋里的任意地方画一个点来开始模型.几秒以后将看到一条线出现描述瓶子将去 ...

  6. HDOJ 2544 最短路(最短路径 dijkstra算法,SPFA邻接表实现,floyd算法)

    最短路 Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submis ...

  7. CSS浏览器兼容问题集(一)

    CSS对浏览器的兼容性有时让人非常头疼,也许当你了解其中的技巧跟原理,就会认为也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理方法并整理了一下.对于web2.0的过度,请尽量用xhtml ...

  8. Spring MVC学习------------WebApplicationContext

    父子上下文(WebApplicationContext) 假设你使用了listener监听器来载入配置.一般在Struts+Spring+Hibernate的项目中都是使用listener监听器的. ...

  9. Cookie与Session的区别与联系及生命周期

    Cookie与Session的区别与联系及生命周期 一.Session与Cookie介绍 这些都是基础知识,不过有必要做深入了解.先简单介绍一下. 二者的定义: 当你在浏览网站的时候,WEB 服务器会 ...

  10. kafka查询topic属性含义

    第一行,列出了topic的名称,分区数(PartitionCount),副本数(ReplicationFactor)以及其他的配置(Config.s) Leader:1 表示为做为读写的broker的 ...