获取imageview 图片大小

摘要:
如标题所示,ImageView在显示图像时受到屏幕大小以及图像宽度和高度的限制。通常,图像是缩放的,并且在宽度和高度上没有充满ImageView。

如题,ImageView在显示图片的时候,受限于屏幕大小,和图片宽高。通常图片是被缩放过,且不是宽和高都充满ImageView的。

此时,我们如何获得Image被实际绘制的宽高呢?如下:

  1. finalImageViewiv=(ImageView)findViewById(R.id.iv_test);
  2. iv.setImageResource(R.drawable.abc);
  3. //等待ImageVivew加载完成
  4. iv.post(newRunnable(){
  5. @Override
  6. publicvoidrun(){
  7. //TODOAuto-generatedmethodstub
  8. //ImageView的宽和高
  9. Log.d("lxy","iv_W="+iv.getWidth()+",iv_H="+iv.getHeight());
  10. //获得ImageView中Image的真实宽高,
  11. intdw=iv.getDrawable().getBounds().width();
  12. intdh=iv.getDrawable().getBounds().height();
  13. Log.d("lxy","drawable_X="+dw+",drawable_Y="+dh);
  14. //获得ImageView中Image的变换矩阵
  15. Matrixm=iv.getImageMatrix();
  16. float[]values=newfloat[10];
  17. m.getValues(values);
  18. //Image在绘制过程中的变换矩阵,从中获得x和y方向的缩放系数
  19. floatsx=values[0];
  20. floatsy=values[4];
  21. Log.d("lxy","scale_X="+sx+",scale_Y="+sy);
  22. //计算Image在屏幕上实际绘制的宽高
  23. intcw=(int)(dw*sx);
  24. intch=(int)(dh*sy);
  25. Log.d("lxy","caculate_W="+cw+",caculate_H="+ch);
  26. }});
    1. <ImageView
    2. android:id="@+id/iv_test"
    3. android:layout_width="match_parent"
    4. android:layout_height="match_parent"
    5. />

免责声明:文章转载自《获取imageview 图片大小》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇如何在 Serverless K8s 集群中低成本运行 Spark 数据计算?利用strace &amp;amp; Perf分析MySQL下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

随便看看

Hibernate 数据的批量插入、更新和删除

对于这个批处理场景,Hibernate提供了一个批处理解决方案。接下来,我们将从批插入、批更新和批删除三个方面介绍如何处理此批处理场景。为了避免这种情况,Hibernate为批量更新和批量删除提供了类似于SQL的HQL语法。...

Redis设置Auth认证保护

Redis有一种保护数据安全的身份验证方法。有两种方法可以设置此身份验证。一个是通过配置文件。另一种是直接在Redis客户端命令中设置参数requirepas。首先是在配置文件中查找参数requirepass。这是配置Redis访问密码的参数。由于Redis具有很强的并发能力,并且只使用密码,攻击者可能会在短时间内发送大量密码猜测请求,这很容易被暴力破解。因...

oracle的序列号(sequence)

Oracle的自动递增列应使用序列号。在初始化阶段,需要手动创建序列,然后在插入序列时手动读取分配给相关字段(如ID)的序列的nextval。这很麻烦。但是,这对于SQL Server来说不是问题,可以获得。oracle的序列号也有缓存。默认情况下,一次生成20个。如果没有用完,它们可能会丢失,这可能会导致ID不一致。此外,有时这可能会引起误解。例如,我有一...

zabbix监控华为交换机

xmlversion=“1.0”encoding=“UTF-8”?...

sqlserver2016安装

2008以前的版本在SQLserver配置管理其中设置。...

SQL中一次插入多条数据

SQL中insert一次可以插入一条数据,我们有三种方法可以一次性插入多条数据。在此处还有一些有趣的问题,当我使用以下代码来插入多条数据时:selecttop0*intonewstudentfromstudentinsertintonewstudentselect*fromstudent这里会发生这样的报错:因为NewClass表中ClassId为标识列,所...