ImageView.ScaleType设置,适配列表item

本文详细介绍了ImageView的ScaleType属性如何决定图片在View上的显示方式,包括缩放比例和填充模式。探讨了不同属性如center和fitXY的应用场景,为开发者提供实用指导。

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

ImageView的Scaletype决定了图片在View上显示时的样子,如进行何种比例的缩放,及显示图片的整体还是充满,等等。导致参差不齐,效果很差。

设置的方式包括:

在整个item中的ImageView设置属性scaleType,找到适合自己项目的属性。

1. 在layout xml中定义android:scaleType="center"

2. 或在代码中调用 mImageView.setScaleType(ImageView.ScaleType.CENTER);

 

接下来,具体看自己项目中适合用哪个属性,慢慢试。个人感觉fitXY  以及 center 相对常用。

 

书到用时方恨少,纸上得来终觉浅。共勉。

希望可以帮助到你。如有更好的方法,留言评论交流,一定第一时间回复。

 

我的container是子视图 package com.example.a320; import android.net.Uri; import android.os.Bundle; import android.view.View; import android.widget.Button; import android.widget.ImageView; import android.widget.LinearLayout; import android.widget.SearchView; import android.widget.TextView; import android.widget.Toast; import androidx.activity.EdgeToEdge; import androidx.appcompat.app.AppCompatActivity; import androidx.core.graphics.Insets; import androidx.core.view.ViewCompat; import androidx.core.view.WindowInsetsCompat; public class MainActivity extends AppCompatActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); EdgeToEdge.enable(this); setContentView(R.layout.activity_main); ViewCompat.setOnApplyWindowInsetsListener(findViewById(R.id.main), (v, insets) -> { Insets systemBars = insets.getInsets(WindowInsetsCompat.Type.systemBars()); v.setPadding(systemBars.left, systemBars.top, systemBars.right, systemBars.bottom); return insets; }); LinearLayout container = findViewById(R.id.container); String[] texts = {"外卖","超市便利","酒店民俗","休闲玩乐","看病买药","团购","美食","跑腿","拼好饭","电影演出","美团优选","骑车","特价团","免费水果","男士理发"}; // 假设你有 5 张图片的 Uri,这里简单模拟 Uri[] imageUris = new Uri[15]; for (int i = 0; i < 15; i++) { // 这里只是示例,实际需要替换为真实的图片 Uri imageUris[i] = Uri.parse("android.resource://" + getPackageName() + "/mipmap/t" + (i + 1)); } LinearLayout currentRow = null; for (int i = 0; i < 15; i++) { if (i % 5 == 0) { // 每 5 个元素创建一个新的水平 LinearLayout 作为行容器 currentRow = new LinearLayout(this); currentRow.setOrientation(LinearLayout.HORIZONTAL); LinearLayout.LayoutParams rowParams = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.MATCH_PARENT, LinearLayout.LayoutParams.WRAP_CONTENT ); rowParams.bottomMargin = 16; // 设置行与行之间的间距 container.addView(currentRow, rowParams); } // 创建一个垂直的 LinearLayout 用于包含图片和文字 LinearLayout itemLayout = new LinearLayout(this); itemLayout.setOrientation(LinearLayout.VERTICAL); // 创建 ImageView设置图片 ImageView imageView = new ImageView(this); imageView.setImageURI(imageUris[i]); LinearLayout.LayoutParams imageParams = new LinearLayout.LayoutParams( 200, // 图片宽度 170 // 图片高度 ); imageView.setLayoutParams(imageParams); imageView.setScaleType(ImageView.ScaleType.CENTER_CROP); itemLayout.addView(imageView); // 创建 TextView 并设置文字 TextView textView = new TextView(this); textView.setText(texts[i]); LinearLayout.LayoutParams textParams = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT ); textParams.gravity = android.view.Gravity.CENTER_HORIZONTAL; textParams.topMargin = 8; // 设置文字与图片的间距 textView.setLayoutParams(textParams); itemLayout.addView(textView); // 将组合视图添加到当前行 LinearLayout.LayoutParams itemParams = new LinearLayout.LayoutParams( LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT ); itemParams.rightMargin = 66; // 设置元素之间的间距 currentRow.addView(itemLayout, itemParams); } } }
最新发布
03-24
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值