返回顶部
首页 > 资讯 > 精选 >Android使用API实现图像扭曲效果示例
  • 702
分享到

Android使用API实现图像扭曲效果示例

androidapi图像 2023-05-30 22:05:08 702人浏览 独家记忆
摘要

本文实例讲述了Android使用api实现图像扭曲效果。分享给大家供大家参考,具体如下:public class BitmapMesh extends GraphicsActivity { @Override protected void

本文实例讲述了Android使用api实现图像扭曲效果。分享给大家供大家参考,具体如下:

public class BitmapMesh extends GraphicsActivity { @Override protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(new SampleView(this)); } private static class SampleView extends View {   //定义常量,指定该图片横向被划分为20格  private static final int WIDTH = 20;   //定义常量,指定该图片纵向上被划分为20格  private static final int HEIGHT = 20;  //记录该图像上包含441个顶点  private static final int COUNT = (WIDTH + 1) * (HEIGHT + 1);  //位图  private final Bitmap mBitmap;  //数组,记录Bitmap上的21*21个点的坐标  private final float[] mVerts = new float[COUNT * 2];   //记录Bitmap上的21*21个点经过扭曲后的坐标  private final float[] mOrig = new float[COUNT * 2];  private final Matrix mMatrix = new Matrix();  private final Matrix mInverse = new Matrix();  private static void setXY(float[] array, int index, float x, float y) {   array[index * 2 + 0] = x;   array[index * 2 + 1] = y;  }  public SampleView(Context context) {   super(context);   setFocusable(true);   //加载图片   mBitmap = BitmapFactory.decodeResource(getResources(), R.raw.beach);   //获取图像的宽度和高度   float w = mBitmap.getWidth();   float h = mBitmap.getHeight();   //构建扭曲数据   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;      //初始化orig,verts数组     //初始化,orig,verts两个数组均匀地保存了21 * 21个点的x,y坐标      setXY(mVerts, index, fx, fy);     setXY(mOrig, index, fx, fy);     index += 1;    }   }   //设置平移效果   mMatrix.setTranslate(10, 10);   //实现乱矩阵逆向坐标映射   mMatrix.invert(mInverse);  }  @Override  protected void onDraw(canvas canvas) {   canvas.drawColor(0xFFCCCCCC);   //对matrix的变换应用到canvas上的所有对象.   canvas.concat(mMatrix);      canvas.drawBitmapMesh(mBitmap, WIDTH, HEIGHT, mVerts, 0, null, 0,     null);  }  //根据触摸事件的位置计算verts数组里各元素的值  private void warp(float cx, float cy) {   final float K = 10000;   float[] src = mOrig;   float[] dst = mVerts;   for (int i = 0; i < COUNT * 2; i += 2) {    float x = src[i + 0];    float y = src[i + 1];    float dx = cx - x;    float dy = cy - y;    float dd = dx * dx + dy * dy;     //计算每个坐标点与当前点(cx,cy)之间的距离    float d = FloatMath.sqrt(dd);     //扭曲度,距离当前点(cx,cy)越远,扭曲度越小    float pull = K / (dd + 0.000001f);    pull /= (d + 0.000001f);    //对dst数组(保存bitmap 上21 * 21个点经过扭曲后的坐标)赋值    if (pull >= 1) {     dst[i + 0] = cx;     dst[i + 1] = cy;    } else {      //控制各顶点向触摸事件发生点偏移     dst[i + 0] = x + dx * pull;     dst[i + 1] = y + dy * pull;    }   }  }  private int mLastWarpX = -9999; // don't match a touch coordinate  private int mLastWarpY;  @SuppressLint("ClickableViewAccessibility") @Override  public boolean onTouchEvent(MotionEvent event) {   float[] pt = { event.getX(), event.getY() };   //用当前矩阵改变pts中的值,然后存储在pts中,同上,pts也是存储点的坐标的数组   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;  } }}

--结束END--

本文标题: Android使用API实现图像扭曲效果示例

本文链接: https://lsjlt.com/news/221623.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Android使用API实现图像扭曲效果示例
    本文实例讲述了Android使用API实现图像扭曲效果。分享给大家供大家参考,具体如下:public class BitmapMesh extends GraphicsActivity { @Override protected void ...
    99+
    2023-05-30
    android api 图像
  • 怎么在Android中实现绘制扭曲图像
    怎么在Android中实现绘制扭曲图像?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。定义基本变量:MyView是用于显示扭曲的图像的自定义view,angle是圆形轨迹的当前角...
    99+
    2023-05-30
    android
  • Flutter使用NetworkImage实现图像显示效果
    使用 NetworkImage 显示图像 在 GitHub 中,每个成员都有其头像的 URL。您的下一个改进是将该头像添加到Member课程中并在应用程序中显示这些头像。 更新Mem...
    99+
    2024-04-02
  • Android图像视图ImageView实现图像拉伸效果
    本文实例为大家分享了Android图像视图ImageView实现图像拉伸效果的具体代码,供大家参考,具体内容如下 在layout调整属性src指定图形来源。Activity中setS...
    99+
    2024-04-02
  • Flutter怎么使用NetworkImage实现图像显示效果
    本篇内容主要讲解“Flutter怎么使用NetworkImage实现图像显示效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Flutter怎么使用NetworkImage实现图像显示效果”吧!...
    99+
    2023-06-30
  • Python实现图像去雾效果的示例代码
    目录修改部分训练测试数据集下载地址修改部分 我利用该代码进行了去雾任务,并对原始代码进行了增删,去掉了人脸提取并对提取人脸美化的部分,如下图 增改了一些数据处理代码,Create_...
    99+
    2024-04-02
  • Android 自定义View实现芝麻分曲线图效果
    1.简介 其实这个效果几天之前就写了,但是一直没有更新博客,本来想着把芝麻分雷达图也做好再发博客的,然后今天看到鸿洋的微信公众号有朋友发了芝麻分的雷达图,所以就算了,算是一个互...
    99+
    2022-06-06
    view 自定义view Android
  • android实现Splash闪屏效果示例
    本文实例讲述了android实现Splash闪屏效果的方法。分享给大家供大家参考,具体如下: Java代码: public class Splash extends Acti...
    99+
    2022-06-06
    示例 Android
  • Android裁剪图像实现方法示例
    本文实例讲述了Android裁剪图像实现方法。分享给大家供大家参考,具体如下: package com.xiaoma.piccut.demo; import java.io....
    99+
    2022-06-06
    示例 方法 Android
  • Android实现局部图片滑动指引效果示例
    今天发布本文的原因是应一个网友要求,就是实现局部的图片滑动指引效果。这种效果一般是在新闻客户端上比较常见,其功能是: 1、顶部单张图片左右拖拉滑动; 2、带指引; 3、仅...
    99+
    2022-06-06
    示例 图片 Android
  • 使用canvas怎么实现一个扭蛋机动画效果
    使用canvas怎么实现一个扭蛋机动画效果?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。布局扭蛋机的布局比较简单,只需要在基础背景上添加一些元素就可以,最主要的是canvas标...
    99+
    2023-06-09
  • Android自定义AvatarImageView实现头像显示效果
    看看效果图:我们项目中头像显示一般都是圆形的,但是有时候不排除各种样式(不一定是个规则的形状),比如 上次UI给了我一个 圆形下面少了一块。我们一般实现自定义形状的图形有三种方式:PorterDuffXfermode 、BitmapShad...
    99+
    2023-05-30
    android avatarimageview 头像
  • 使用Mybatis实现分页效果示例
    一、创建分页的工具类PageUti,存储分页所需要的五个数据:pageIndex(当前页码),pageSize(每页记录条数),count(总记录数),pageNum(总页数),li...
    99+
    2024-04-02
  • Android转场效果实现示例浅析
    目录前言Activity跳转动画共享元素通过window去实现总结前言 又没什么好的思路,还是随便写一些,所以这次就来整点活。 我们都知道Activity的跳转拥有默认的跳转动画,...
    99+
    2023-02-14
    Android转场效果 Android转场
  • 使用纯CSS、JS实现图片轮播效果的示例
    小编给大家分享一下使用纯CSS、JS实现图片轮播效果的示例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!js有什么特点1、js属于一种解释性脚本语言;2、在绝大多...
    99+
    2023-06-14
  • 如何使用css实现3D图像轮转效果
    这篇文章主要为大家展示了“如何使用css实现3D图像轮转效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用css实现3D图像轮转效果”这篇文章吧。首先看...
    99+
    2024-04-02
  • 使用JavaScript实现简单图像放大镜效果
    目录项目基本结构第 1 步:图像放大镜的基本结构第 2 步:将图像添加到放大镜第 3 步:CSS设计放大镜第 4 步:使用 JavaScript 激活图像放大镜 完整源码下...
    99+
    2022-11-13
    JavaScript图像放大镜 JavaScript 放大镜
  • Android 实现切圆图作为头像使用实例
    Android 切圆图 效果图如下: MyView 类 public class MyView extends View { Bitmap bmp; Paint p...
    99+
    2022-06-06
    Android
  • Android实现拍照及图片显示效果
    本文实例为大家分享了Android拍照及图片显示的具体代码,供大家参考,具体内容如下 1、功能声明 当应用需要使用相机、NFC等外设时,需要在AndroidManifest...
    99+
    2022-06-06
    图片 Android
  • C语言实现二值图像模拟灰值图像显示效果
    本文实例为大家分享了C语言实现二值图像模拟灰值图像显示效果的具体代码,供大家参考,具体内容如下 图案法 图案法(patterning)是指灰度可以用一定比例的黑白点组成的区域表示,从...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作