Android之绚丽的图片游览效果--有点像W7效果,透明的倒影,层叠的图片,渐变的颜色透明度

本文主要是介绍Android之绚丽的图片游览效果--有点像W7效果,透明的倒影,层叠的图片,渐变的颜色透明度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转自http://blog.csdn.net/kkfdsa132/article/details/6408052

这里转载一个牛人的博客:http://www.cnblogs.com/tankaixiong/archive/2011/02/24/1964340.html

          下面,是我参照他的博客实现的一个效果图。这个程序,在他的基础上进行了一些改良,但改良得不是很好,嘻嘻,等有空,继续研究。该实例下载路径:http://download.csdn.net/source/3275783

          (一)截图

             

       (二)实现关键:

          1、改写Gallery,实现图片的层叠和透明度渐变。 主要是改写getChildStaticTransformation方法

          2、对图片进行加工处理,实现透明倒影。

          3、对于超大图片,先进行缩小。防止图片过大,超出屏幕范围报错。

       (三)代码

          1、Activity类代码:GallaryBrowser.java

          

[java] view plaincopy
  1. package com.myandroid.test;  
  2.   
  3.   
  4. import android.app.Activity;  
  5. import android.os.Bundle;  
  6. import android.view.View;  
  7. import android.widget.ImageSwitcher;  
  8. import android.widget.ImageView;  
  9. import android.widget.Gallery.LayoutParams;  
  10. import android.widget.ViewSwitcher.ViewFactory;  
  11.   
  12. public class GallaryBrowser extends Activity {  
  13.     private Integer[] imageIds = new Integer[] {  
  14.             R.drawable.a, R.drawable.desert,   
  15.             R.drawable.hydrangeas, R.drawable.lighthouse,  
  16.             R.drawable.jellyfish, R.drawable.koala,  
  17.             R.drawable.lighthouse, R.drawable.penguins,  
  18.             R.drawable.tulips  
  19.     };  
  20.       
  21.   
  22.       
  23.     /** Called when the activity is first created. */  
  24.     @Override  
  25.     public void onCreate(Bundle savedInstanceState) {  
  26.         super.onCreate(savedInstanceState);  
  27.           
  28.         final CoverFlow cf = new CoverFlow(this);  
  29.         cf.setAdapter(new ImageAdapter(this, imageIds));  
  30.         cf.setAnimationDuration(1500);  
  31.         setContentView(cf);  
  32.   
  33.     }  
  34.   
  35. }  

          2、图片处理代码,主要是实现旋转和倒影: MyImgView.java

          

[java] view plaincopy
  1.      ///******************************************************************************//  
  2. ///**************************请尊重tank的成果毕竟这也是花了笔者很多时间和心思*****//  
  3. /*************************  为了让大家容易懂tank特地详细的写了很多的解释*********************************************////  
  4. ///**************************欢迎访问我的博客http://www.cnblogs.com/tankaixiong/********************************************//  
  5. ///***************************里面文章将持续更新!***************************************************//  
  6.   
  7.   
  8. package com.myandroid.test;  
  9.   
  10. import android.graphics.Bitmap;  
  11. import android.graphics.Canvas;  
  12. import android.graphics.LinearGradient;  
  13. import android.graphics.Matrix;  
  14. import android.graphics.Paint;  
  15. import android.graphics.PixelFormat;  
  16. import android.graphics.PorterDuffXfermode;  
  17. import android.graphics.Bitmap.Config;  
  18. import android.graphics.PorterDuff.Mode;  
  19. import android.graphics.Shader.TileMode;  
  20. import android.graphics.drawable.Drawable;  
  21.   
  22. public class MyImgView {  
  23.   
  24.     /** 
  25.      * 添加倒影,原理,先翻转图片,由上到下放大透明度 
  26.      *  
  27.      * @param originalImage 
  28.      * @return 
  29.      */  
  30.     public static Bitmap createReflectedImage(Bitmap originalImage) {  
  31.         // The gap we want between the reflection and the original image  
  32.         final int reflectionGap = 4;  
  33.   
  34.         int width = originalImage.getWidth();  
  35.         int height = originalImage.getHeight();  
  36.   
  37.         // This will not scale but will flip on the Y axis  
  38.         Matrix matrix = new Matrix();  
  39.         matrix.preScale(1, -1);  
  40.   
  41.         // Create a Bitmap with the flip matrix applied to it.  
  42.         // We only want the bottom half of the image  
  43.         Bitmap reflectionImage = Bitmap.createBitmap(originalImage, 0,  
  44.                 height / 2, width, height / 2, matrix, false);  
  45.   
  46.         // Create a new bitmap with same width but taller to fit reflection  
  47.         Bitmap bitmapWithReflection = Bitmap.createBitmap(width,  
  48.                 (height + height / 2), Config.ARGB_8888);  
  49.   
  50.         // Create a new Canvas with the bitmap that's big enough for  
  51.         // the image plus gap plus reflection  
  52.         Canvas canvas = new Canvas(bitmapWithReflection);  
  53.         // Draw in the original image  
  54.         canvas.drawBitmap(originalImage, 00null);  
  55.         // Draw in the gap  
  56.         Paint defaultPaint = new Paint();  
  57.         canvas.drawRect(0, height, width, height + reflectionGap, defaultPaint);  
  58.         // Draw in the reflection  
  59.         canvas.drawBitmap(reflectionImage, 0, height + reflectionGap, null);  
  60.   
  61.         // Create a shader that is a linear gradient that covers the reflection  
  62.         Paint paint = new Paint();  
  63.         LinearGradient shader = new LinearGradient(0,  
  64.                 originalImage.getHeight(), 0, bitmapWithReflection.getHeight()  
  65.                         + reflectionGap, 0x70ffffff0x00ffffff, TileMode.CLAMP);  
  66.         // Set the paint to use this shader (linear gradient)  
  67.         paint.setShader(shader);  
  68.         // Set the Transfer mode to be porter duff and destination in  
  69.         paint.setXfermode(new PorterDuffXfermode(Mode.DST_IN));  
  70.         // Draw a rectangle using the paint with our linear gradient  
  71.         canvas.drawRect(0, height, width, bitmapWithReflection.getHeight()  
  72.                 + reflectionGap, paint);  
  73.   
  74.         return bitmapWithReflection;  
  75.     }  
  76.     //drawable 类型转化为bitmap  
  77.     public static Bitmap drawableToBitmap(Drawable drawable) {  
  78.   
  79.         Bitmap bitmap = Bitmap  
  80.                 .createBitmap(  
  81.                         drawable.getIntrinsicWidth(),  
  82.                         drawable.getIntrinsicHeight(),  
  83.                         drawable.getOpacity() != PixelFormat.OPAQUE ? Bitmap.Config.ARGB_8888  
  84.                                 : Bitmap.Config.RGB_565);  
  85.         Canvas canvas = new Canvas(bitmap);  
  86.         // canvas.setBitmap(bitmap);  
  87.         drawable.setBounds(00, drawable.getIntrinsicWidth(), drawable  
  88.                 .getIntrinsicHeight());  
  89.         drawable.draw(canvas);  
  90.         return bitmap;  
  91.     }  
  92.   
  93. }  

          3、自定义的Gallery,继承Gallery类,重写getChildStaticTransformation方法,实现图片的重叠和透明度渐变:CoverFlow.java

          

[java] view plaincopy
  1. ///******************************************************************************//  
  2. ///**************************请尊重tank的成果毕竟这也是花了笔者很多时间和心思*****//  
  3. /*************************  为了让大家容易懂tank特地详细的写了很多的解释*********************************************////  
  4. ///**************************欢迎访问我的博客http://www.cnblogs.com/tankaixiong/********************************************//  
  5. ///***************************里面文章将持续更新!***************************************************//  
  6. package com.myandroid.test;  
  7.   
  8. import android.content.Context;  
  9. import android.graphics.Camera;  
  10. import android.graphics.Matrix;  
  11. import android.util.AttributeSet;  
  12. import android.util.Log;  
  13. import android.view.View;  
  14. import android.view.animation.Transformation;  
  15. import android.widget.Gallery;  
  16. import android.widget.ImageView;  
  17.   
  18.   
  19. //自己定义的Gallery  
  20. public class CoverFlow extends Gallery {  
  21.   
  22.     private Camera mCamera = new Camera();  
  23.     private int mMaxRotationAngle = 50;  
  24.     private int mMaxZoom = -500;  
  25.     private int mCoveflowCenter;  
  26.     private boolean mAlphaMode = true;  
  27.     private boolean mCircleMode = false;  
  28.   
  29.     public CoverFlow(Context context) {  
  30.         super(context);  
  31.         this.setStaticTransformationsEnabled(true);  
  32.         Log.e("sequence""CoverFlow2");  
  33.     }  
  34.   
  35.     public CoverFlow(Context context, AttributeSet attrs) {  
  36.         super(context, attrs);  
  37.         this.setStaticTransformationsEnabled(true);  
  38.     }  
  39.   
  40.     public CoverFlow(Context context, AttributeSet attrs, int defStyle) {  
  41.         super(context, attrs, defStyle);  
  42.         this.setStaticTransformationsEnabled(true);  
  43.     }  
  44.   
  45.     public int getMaxRotationAngle() {  
  46.         return mMaxRotationAngle;  
  47.     }  
  48.   
  49.     public void setMaxRotationAngle(int maxRotationAngle) {  
  50.         mMaxRotationAngle = maxRotationAngle;  
  51.     }  
  52.   
  53.     public boolean getCircleMode() {  
  54.         return mCircleMode;  
  55.     }  
  56.   
  57.     public void setCircleMode(boolean isCircle) {  
  58.         mCircleMode = isCircle;  
  59.     }  
  60.   
  61.     public boolean getAlphaMode() {  
  62.         return mAlphaMode;  
  63.     }  
  64.   
  65.     public void setAlphaMode(boolean isAlpha) {  
  66.         mAlphaMode = isAlpha;  
  67.     }  
  68.   
  69.     public int getMaxZoom() {  
  70.         return mMaxZoom;  
  71.     }  
  72.   
  73.     public void setMaxZoom(int maxZoom) {  
  74.         mMaxZoom = maxZoom;  
  75.     }  
  76.   
  77.     private int getCenterOfCoverflow() {  
  78.         return (getWidth() - getPaddingLeft() - getPaddingRight()) / 2  
  79.                 + getPaddingLeft();  
  80.     }  
  81.   
  82.     private static int getCenterOfView(View view) {  
  83.         return view.getLeft() + view.getWidth() / 2;  
  84.     }  
  85.     //重写Garray方法 ,产生层叠和放大效果  
  86.     @Override  
  87.     protected boolean getChildStaticTransformation(View child, Transformation t) {  
  88.           
  89.         final int childCenter = getCenterOfView(child);  
  90.         final int childWidth = child.getWidth();  
  91.         int rotationAngle = 0;  
  92.         t.clear();  
  93.         t.setTransformationType(Transformation.TYPE_MATRIX);  
  94.         if (childCenter == mCoveflowCenter) {  
  95.             transformImageBitmap((ImageView) child, t, 00);  
  96.         } else {  
  97.             rotationAngle = (int) (((float) (mCoveflowCenter - childCenter) / childWidth) * mMaxRotationAngle);  
  98.             // Log.d("test", "recanglenum:"+Math.floor ((mCoveflowCenter -  
  99.             // childCenter) / childWidth));  
  100.             if (Math.abs(rotationAngle) > mMaxRotationAngle) {  
  101.                 rotationAngle = (rotationAngle < 0) ? -mMaxRotationAngle  
  102.                         : mMaxRotationAngle;  
  103.             }  
  104.             transformImageBitmap((ImageView) child, t, rotationAngle,  
  105.                     (int) Math.floor((mCoveflowCenter - childCenter)/ (childWidth==0?1:childWidth)));  
  106.         }  
  107.         Log.e("sequence""getChildStaticTransformation");  
  108.         return true;  
  109.     }  
  110.   
  111.     /** 
  112.      * This is called during layout when the size of this view has changed. If 
  113.      * you were just added to the view hierarchy, you're called with the old 
  114.      * values of 0. 
  115.      *  
  116.      * @param w 
  117.      *            Current width of this view. 
  118.      * @param h 
  119.      *            Current height of this view. 
  120.      * @param oldw 
  121.      *            Old width of this view. 
  122.      * @param oldh 
  123.      *            Old height of this view. 
  124.      */  
  125.     protected void onSizeChanged(int w, int h, int oldw, int oldh) {  
  126.         mCoveflowCenter = getCenterOfCoverflow();  
  127.         super.onSizeChanged(w, h, oldw, oldh);  
  128.         Log.e("sequence""onSizeChanged");  
  129.     }  
  130.   
  131.     /** 
  132.      * Transform the Image Bitmap by the Angle passed 
  133.      *  
  134.      * @param imageView 
  135.      *            ImageView the ImageView whose bitmap we want to rotate 
  136.      * @param t 
  137.      *            transformation 
  138.      * @param rotationAngle 
  139.      *            the Angle by which to rotate the Bitmap 
  140.      */  
  141.     private void transformImageBitmap(ImageView child, Transformation t,  
  142.             int rotationAngle, int d) {  
  143.         mCamera.save();  
  144.         final Matrix imageMatrix = t.getMatrix();  
  145.         final int imageHeight = child.getLayoutParams().height;  
  146.         final int imageWidth = child.getLayoutParams().width;  
  147.         final int rotation = Math.abs(rotationAngle);  
  148.         mCamera.translate(0.0f, 0.0f, 100.0f);  
  149.         // As the angle of the view gets less, zoom in  
  150.         if (rotation <= mMaxRotationAngle) {  
  151.             float zoomAmount = (float) (mMaxZoom + (rotation * 1.5));  
  152.             mCamera.translate(0.0f, 0.0f, zoomAmount);  
  153.             if (mCircleMode) {  
  154.                 if (rotation < 40)  
  155.                     mCamera.translate(0.0f, 1550.0f);  
  156.                 else  
  157.                     mCamera.translate(0.0f, (255 - rotation * 2.5f), 0.0f);  
  158.             }  
  159.             if (mAlphaMode) {  
  160.                 ((ImageView) (child)).setAlpha((int) (255 - rotation * 2.5));  
  161.             }  
  162.         }  
  163.         mCamera.rotateY(rotationAngle);  
  164.         mCamera.getMatrix(imageMatrix);  
  165.   
  166.         imageMatrix.preTranslate(-(imageWidth / 2), -(imageHeight / 2));  
  167.         imageMatrix.postTranslate((imageWidth / 2), (imageHeight / 2));  
  168.         mCamera.restore();  
  169.         Log.e("sequence""transformImageBitmap");  
  170.     }  
  171. }  

          4、图片适配器:ImageAdapter。这里,我改写了getView方法,把图片按照一定比例进行缩放,防止图片过大,超出屏幕而导致报错。

          

[java] view plaincopy
  1.  package com.myandroid.test;  
  2.   
  3. import java.io.InputStream;  
  4.   
  5. import android.content.Context;  
  6. import android.content.res.Resources;  
  7. import android.graphics.Bitmap;  
  8. import android.graphics.BitmapFactory;  
  9. import android.graphics.Matrix;  
  10. import android.graphics.drawable.BitmapDrawable;  
  11. import android.view.View;  
  12. import android.view.ViewGroup;  
  13. import android.widget.BaseAdapter;  
  14. import android.widget.Gallery;  
  15. import android.widget.ImageView;  
  16.   
  17. public class ImageAdapter extends BaseAdapter {  
  18.     private Context context;  
  19.     private Integer[] images;  
  20.       
  21.     public ImageAdapter(Context context, Integer[] imageIds) {  
  22.         this.context = context;  
  23.         this.images = imageIds;  
  24.     }  
  25.       
  26.     @Override  
  27.     public int getCount() {  
  28.         // TODO Auto-generated method stub  
  29.         return images.length;  
  30.     }  
  31.   
  32.     @Override  
  33.     public Object getItem(int position) {  
  34.         // TODO Auto-generated method stub  
  35.         return position;  
  36.     }  
  37.   
  38.     @Override  
  39.     public long getItemId(int position) {  
  40.         // TODO Auto-generated method stub  
  41.         return position;  
  42.     }  
  43.   
  44.     @Override  
  45.     public View getView(int position, View convertView, ViewGroup parent) {  
  46.           
  47.          ImageView imageView = new ImageView(context);  
  48.          //创建BitMap对象,用于显示图片     
  49.          Bitmap bitmap = BitmapFactory.decodeResource(context.getResources(),  
  50.                  images[position]);     
  51.          Matrix matrix = new Matrix();   //矩阵,用于图片比例缩放     
  52.          matrix.postScale((float)80/bitmap.getWidth(),   
  53.                  (float)60/bitmap.getHeight());    //设置高宽比例(三维矩阵)  
  54.          //图片不能超出屏幕范围,否则报错,这里进行缩小  
  55.          Bitmap newBmp = Bitmap.createBitmap(bitmap, 00, bitmap.getWidth(),  
  56.                  bitmap.getHeight(), matrix, true);      
  57.          imageView.setImageBitmap(MyImgView.createReflectedImage(newBmp));  
  58.          imageView.setLayoutParams(new Gallery.LayoutParams(8060));  
  59.   
  60.          return imageView;  
  61.     }  
  62.   
  63. }  



这篇关于Android之绚丽的图片游览效果--有点像W7效果,透明的倒影,层叠的图片,渐变的颜色透明度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/989682

相关文章

C#中图片如何自适应pictureBox大小

《C#中图片如何自适应pictureBox大小》文章描述了如何在C#中实现图片自适应pictureBox大小,并展示修改前后的效果,修改步骤包括两步,作者分享了个人经验,希望对大家有所帮助... 目录C#图片自适应pictureBox大小编程修改步骤总结C#图片自适应pictureBox大小上图中“z轴

使用Python将长图片分割为若干张小图片

《使用Python将长图片分割为若干张小图片》这篇文章主要为大家详细介绍了如何使用Python将长图片分割为若干张小图片,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果1. Python需求

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

使用 Python 和 LabelMe 实现图片验证码的自动标注功能

《使用Python和LabelMe实现图片验证码的自动标注功能》文章介绍了如何使用Python和LabelMe自动标注图片验证码,主要步骤包括图像预处理、OCR识别和生成标注文件,通过结合Pa... 目录使用 python 和 LabelMe 实现图片验证码的自动标注环境准备必备工具安装依赖实现自动标注核心

使用Python实现生命之轮Wheel of life效果

《使用Python实现生命之轮Wheeloflife效果》生命之轮Wheeloflife这一概念最初由SuccessMotivation®Institute,Inc.的创始人PaulJ.Meyer... 最近看一个生命之轮的视频,让我们珍惜时间,因为一生是有限的。使用python创建生命倒计时图表,珍惜时间

Java操作xls替换文本或图片的功能实现

《Java操作xls替换文本或图片的功能实现》这篇文章主要给大家介绍了关于Java操作xls替换文本或图片功能实现的相关资料,文中通过示例代码讲解了文件上传、文件处理和Excel文件生成,需要的朋友可... 目录准备xls模板文件:template.xls准备需要替换的图片和数据功能实现包声明与导入类声明与

Android WebView的加载超时处理方案

《AndroidWebView的加载超时处理方案》在Android开发中,WebView是一个常用的组件,用于在应用中嵌入网页,然而,当网络状况不佳或页面加载过慢时,用户可能会遇到加载超时的问题,本... 目录引言一、WebView加载超时的原因二、加载超时处理方案1. 使用Handler和Timer进行超

基于C#实现将图片转换为PDF文档

《基于C#实现将图片转换为PDF文档》将图片(JPG、PNG)转换为PDF文件可以帮助我们更好地保存和分享图片,所以本文将介绍如何使用C#将JPG/PNG图片转换为PDF文档,需要的可以参考下... 目录介绍C# 将单张图片转换为PDF文档C# 将多张图片转换到一个PDF文档介绍将图片(JPG、PNG)转