Android Matrix (二)具体图形变换参数的获取

这篇具有很好参考价值的文章主要介绍了Android Matrix (二)具体图形变换参数的获取。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Android Matrix (二)具体图形变换参数的获取

Matrix 类在 Android 中用于表示 3x3 的变换矩阵。这个矩阵可以应用于画布(Canvas),视图(View)或者位图(Bitmap),以实现各种图形变换,如旋转、缩放、平移和倾斜。
在 Android 中,Matrix 类并不直接提供方法来查询它所执行的特定变换(如平移、缩放、旋转等)。然而,您可以通过检查矩阵的值来推断出应用于图形的变换。Matrix 类中的 getValues 方法可以用来获取矩阵的九个值,这些值反映了应用于图像的各种变换。
Android Matrix (二)具体图形变换参数的获取,android,android

以下是如何获取和理解这些矩阵值的方法:

float[] values = new float[9];
matrix.getValues(values);

float scaleX = values[Matrix.MSCALE_X];
float scaleY = values[Matrix.MSCALE_Y];
float skewX = values[Matrix.MSKEW_X];
float skewY = values[Matrix.MSKEW_Y];
float transX = values[Matrix.MTRANS_X];
float transY = values[Matrix.MTRANS_Y];
float persp0 = values[Matrix.MPERSP_0];
float persp1 = values[Matrix.MPERSP_1];
float persp2 = values[Matrix.MPERSP_2];

在 Android 的 Matrix 类中,矩阵是一个 3x3 的数组,用于表示二维图形的变换。矩阵中的每个值都有特定的作用,以下是它们的详细分析:

缩放(Scale)

  • ScaleX (Matrix.MSCALE_X)ScaleY (Matrix.MSCALE_Y):这两个值代表图像在 X 轴(水平方向)和 Y 轴(垂直方向)上的缩放比例。
    • 如果 ScaleXScaleY 大于 1,则图像在相应轴上被放大。
    • 如果这些值小于 1,则图像在相应轴上被缩小。
    • 如果这些值等于 1,则图像在该轴上保持原始大小。
    • 实际应用:缩放变换可以用于适配不同屏幕尺寸的视图,或在动画中创建放大和缩小的效果。

倾斜/斜切(Skew)

  • SkewX (Matrix.MSKEW_X)SkewY (Matrix.MSKEW_Y):这两个值代表图像在 X 轴和 Y 轴上的倾斜程度,也称为斜切。
    • SkewXSkewY 通常用于创建图像的倾斜效果。
    • 它们会使图像在一个轴向上倾斜,而在另一个轴向上保持位置。
    • 实际应用:倾斜/斜切变换常用于创建动态的视觉效果,如模仿风吹动的旗帜或斜视角查看图像。

平移(Translate)

  • TransX (Matrix.MTRANS_X)TransY (Matrix.MTRANS_Y):这两个值代表图像在 X 轴和 Y 轴上的平移距离。
    • TransXTransY 用于移动图像的位置。
    • 正值表示沿着正方向的移动,而负值表示沿着负方向的移动。
    • 实际应用:平移变换广泛用于动画中的对象移动,如滑动菜单或对话框的出现和消失。

透视(Perspective)

  • Persp0 (Matrix.MPERSP_0)Persp1 (Matrix.MPERSP_1)Persp2 (Matrix.MPERSP_2):这些值用于实现图像的透视变换。
    • 透视变换影响图像的深度感和三维效果。
    • 它们可以用于创建类似于在三维空间中查看二维图像的效果。
    • 实际应用:透视变换可以用于创建深度感,如在地图应用中模拟3D建筑的视角。

每个值的组合可以创建复杂的变换效果,如旋转(通过结合缩放和倾斜)、倾斜然后平移等。理解这些参数及其相互作用对于高级图形操作非常重要。
Android Matrix (二)具体图形变换参数的获取,android,android文章来源地址https://www.toymoban.com/news/detail-816232.html

分析变换

  • 缩放:通过比较 scaleXscaleY 的值来确定图像是否被缩放,并且缩放了多少。
  • 平移transXtransY 的值如果不为零,则表示图像被平移。
  • 旋转:旋转可以通过 skewXskewY 的值来推断。纯旋转不会改变 scaleXscaleY,但会改变 skewXskewY
  • 倾斜/斜切:如果 skewXskewY 的值不为零,且 scaleXscaleY 也被改变,则图像可能同时经历了旋转和倾斜。

注意事项

  • 获取到的这些值是相对于图像最初状态的变换。如果矩阵经过了多次变换,这些值是累积效果的结果。
  • 解析这些值需要对矩阵变换有一定的理解。
  • 如果您只对特定类型的变换(如平移或缩放)感兴趣,您可能只需检查相关的矩阵值。

到了这里,关于Android Matrix (二)具体图形变换参数的获取的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Android性能优化系列-腾讯matrix-IO监控-IOCanaryPlugin源码分析

    作者:秋去无痕 matrix 对io的监控包括四个方面 监控在主线程执行 IO 操作的问题 监控缓冲区过小的问题 监控重复读同一文件 监控内存泄漏问题 IOCanaryPlugin,内部由IOCanaryCore完成真正的操作。 根据配置进行hook的安装 取消hook 底层hook安装包函几个步骤,加载so,设置hook内容,

    2024年02月09日
    浏览(83)
  • Android画布Canvas矩阵Matrix放大裁剪Rect区域的Bitmap,Kotlin

                          Android Matrix画布Canvas缩放scale,Kotlin-CSDN博客 文章浏览阅读116次,点赞3次,收藏3次。文章浏览阅读9.6k次。文章浏览阅读1.8k次。/*Java代码 将Drawable转化为Bitmap */ Bitmap drawableToBitmap(Drawable drawable) { int width = drawable.getIntrinsicWidth();Android Material Design :Line

    2024年02月03日
    浏览(41)
  • Android Matrix绘制PaintDrawable设置BitmapShader,手指触点为圆心scale放大原图,Kotlin

      在 Android基于Matrix绘制PaintDrawable设置BitmapShader,以手指触点为中心显示原图的圆切图,Kotlin(4)-CSDN博客 的基础上,实现一个功能,手指在上面原图的区域滑动,然后在下面的图中以若干放大因子放大显示切块出来的小图,下面切块出来的原图的圆心是手指在上面的触点

    2024年01月21日
    浏览(50)
  • Android Matrix绘制PaintDrawable设置BitmapShader,手指触点为圆心scale放大原图,Kotlin(二)

      在  Android Matrix绘制PaintDrawable设置BitmapShader,手指触点为圆心scale放大原图,Kotlin-CSDN博客 基础上,限定下面切图的绘制区域,超出绿色区域的轨迹线不再绘制。               所有的绘制轨迹线,都限定在了绿色的圆角矩形框中,超出区域不予绘制。       遗留问题,手

    2024年01月20日
    浏览(62)
  • Android基于Matrix绘制PaintDrawable设置BitmapShader,以手指触点为中心显示原图像圆图,Kotlin(3)

    Android基于Matrix绘制PaintDrawable设置BitmapShader,以手指触点为中心显示原图像圆图,Kotlin(3)       在 Android基于Matrix绘制PaintDrawable设置BitmapShader,以手指触点为中心显示原图像圆图,Kotlin(2)-CSDN博客 文章浏览阅读313次,点赞4次,收藏3次。【代码】Android基于Matrix绘制Pain

    2024年01月20日
    浏览(49)
  • Android基于Matrix绘制PaintDrawable设置BitmapShader,以手指触点为中心显示原图像圆图,Kotlin(2)

      在 https://zhangphil.blog.csdn.net/article/details/135374279 基础上,增加一个功能,当手指在上面的图片上滑动时候,显示滑动轨迹:               https://zhangphil.blog.csdn.net/article/details/135374279 https://zhangphil.blog.csdn.net/article/details/135374279  

    2024年01月16日
    浏览(59)
  • Android 裁剪 几何变换

    canvas.clipRect(left , top ,right,bottom) 裁切函数 canvas.clipPath() // 切割图形 clipOutRect / clipOutPath 切出,切出的是不需要的 clipPath(path) 切出来会有毛边 锯齿,会把指定范围的显示出来,其他的不显示,按像素px进行裁切 如果需要精细显示 可以使用xfermode canvas 几何变换(改变坐标系) tr

    2024年02月11日
    浏览(34)
  • Android跳转具体应用权限管理,三种方式

    背景: Android越来越安全合规,在应用里,需要给用户所有可选择和取消的明确方式。 比如:设置了权限,也要给用户关闭权限的入口。被要求在应用的设置里,提供权限管理入口。 解决方式有三: 方式一:给每个手机厂商跳转做定制适配 有点费力,但是精准,如下:  

    2024年02月16日
    浏览(71)
  • Android基于Matrix绘制PaintDrawable设置BitmapShader,以手指触点为中心显示原图的圆切图,Kotlin(4)

    Android基于Matrix绘制PaintDrawable设置BitmapShader,以手指触点为中心显示原图的圆切图,Kotlin(4)   这篇 Android基于Matrix绘制PaintDrawable设置BitmapShader,以手指触点为中心显示原图像圆图,Kotlin(3)-CSDN博客 虽然实现了上图绘制手指在屏幕滑动的轨迹,且在下面的切图中用中心圆

    2024年01月16日
    浏览(39)
  • Android图形-架构2

    目录 引言 组件概述 底层组件: 上层组件: Android图形架构主要涉及些什么呢? 1)Android 系统级图形架构的基本元素? 2)应用框架和多媒体系统如何使用这些元素? 3)图形数据的缓冲区是如何在系统中移动的? 4) Surface 和 EGLSurface 的交互方式? 5) SurfaceView 和 TextureView 的区

    2024年02月09日
    浏览(74)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包