/**
* @author chenli
* @create 2019/4/26
* @Describe
*/
import android.content.Context;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
/**
* 宽度自适应ImageView,宽度始终充满显示区域,高度成比例缩放
*/
public class AutoScaleWidthImageView extends android.support.v7.widget.AppCompatImageView {
public AutoScaleWidthImageView (Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
Drawable d = getDrawable();
if(d!=null){
// ceil not round - avoid thin vertical gaps along the left/right edges
int width = MeasureSpec.getSize(widthMeasureSpec);
//高度根据使得图片的宽度充满屏幕计算而得
int height = (int) Math.ceil((float) width * (float) d.getIntrinsicHeight() / (float) d.getIntrinsicWidth());
setMeasuredDimension(width, height);
}e
宽度自适应ImageView,宽度始终充满显示区域,高度成比例缩放
最新推荐文章于 2021-06-04 14:03:09 发布
该博客探讨了如何让ImageView在不同设备上宽度始终充满屏幕,同时保持图片高度按比例缩放,确保不失真。通过调整布局和设置图片加载参数,可以达到理想的显示效果。
摘要由CSDN通过智能技术生成