Android图像视图ImageView实现图像拉伸效果本⽂实例为⼤家分享了Android图像视图ImageView实现图像拉伸效果的具体代码,供⼤家参考,具体内容如下在layout调整属性src指定图形来源。Activity中setScaleType设置图形的拉伸类型。
MainActivity
ample.junior;
import android.os.Bundle;
import androidx.appcompat.app.AppCompatActivity;
import android.view.View;
import android.widget.ImageView;
// 页⾯类直接实现点击的接⼝View.OnClickListener
public class ScaleActivity extends AppCompatActivity implements View.OnClickListener {
private ImageView iv_scale; // 声明⼀个图像视图的对象
@Override
protected void onCreate(Bundle savedInstanceState) {
setContentView(R.layout.activity_scale);
// 从布局⽂件中获取名叫iv_scale的图像视图
iv_scale = findViewById(R.id.iv_scale);
// 下⾯通过七个按钮,分别演⽰不同拉伸类型的图⽚拉伸效果
findViewById(R.id.btn_center).setOnClickListener(this);
findViewById(R.id.btn_fitCenter).setOnClickListener(this);
findViewById(R.id.btn_centerCrop).setOnClickListener(this);
findViewById(R.id.btn_centerInside).setOnClickListener(this);
findViewById(R.id.btn_fitXY).setOnClickListener(this);
findViewById(R.id.btn_fitStart).setOnClickListener(this);
findViewById(R.id.btn_fitEnd).setOnClickListener(this);
}
@Override
public void onClick(View v) {  // ⼀旦监听到点击动作,就触发的onClick⽅法
if (v.getId() == R.id.btn_center) {
// 将拉伸类型设置为“按照原尺⼨居中显⽰”
iv_scale.setScaleType(ImageView.ScaleType.CENTER);
} else if (v.getId() == R.id.btn_fitCenter) {
// 将拉伸类型设置为“保持宽⾼⽐例,拉伸图⽚使其位于视图中间”
iv_scale.setScaleType(ImageView.ScaleType.FIT_CENTER);
} else if (v.getId() == R.id.btn_centerCrop) {
// 将拉伸类型设置为“拉伸图⽚使其充满视图,并位于视图中间”
iv_scale.setScaleType(ImageView.ScaleType.CENTER_CROP);
} else if (v.getId() == R.id.btn_centerInside) {
// 将拉伸类型设置为“保持宽⾼⽐例,缩⼩图⽚使之位于视图中间(只缩⼩不放⼤)”
iv_scale.setScaleType(ImageView.ScaleType.CENTER_INSIDE);
} else if (v.getId() == R.id.btn_fitXY) {
// 将拉伸类型设置为“拉伸图⽚使其正好填满视图(图⽚可能被拉伸变形)”
iv_scale.setScaleType(ImageView.ScaleType.FIT_XY);
} else if (v.getId() == R.id.btn_fitStart) {
/
/ 将拉伸类型设置为“保持宽⾼⽐例,拉伸图⽚使其位于视图上⽅或左侧”
iv_scale.setScaleType(ImageView.ScaleType.FIT_START);
} else if (v.getId() == R.id.btn_fitEnd) {
// 将拉伸类型设置为“保持宽⾼⽐例,拉伸图⽚使其位于视图下⽅或右侧”
iv_scale.setScaleType(ImageView.ScaleType.FIT_END);
}
}
}
layout
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="schemas.android/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<ImageView
android:id="@+id/iv_scale"
android:layout_width="match_parent"
android:layout_height="200dp"
android:layout_marginTop="10dp"
android:src="@drawable/apple1" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"        android:layout_marginTop="10dp"
android:orientation="horizontal">
<Button
android:id="@+id/btn_fitCenter"android layout布局
android:layout_width="0dp"
android:layout_height="wrap_content"            android:layout_weight="1"
android:text="fitCenter"
android:textColor="#000000"
android:textSize="11sp" />
<Button
android:id="@+id/btn_centerCrop"
android:layout_width="0dp"
android:layout_height="wrap_content"            android:layout_weight="1"
android:text="centerCrop"
android:textColor="#000000"
android:textSize="11sp" />
<Button
android:id="@+id/btn_centerInside"            android:layout_width="0dp"
android:layout_height="wrap_content"            android:layout_weight="1"
android:text="centerInside"
android:textColor="#000000"
android:textSize="11sp" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"        android:layout_marginTop="10dp"
android:orientation="horizontal">
<Button
android:id="@+id/btn_center"
android:layout_width="0dp"
android:layout_height="wrap_content"            android:layout_weight="1"
android:text="center"
android:textColor="#000000"
android:textSize="11sp" />
<Button
android:id="@+id/btn_fitXY"
android:layout_width="0dp"
android:layout_height="wrap_content"            android:layout_weight="1"
android:text="fitXY"
android:textColor="#000000"
android:textSize="11sp" />
<Button
android:id="@+id/btn_fitStart"
android:layout_width="0dp"
android:layout_height="wrap_content"            android:layout_weight="1"
android:text="fitStart"
android:textColor="#000000"
android:textSize="11sp" />
<Button
android:id="@+id/btn_fitEnd"
android:layout_width="0dp"
android:layout_height="wrap_content"            android:layout_weight="1"
android:text="fitEnd"
android:textColor="#000000"
android:textSize="11sp" />
</LinearLayout>
</LinearLayout>
result
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。