android-缩放ImageView以适合屏幕宽度/高度,同时保持宽高比

我正在Xamarin上开发移动应用程序.

在应用程序中,有一个ImageView显示的图像太小而无法适合屏幕的宽度.

我想缩放图像以适合屏幕宽度,同时保持宽高比.

我的axml

<LinearLayout
    android:id="@+id/overlayImageContainer"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content">
    <ImageView
        android:id="@+id/overlayImageView"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:adjustViewBounds="true"
        android:scaleType="fitCenter"/>
</LinearLayout>

结果

两个ImageViews显示a)比屏幕宽度宽的图片和b)比屏幕宽度窄的图片

android-缩放ImageView以适合屏幕宽度/高度,同时保持宽高比

我尝试了android:scaleType和android:adjustViewBounds =“ true”的各种组合,但均未成功.

解决方法:

事实证明这有点困难,而且开箱即用. Many have similar problems.

我最终将@patrick-boos solution移植到.Net,如下所示:

扩展ImageView类

using Android.Content;
using Android.Util;
using Android.Widget;

namespace Nsa.BigBrotherUtility.Helpers
{
    /// <summary>
    /// DynamicImageView is a helper extension that overrides OnMeasure in order to scale the said image
    /// to fit the entire width/or height of the parent container. 
    /// </summary>
    public class DynamicImageView : ImageView
    {
        public DynamicImageView(Context context, IAttributeSet attributeSet) : base(context, attributeSet)
        {

        }

        protected override void OnMeasure(int widthMeasureSpec, int heightMeasureSpec)
        {
            int width = MeasureSpec.GetSize(widthMeasureSpec);
            int height = width * Drawable.IntrinsicHeight / Drawable.IntrinsicWidth;
            SetMeasuredDimension(width, height);
        }

    }
}

我的axml

<Nsa.BigBrotherUtility.Helpers.DynamicImageView
  android:id="@+id/overlayImageView"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:layout_gravity="center_vertical"
/>

结果

现在,在保持宽高比的同时,可以将600×600的图像拉伸为填充屏幕的宽度

android-缩放ImageView以适合屏幕宽度/高度,同时保持宽高比

上一篇:Android Image Crop Uri异常


下一篇:Android-ViewPager仅翻转布局而不是片段