First, introduction;

The Android ImageView control has a ScaleType property that determines how the image will appear on the ImageView, including whether or not to scale, how to scale, and where to place the image after scaling.

1.1, ScaleType setting methods include a, define android in layout XML: ScaleType =” XXX “; B, call imageView.setScaleType(imageView.scaletype.xxx) in Java code.

1.2. ScaleType includes

A, layout XML: matrix, fitXY, fitStart, fitCenter, fitEnd, Center, centerCrop, centerInside B, Java code: ImageView. ScaleType. MATRIX, ImageView. ScaleType. FIT_XY, ImageView. ScaleType. FIT_START, ImageView. ScaleType. FIT_CENTER, Image The ScaleType FIT_END, ImageView. ScaleType. CENTER, ImageView. ScaleType. CENTER_CROP, ImageView. ScaleType. CENTER_INSIDE

1.3. Default value of ScaleType

fit_center

Second, the graphic display of attributes

The big artwork:

Small artwork:

2.1, the android: scaleType = “center”

A, when the image is larger than the width and height of the ImageView: based on the center point of the image and the center point of the ImageView, centering the image according to the original size of the display, without scaling, using the size of the ImageView to capture the center part of the image.

B, when the image is smaller than the width and height of ImageView: center the image directly.

Layout File:

<? The XML version = "1.0" encoding = "utf-8"? > <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="20dp" tools:context=".MainActivity"> <ImageView android:layout_width="300dp" android:layout_height="300dp" android:layout_centerHorizontal="true" android:background="@android:color/holo_green_light" android:scaleType="center" android:src="@drawable/big" /> <ImageView android:layout_width="300dp" android:layout_height="300dp" android:layout_alignParentBottom="true" android:layout_centerHorizontal="true" android:background="@android:color/holo_green_light" android:scaleType="center" android:src="@drawable/small" /> </RelativeLayout>Copy the code

Display:

 

2.2, the android: scaleType = “centerCrop”

A, when the image is larger than the width and height of ImageView: Base on the center of the image and the center of the ImageView, scale down the image until the width and height of the image on one side is equal to the width and height of the ImageView, and the length of the image on the other side is greater than or equal to the length of the ImageView. Finally, the image is centered with the ImageView size.

B, when the image is smaller than the width and height of the ImageView: base on the center of the image and the center of the ImageView, scale up the image until the width and height of the image is greater than or equal to the width and height of the ImageView, and center the image according to the size of the ImageView.

Layout file

<? The XML version = "1.0" encoding = "utf-8"? > <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:padding="20dp" tools:context=".MainActivity"> <ImageView android:layout_width="300dp" android:layout_height="300dp" android:layout_centerHorizontal="true" android:background="@android:color/holo_green_light" android:scaleType="centerCrop" android:src="@drawable/big" /> <ImageView android:layout_width="300dp" android:layout_height="300dp" android:layout_alignParentBottom="true" android:layout_centerHorizontal="true" android:background="@android:color/holo_green_light" android:scaleType="centerCrop" android:src="@drawable/small" /> </RelativeLayout>Copy the code

Display:

 

2.3, the android: scaleType = “centerInside”

A, when the image is larger than the width and height of the ImageView: based on the center of the image and the center point of the ImageView, scale down the image so that the width and height of the image is equal to or less than the width and height of the ImagevView, until the content of the image is completely centered.

B. When the image is smaller than the width and height of ImageView: center the image directly.

Display:

 

2.4, the android: scaleType = “fitCenter”

Enlarging (shrinking) an image to the width or height of the ImageView, centered.

Display:

2.5, the android: scaleType = “fitStart”

Enlarging (shrinking) an image to the width or height of the ImageView and displaying it above the ImageView.

Effect:

2.6, the android: scaleType = “fitEnd”

Enlarging (shrinking) an image to the width or height of the ImageView, shown below the ImageView.

Effect:

 

2.7, the android: scaleType = “fitXY”

To display an image in an ImageView at the specified size, stretch or shrink the image, not maintain the original scale, and fill the ImageView.

Effect:

2.8, the android: scaleType = “matrix”

Represents the matrix to scale when drawing with an image, which can be set using imageView.setimagematrix (matrix). By default, the image is rendered from the top left corner of the ImageView, without any scaling, and the original image is clipped as it exceeds the ImageView.

Effect: