ImageView.src设置图片资源,图片不拉伸了,却有空隙部分

当ImageView.src设置图片资源时,通过添加android:adjustViewBounds="true"并配合设置最大宽度和最大高度,可以避免图片拉伸并消除空隙。在XML布局中设置android:scaleType="fitXY",并在代码中动态调整ImageView的LayoutParams,实现图片在指定宽度内充满,高度自适应。

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

问题  ImageView.src设置图片资源,图片不拉伸了,却有空隙部分:

    <LinearLayout
        android:id="@+id/linearLayout1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical" >

    <ImageView
        android:layout_width="wrap_content"
        android:layout_height="205dp"
        android:scaleType="centerInside"
        android:background="@drawable/feature_guide_1" >
    </ImageView>
    </LinearLayout>




解决:如下方式设置 就没有空隙了

    <LinearLayout
        android:id="@+id/linearLayout1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical" >

        <ImageView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:adjustViewBounds="true"
            android:scaleType="fitXY"
            android:src="@drawable/feature_guide_0" >
        </ImageView>
    </LinearLayout>


以下为参考内容的转载:

最近碰到一个需求,要求是在不知道图片宽度和高度的情况下,让图片在指定宽度内充满,同时高度自适应,在网络上查找了一下,也有很多解决方法,后来针对自己的应用,选择了一个修改较小的方案,最后证明效果还是蛮不错的,记录在这里,希望能帮助到有同样需求的人。

好了,言归正传

首先,需要给你的ImageView布局加上android:adjustViewBounds="true"

<ImageView android:id="@+id/test_image"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scaleType="fitXY"
android:adjustViewBounds="true"
android:layout_gravity="center"
android:contentDescription="@string/app_name"
android:src="@drawable/ic_launcher" />

 

然后,在代码里设置ImageView.最大宽度和最大高度,因为adjustViewBounds属性只有在设置了最大高度和最大宽度后才会起作用

int screenWidth = getScreenWidth(this);
ViewGroup.LayoutParams lp = testImage.getLayoutParams();
lp.width = screenWidth;
lp.height = LayoutParams.WRAP_CONTENT;
testImage.setLayoutParams(lp);

testImage.setMaxWidth(screenWidth);
testImage.setMaxHeight(screenWidth * 5); 这里其实可以根据需求而定,我这里测试为最大宽度的5倍


ok,接下来,再按照常规方法加载图片就会得倒预期的效果了,需要的同学可以试试,good luck.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值