这个实例 是图像的扭曲,代码比较复杂,很多不是很懂,只把大体意思几下:
canvas.drawBitmapMesh(mBitmap, WIDTH, HEIGHT, mVerts, 0,
null, 0, null);
主要通过mesh创建一个图像,这个mesh呢是可以扭曲的,这里面一定要注意vmVerts,这个数组是宽高都加以后乘机的两倍 然后在加上 偏移数值 ,上面的偏移是0.
private static final int WIDTH = 20;
private static final int HEIGHT = 20;
private static final int COUNT = (WIDTH + 1) * (HEIGHT + 1);
private final Bitmap mBitmap;
private final float[] mVerts = new float[COUNT*2];
private final float[] mOrig = new float[COUNT*2];
private final Matrix mMatrix = new Matrix();
private final Matrix mInverse = new Matrix();
这是最基本的初始化,注意数组的变化。
下面是把成对的坐标放在一个数组中,其中奇数项存x,偶数项存y。
private static void setXY(float[] array, int index, float x, float y) {
array[index*2 + 0] = x;
array[index*2 + 1] = y;
}
@Override protected void onDraw(Canvas canvas) {
canvas.drawColor(0xFFCCCCCC);
canvas.concat(mMatrix);
// canvas.concat(mInverse);
canvas.drawBitmapMesh(mBitmap, WIDTH, HEIGHT, mVerts, 0,
null, 0, null);
}
其中canvas.concat(mMatrix);不是很懂貌似是用参数来取代默认的Matrix,就是说要对哪个进行绘画。
public SampleView(Context context) {
super(context);
setFocusable(true);
mBitmap = BitmapFactory.decodeResource(getResources(),
R.drawable.beach);
float w = mBitmap.getWidth();
float h = mBitmap.getHeight();
// construct our mesh
int index = 0;
for (int y = 0; y <= HEIGHT; y++) {
float fy = h * y / HEIGHT;
for (int x = 0; x <= WIDTH; x++) {
float fx = w * x / WIDTH;
setXY(mVerts, index, fx, fy);
setXY(mOrig, index, fx, fy);
index += 1;
}
}
mMatrix.setTranslate(100, 10);
mMatrix.invert(mInverse);
// mInverse.setTranslate(100, 100);
}
上面就是一个view的构造函数, mMatrix.setTranslate(100, 10);
用来设置mMatrix在屏幕上的位置。for循环是把图像上的每个点都存储在数组中。
最后动过一个事件来改变数组中值产生图像的变化。
@Override public boolean onTouchEvent(MotionEvent event) {
float[] pt = { event.getX(), event.getY() };
mInverse.mapPoints(pt);
int x = (int)pt[0];
int y = (int)pt[1];
if (mLastWarpX != x || mLastWarpY != y) {
mLastWarpX = x;
mLastWarpY = y;
warp(pt[0], pt[1]);
invalidate();
}
return true;
分享到:
相关推荐
比较好用的电子教鞭,可以不锁定屏幕情况下画图。
cartopy画图-降雨,cartopy画图-降雨
Unity 画图-画板-画笔
如何使用pandas解析数据并存储,再利用matplotlib画图------data1.csv
海龟画图-凯蒂猫-python代码
在线画图-流线图形在线设计.zip在线画图-流线图形在线设计.zip在线画图-流线图形在线设计.zip
画图工具源码.zip
11、学习画图--电脑基础知识.docx
海龟画图-机器猫-python代码
画图程序源码.zip
项目管理-画图-画流程图-画甘特图
python mat 画图-樱花树
Android程序源码--画图,画图Android程序源码--
Matlab画图-MatLab2画图.doc Matlab画图教程,很实用
python画图-22-列表修改数据.ev4.rar
python画图-21-列表删除数据.ev4.rar
vs平台,基于qt的画图--graphics练习 使用的c++ 实现椭圆,颜色改变,添加图形,view里面右键菜单,添加删除item
dino用opengl描点画图-恐龙 经典题目 不用多说了吧。
使用Android开发的画图着色程序, 源码适用于Android学习用, 生成的apk适用于小孩学习着色用.
地震数据剖面画图-Matlab程序