我们都知道Imageview中有不同的拉伸比率,比如fitStart,centCrop这样的,所以imageview中的drawable不一定和imageview占有相同的位置和大小,那么怎么计算呢?

思路:

1.得到imageview现在的宽高

2.得到imageview现在显示的区域(Rect)

3.得到drawable本身图片的宽高

4.得到drawable显示时的缩放比例

5.计算得到drawable现在显示的宽高

6.通过drawable显示的宽高和imageview显示的宽高来计算出imageview距离内部drawable的内边距

7.通过imageview的显示区域和內边距计算出drawable的显示区域

        // view的实际宽高
float vWidth = v.getWidth();
float vHeight = v.getHeight(); // 得到imageview中的矩阵,准备得到drawable的拉伸比率
Matrix m = v.getImageMatrix();
float[] values = new float[10];
m.getValues(values); // drawable的本身宽高
float dOriginalWidth = drawable.getIntrinsicWidth();
float dOriginalHeight = drawable.getIntrinsicHeight();
float dRatio = dOriginalWidth / dOriginalHeight;//如果大于1,表示drawable宽>高
drawable = null; //Image在绘制过程中的变换矩阵,从中获得x和y方向的缩放系数 value[0],[4]
//得到drawable的实际显示时的宽高
int dWidth = (int)(dOriginalWidth * values[0]);
int dHeight = (int)(dOriginalHeight * values[4]); //得到imageview的宽高和drawable的宽高的差值
float w = vWidth - dWidth;
float h = vHeight - dHeight; Rect startBounds = new Rect();
v.getGlobalVisibleRect(startBounds);

之后通过对startBounds进行修改,就可以求出drawable实际显示的范围了。因为拉伸模式不同,所以计算方式也不同,下面给出几种模式的计算方式

if (originalType == ScaleType.CENTER_INSIDE) {
//finalBounds = getCentInside_originalPic_finalBounds(v, dRatio, startBounds);
finalBounds.left = (int) (startBounds.left + (w / 2) + 0.5f);
finalBounds.top = (int) (startBounds.top + (h / 2) +0.5f);
finalBounds.right = (int) (startBounds.right - (w / 2) + 0.5f);
finalBounds.bottom = (int) (startBounds.bottom - (h / 2) + 0.5f);
}
else if (originalType == ScaleType.FIT_START) {
//finalBounds = getFitStart_originalPic_finalBounds(dRatio, startBounds);
finalBounds.right = (int) (startBounds.right - w + 0.5f);
finalBounds.top = startBounds.top;
finalBounds.left = startBounds.left;
finalBounds.bottom = (int) (startBounds.bottom - h + 0.5f);
}
else if (originalType == ScaleType.FIT_CENTER) {
//finalBounds = getFitCenter_originalPic_finalBounds(dRatio, startBounds);
finalBounds.left = (int) (startBounds.left + (w / 2) + 0.5f);
finalBounds.top = (int) (startBounds.top + (h / 2) +0.5f);
finalBounds.right = (int) (startBounds.right - (w / 2) + 0.5f);
finalBounds.bottom = (int) (startBounds.bottom - (h / 2) + 0.5f);
}
else if (originalType == ScaleType.FIT_END) {
//finalBounds = getFitEnd_originalPic_finalBounds(dRatio, startBounds);
finalBounds.left = (int) (startBounds.left + w + 0.5f);
finalBounds.top = (int) (startBounds.top + h + 0.5f);
finalBounds.right = startBounds.right;
finalBounds.bottom = startBounds.bottom;
}

参考自:http://blog.csdn.net/liu_zhen_wei/article/details/8349400

得到ImageView中drawable显示的区域的计算方法的更多相关文章

  1. Glide加载图片到自定义的圆形ImageView中不显示

    当使用自定义的圆形ImageView时,发现使用Glide加载并设置默认初始图片时,自定义的ImageView一直显示默认图片,无法更新到加载的图片. 使用下面代码可以解决这个问题 Glide.wit ...

  2. Android中EditText显示明文与密文的两种方式

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 记录输入框显示.隐藏密码的简单布局以及实现方式. 效果图    代码分析 方式一 /**方式一:*/ private void sh ...

  3. [转]android中drawable资源的解释及例子

    原文链接:         http://blog.csdn.net/wode_dream/article/details/38584693 文章中的内容参考Dev Guide中的Drawable R ...

  4. Android中Drawable知识总结

    本文是学习<Android开发艺术探索>中Drawable章节之后的一个总结. 一.常见的Drawable种类介绍 Drawable类 xml标签 描述 BitmapDrawable 表示 ...

  5. Android ListView滑动过程中图片显示重复错乱闪烁问题解决

    最新内容建议直接访问原文:Android ListView滑动过程中图片显示重复错乱闪烁问题解决 主要分析Android ListView滚动过程中图片显示重复.错乱.闪烁的原因及解决方法,顺带提及L ...

  6. Android中Drawable分类汇总(上)

    Android把可绘制的对象抽象为Drawable,不同的图形图像资源就代表着不同的drawable类型.Android FrameWork提供了一些具体的Drawable实现,通常在代码中都不会直接 ...

  7. Android:ImageView控件显示图片

    1)android显示图片可以使用imageView来呈现,而且也可以通过ImageButton来实现给button添加图片. 2)在创建一个ImageView后,显示图片绑定元素是:android: ...

  8. CSS---解决内容过多就会出文本溢出(显示在区域外面,不换行的情况)

    当我们设置我的的div,或者其它文本框固定宽度之后,文本内容过多就会出文本溢出(显示在区域外面,不换行的情况). 这时我们可以使用Css中的几个属于来解.有以下的三个属于可以解决问题: 1,word- ...

  9. 如何获取imageView中当前内容的相关信息并比较?

    public class MainActivity extends Activity implements OnClickListener{ private Button button; privat ...

随机推荐

  1. 设置idealUI选中变量的颜色与同名称变量的颜色一致

  2. Java基础常见英语词汇(共70个)

    ——————————ASP.Net+Android+IOS开发..Net培训.期待与您交流!—————————— Java英文单词 OO: object—oriented ,面向对象 OOP:obje ...

  3. 关于日期转换的知识点(SimpleDateFormat)

    这篇文章不是系统的学习,是阅读一些文章,然后总结汇总的. 一:SimpleDateFormat类 1.介绍 SimpleDateFormat 是一个以国别敏感的方式格式化和分析数据的具体类. 它允许格 ...

  4. H5地理位置定位

    一:介绍使用的知识点 1.地理定位的原理 2.geolocation对象 3.Geolocation Api 4.getCurrentPosition的第一个参数 5.getCurrentPositi ...

  5. Python3.7.2,在Linux上跑来跑去的,是在升级打怪么?

    Python3.7.2,在Linux上跑来跑去的,是在升级打怪么?   前不久,发布了Python在Windows(程序员:Python学不学?完全没必要纠结)和Mac OS(我是Python,P派第 ...

  6. SpringAOP实战应用

    Springboot中使用AOP特性非常简单,使用@AspectJ注解,然后再配置中开启AspectJ即可.在日常的应用,有时可以将日志记录和异常处理在一个拦截器中统一处理,但有时在项目中无法通过一个 ...

  7. 基于CommonsCollections4的Gadget分析

    基于CommonsCollections4的Gadget分析 Author:Welkin 0x1 背景及概要 随着Java应用的推广和普及,Java安全问题越来越被人们重视,纵观近些年来的Java安全 ...

  8. 隧道接口工具airtun-ng

    隧道接口工具airtun-ng   airtun-ng是aircrack-ng套件提供的一个工具.该工具可以为无线网卡建立隧道接口.通过该接口,渗透测试人员可以建立wIDS,分析指定的AP的数据.借助 ...

  9. normalizr实践使用(个人总结,仅供参考)

    # normalizr实践使用 原数据 (自编数据,本数据仅供参考) var aaaObj ={ "id" : "0000000000000000000000000000 ...

  10. Kruskal 模板

    最小生成树指的是在图上面找到权值最小的一棵树,并且保证图上所有的点都在这棵树上. 解决办法:Kruskal 算法(贪心思想) 将边按权值从小到大排序,然后按这个顺序不断连边,直到所有点联通. /** ...