Android 绘制一个Loading动画__向图片中缓慢填充颜色,从而形成动画效果
来源:互联网 发布:男生衣服品牌知乎 编辑:程序博客网 时间:2024/05/16 01:18
Android 绘制一个Loading动画__向图片中缓慢填充颜色,从而形成动画效果
需求:制作一个加载动画,向一个不规则图片图形中从从下到上依次填充颜色,形成动画效果。
效果如下:
代码如下:
LoadingAnimatorView.java
package cn.yw.lib.animation;import cn.yw.lib.R;import android.content.Context;import android.graphics.Bitmap;import android.graphics.BitmapFactory;import android.graphics.Canvas;import android.graphics.Color;import android.graphics.Paint;import android.view.SurfaceHolder;import android.view.SurfaceView;public class LoadingAnimatorView extends SurfaceView implements SurfaceHolder.Callback, Runnable { private SurfaceHolder holder; private Bitmap bitmap; private Paint paint1; private Paint paint2; public boolean flag = true; private int y = 100; public LoadingAnimatorView(Context context) { super(context); this.setFocusable(true); this.setFocusableInTouchMode(true); holder = this.getHolder(); holder.addCallback(this); paint1 = new Paint(); paint1.setColor(Color.RED); paint2 = new Paint(); paint2.setColor(Color.GRAY); Bitmap bitmap1 = BitmapFactory.decodeStream(context.getResources() .openRawResource(R.drawable.ic_launcher)); bitmap = bitmap1.extractAlpha();// 获取一个透明图片 y = bitmap.getWidth();//初始化y轴坐标 } //改变裁剪区域 private void playAnimator() { if (y > 0) { y-=3; } } private void drawLoadingAnimator() { Canvas canvas = null; try { canvas = holder.lockCanvas(); if(canvas != null){ canvas.drawBitmap(bitmap, 100, 100,null); canvas.drawColor(Color.GREEN); canvas.drawBitmap(bitmap, 100, 100, paint2); canvas.save(); //裁剪 canvas.clipRect(100, y+100, bitmap.getWidth()+100, bitmap.getHeight()+100); canvas.drawBitmap(bitmap, 100, 100, paint1); canvas.restore(); } /* * Rect src = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight()); * Rect dst = new Rect(100, 100, bitmap.getWidth()+100, y+100); * canvas.drawBitmap(bitmap, src, dst, paint2); */ } catch (Exception e) { e.printStackTrace(); } finally { try{ if (holder != null) { holder.unlockCanvasAndPost(canvas); } }catch(Exception e){ e.printStackTrace(); } } } @Override public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { } @Override public void surfaceCreated(SurfaceHolder holder) { new Thread(this).start();//开启绘制线程 } @Override public void surfaceDestroyed(SurfaceHolder holder) { } //绘制动画线程 @Override public void run() { while (flag) { drawLoadingAnimator(); playAnimator(); try { Thread.sleep(200); } catch (Exception e) { e.printStackTrace(); } } }}
LoadingAnimatorActivity.java
package cn.yw.lib.animation;import android.annotation.SuppressLint;import android.app.Activity;import android.os.Bundle;@SuppressLint("NewApi")public class LoadingAnimatorActivity extends Activity{ private LoadingAnimatorView view; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); view = new LoadingAnimatorView(this); setContentView(view); } @Override public void onBackPressed() { view.flag = false;//结束绘制线程 super.onBackPressed(); }}
0 0
- Android 绘制一个Loading动画__向图片中缓慢填充颜色,从而形成动画效果
- Android播放多张图片形成一个动画效果
- Android 图片填充动画
- 通过Canvas的叠加实现Android中环形View的颜色填充动画效果
- 通过Canvas的叠加实现Android中环形View的颜色填充动画效果
- android怎样播放多张图片形成一个动画
- Android怎样播放多张图片形成一个动画
- Android怎样播放多张图片形成一个动画
- Android通过播放多张图片形成一个动画
- Android怎样播放多张图片形成一个动画
- Android自定义progressDialog实现loading载中动画效果
- Android自定义progressDialog实现 loading 载入中 动画效果
- Android 多张图片形成动画
- android帧动画(图片快速切换形成动画)
- android播放多张图片形成动画 (帧动画)
- android打造独一无二的loading动画效果
- Android 好看的loading动画效果
- CSS3制作加载中loading动画效果
- c#与IDL混编问题
- javascript制作图片移动效果
- Android4.0新的SDK新特性 (汉化)
- oracle 11g sqlplus和plsql developer 乱码解决方案
- windows下eclipseNDK开发兼调试环境配置
- Android 绘制一个Loading动画__向图片中缓慢填充颜色,从而形成动画效果
- 双割线求值
- find和xargs使用详解
- Qt网络编程之QNetworkAccessManager
- 安卓控件大全
- Django Web开发环境的搭建(一)
- unity之选择结构和循环结构
- Django Web开发环境的搭建(二)
- 计算机网络 OSI 七层协议