Android中ImageView自适应高度

本文介绍了一种自定义Android ImageView的方法,该方法可以根据屏幕尺寸调整图片显示,避免图片在填充屏幕时发生变形。通过重写onMeasure方法,实现了图片宽度充满屏幕而高度自适应的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在Android的项目中我们经常遇见处理图片的时候需要根据图片的大小适配屏幕,特别是在电商项目中商品详情图片这个情况居多。在这种情况下我们就需要重新自定义ImageView来计算图片的尺寸。

比如这种情况下我们需要把图片的宽度定义为充满屏幕,高度就需要自适应,这时候如果我们直接在布局中定义ImageView的宽和高的话图片就会出现拉伸的情况,我们要想解决这个问题就需要自定义ImageView并且在onMeasure()方法中重新计算ImageView的高度

package com.zyb.common.widget;

import android.content.Context;
import android.graphics.drawable.Drawable;
import android.support.annotation.Nullable;
import android.util.AttributeSet;
import android.widget.ImageView;

/**
 * 描述:
 * 作者:zyb
 * 时间:2017年06月03日  18:59
 * 版本:2.0
 */

public class AdjustImageView extends android.support.v7.widget.AppCompatImageView {
    public AdjustImageView(Context context) {
        super(context);
    }

    public AdjustImageView(Context context, @Nullable AttributeSet attrs) {
        super(context, attrs);
    }

    public AdjustImageView(Context context, @Nullable AttributeSet attrs, int defStyleAttr) {
        super(context, attrs, defStyleAttr);
    }

    @Override
    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
        Drawable d = getDrawable();
        if (d != null) {
            int width = MeasureSpec.getSize(widthMeasureSpec);
            int height = (int) Math.ceil((float) width * (float) d.getIntrinsicHeight() / (float) d.getIntrinsicWidth());
            setMeasuredDimension(width, height);

        } else {
            super.onMeasure(widthMeasureSpec, heightMeasureSpec);

        }
    }
}

布局文件如下:

<com.zyb.common.widget.AdjustImageView
        android:src="@drawable/img_def2"
        android:id="@+id/imageView"
        android:scaleType="fitXY"
        android:adjustViewBounds="true"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/white"/>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值