Android中使用Matrix控制图形变换和制作倒影效果的方法

作者:summerpxy 时间:2022-11-23 07:35:23 

最近在使用Matrix进行绘图的操作。对Matrix的一些方法有了一些更深的体会,记下来,以便日后复习。
Matrix常用的方法:

一、变换方法:

Matrix提供了translate(平移)、rotate(旋转)、scale(缩放)、skew(倾斜)四种操作,这四种操作的内部实现过程都是通过matrix.setValues(…)来设置矩阵的值来达到变换图片的效果。
Matrix的每种操作都有set、pre、post三种操作,set是清空队列再添加,pre是在队列最前面插入,post是在队列最后面插入。
pre方法表示矩阵前乘,例如:变换矩阵为A,原始矩阵为B,pre方法的含义即是A*B
post方法表示矩阵后乘,例如:变换矩阵为A,原始矩阵为B,post方法的含义即是B*A

1.matrix.preScale(0.5f, 1);  
2.matrix.preTranslate(10, 0); 
3.matrix.postScale(0.7f, 1);   
4.matrix.postTranslate(15, 0); 
等价于:
translate(10, 0) -> scale(0.5f, 1) -> scale(0.7f, 1) -> translate(15, 0)
注意:后调用的pre操作先执行,而后调用的post操作则后执行。

set方法一旦调用即会清空之前matrix中的所有变换,例如:
1.matrix.preScale(0.5f, 1);  
2.matrix.setScale(1, 0.6f);  
3.matrix.postScale(0.7f, 1);  
4.matrix.preTranslate(15, 0); 
等价于
translate(15, 0) -> scale(1, 0.6f) ->  scale(0.7f, 1)

matrix.preScale (0.5f, 1)将不起作用。

二、映射方法   

Matrix提供了mapXXX的方法,用于获取经matrix映射之后的值。主要有:mapPoints,mapRects,mapVectors等方法。
这些方法你会使用到:在你需要记住matrix操作之后的数值的时候。比如:记住矩形旋转34°(rotate)之后四个点的坐标。(你可以尝试着自己计算,你会发现很复杂,还不精确)

需要注意的是,matrix的某些方法使用到中心点的时候,如果不设置,默认是以(0,0)为中心点的。

记下来,以免忘记。


三、制作倒影效果
利用matrix可以实现各种图片的特效,接下来就用marix加上渐变色实现图片倒影的效果,步骤如下:
1. 获取需要倒影效果的图片,这里取原图片的一半
2. 添加颜色渐变到倒影图片上
具体的实现如下面代码所述,我们以一种自定义view的形式给出效果图,代码如下:


package com.flection.view;

import com.flection.main.R;

import android.annotation.SuppressLint;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Bitmap.Config;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.LinearGradient;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.PorterDuffXfermode;
import android.graphics.Shader.TileMode;
import android.graphics.drawable.BitmapDrawable;
import android.util.AttributeSet;
import android.view.View;

public class FlectionView extends View {

Context mContext=null;
 public FlectionView(Context context) {
   super(context);
 }

public FlectionView(Context context, AttributeSet attrs) {
   super(context, attrs);
   this.mContext=context;
 }

@SuppressLint("DrawAllocation")
 @Override
 protected void onDraw(Canvas canvas) {
   //设置背景色
   this.setBackgroundColor(Color.parseColor("#8B8378"));
   Bitmap oldBitmap = BitmapFactory.decodeResource(mContext.getResources(),R.drawable.dropbox);
   Bitmap newBitmap = createFlectionBitmap(oldBitmap);
   canvas.drawBitmap(newBitmap,newBitmap.getWidth() ,newBitmap.getHeight(), new Paint());
   this.invalidate();
 }

//获取原图+倒影图的bitmap
 private Bitmap createFlectionBitmap(Bitmap oldBitmap) {
   int mWidth = oldBitmap.getWidth();
   int mHeight = oldBitmap.getHeight();
   //原图和倒影图之间的缝隙
   int gap = 2;
   Matrix matrix = new Matrix();
   matrix.preScale(1, -1);
   Bitmap flection = Bitmap.createBitmap(oldBitmap, 0, mHeight / 2,
       mWidth, mHeight / 2, matrix, false);
   Bitmap background = Bitmap.createBitmap(mWidth, mHeight+gap+mHeight/2, Config.ARGB_8888);
   Canvas canvas = new Canvas(background);
   Paint p1 = new Paint();
   //画出原图
   canvas.drawBitmap(oldBitmap, 0, 0, p1);
   //画出倒影图
   canvas.drawBitmap(flection, 0, mHeight+gap, p1);
   Paint shaderPaint = new Paint();
   LinearGradient shader = new LinearGradient(0, mHeight, 0,
       flection.getHeight(), 0x70ffffff, 0x00ffffff, TileMode.MIRROR);
   shaderPaint.setShader(shader);
   shaderPaint.setXfermode(new PorterDuffXfermode(android.graphics.PorterDuff.Mode.DST_IN));
   //画出渐变颜色
   canvas.drawRect(0, mHeight+gap, mWidth, background.getHeight(), shaderPaint);
   return background;
 }

}

实现的效果如下图:

Android中使用Matrix控制图形变换和制作倒影效果的方法

标签:Android,Matrix
0
投稿

猜你喜欢

  • Java的Hibernate框架结合MySQL的入门学习教程

    2021-10-18 04:48:20
  • SpringBoot返回多种格式的数据的实现示例

    2023-11-24 14:22:52
  • nacos中的配置使用@Value注解获取不到值的原因及解决方案

    2023-11-29 13:43:00
  • SpringCloud Eureka搭建的方法步骤

    2021-10-10 11:03:29
  • 简单讲解Android开发中触摸和点击事件的相关编程方法

    2023-03-30 12:29:10
  • JAVA并发编程有界缓存的实现详解

    2022-12-09 16:12:53
  • 关于Spring Boot项目的 log4j2 核弹漏洞问题(一行代码配置搞定)

    2022-08-26 03:04:20
  • C++ Boost Fusion创建异构容器详解

    2021-12-30 23:52:58
  • Flutter应用集成极光推送的实现示例

    2023-06-24 03:51:04
  • C# 文字代码页 文字编码的代码页名称速查表

    2023-12-13 04:03:54
  • Java中的clone()和Cloneable接口实例

    2022-09-27 15:31:05
  • Java lambda表达式与泛型整理总结

    2021-07-15 19:57:14
  • spring-cloud-gateway动态路由的实现方法

    2021-07-25 15:24:37
  • java参数传递之值传递和引用传递

    2021-09-26 10:28:46
  • android实现通过NFC读取卡号

    2023-06-24 08:45:54
  • java编程枚举类型那些事!枚举类型定义和重写枚举的方法

    2021-11-19 18:31:15
  • Java Config下的Spring Test几种方式实例详解

    2022-12-17 00:31:36
  • Android 使用ViewPager实现左右循环滑动及轮播效果

    2022-10-28 15:23:21
  • springboot结合maven实现多模块打包

    2022-01-16 07:13:51
  • 判断一个整数是否是2的N次幂实现方法

    2022-12-25 00:55:10
  • asp之家 软件编程 m.aspxhome.com