1

我使用 ImageView 显示图片,我希望图片以矩形显示,比实际尺寸小,但我希望图片可以完全以矩形显示。我设置了其他的scaleType,比如'centerInside',然后图片不能显示在矩形中,但是'center'可以。我想知道如何编写可以在矩形中显示图片的编码,该矩形比它本身还小。

<ImageView
        android:id="@+id/imageView2"
        android:layout_width="20.0dip"
        android:layout_height="20.0dip"
        android:adjustViewBounds="true"
        android:contentDescription="@string/boy"
        android:paddingLeft="20.0dip"
        android:paddingTop="40.0dip"
        android:scaleType="center"
        android:src="@drawable/boy" />
4

6 回答 6

0

两种选择。-

  • 如果 与drawable您的 具有相同的纵横比ImageView,则设置scaleTypefitXY
  • 否则,我会去centerCrop

以防万一你不知道,更多关于scaleTypes 这里

于 2013-10-04T09:31:32.307 回答
0

根据ImageView scale type documentationcenterInside还包括尺寸的填充。

均匀缩放图像(保持图像的纵横比),使图像的两个尺寸(宽度和高度)都等于或小于视图的相应尺寸(减去填充)。

由于您的尺寸padding相同/大于ImageView的尺寸,因此无法显示图像(实际上,它已被推到边界之外)。

使用android:scaleType="centerInside"并考虑使用android:layout_margin而不是android:padding.

于 2013-10-04T09:31:58.237 回答
0

你应该使用android:scaleType="centerInside"

public static final ImageView.ScaleType CENTER_INSIDE

均匀缩放图像(保持图像的纵横比),使图像的两个尺寸(宽度和高度)都等于或小于视图的相应尺寸(减去填充)。然后图像在视图中居中。在 XML 中,使用以下语法:android:scaleType="centerInside"。

详情见这里_

于 2013-10-04T09:34:12.600 回答
0

据我所知,您在使用带有 ImageView 的 scaleType 时遇到问题。将您的 ImageView 放入(例如)FrameLayout 并检查我的示例。

第一个例子:

 <?xml version="1.0" encoding="utf-8"?>  
 <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"  
   android:layout_width="fill_parent"  
   android:layout_height="fill_parent">  
   <ImageView android:layout_width="200dp"  
               android:layout_height="200dp"  
               android:layout_gravity="center"  
               android:src="@drawable/something"  
               android:scaleType="centerInside">  
   </ImageView>  
 </FrameLayout>  

第二(全屏缩放):

 <?xml version="1.0" encoding="utf-8"?>  
 <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"  
   android:layout_width="fill_parent"  
   android:layout_height="fill_parent">  
   <ImageView android:layout_width="fill_parent"  
               android:layout_height="fill_parent"  
               android:layout_gravity="center"  
               android:src="@drawable/something"  
               android:scaleType="centerInside">  
   </ImageView>  
 </FrameLayout>
于 2013-10-04T09:36:59.003 回答
0

试用圆角图片@ http://www.curious-creature.org/2012/12/11/android-recipe-1-image-with-rounded-corners/

找到以下@如何制作带圆角的 ImageView?

http://ruibm.com/?p=184

public class ImageHelper {
public static Bitmap getRoundedCornerBitmap(Bitmap bitmap, int pixels) {
    Bitmap output = Bitmap.createBitmap(bitmap.getWidth(), bitmap
            .getHeight(), Config.ARGB_8888);
    Canvas canvas = new Canvas(output);

    final int color = 0xff424242;
    final Paint paint = new Paint();
    final Rect rect = new Rect(0, 0, bitmap.getWidth(), bitmap.getHeight());
    final RectF rectF = new RectF(rect);
    final float roundPx = pixels;

    paint.setAntiAlias(true);
    canvas.drawARGB(0, 0, 0, 0);
    paint.setColor(color);
    canvas.drawRoundRect(rectF, roundPx, roundPx, paint);

    paint.setXfermode(new PorterDuffXfermode(Mode.SRC_IN));
    canvas.drawBitmap(bitmap, rect, rect, paint);

    return output;
}
}

您还可以查看RoundCornerImageView的演示实现

于 2013-10-04T09:39:19.970 回答
0

使用 scaleType="fitXY" 而不是 center

于 2013-10-04T09:42:47.937 回答