在CSS中轻松设置width=100%就可以使得图片宽度充满屏幕,高度自适应,那么在Android里面怎样才能实现这种效果呢?


  • 使用默认的ImageView

首先试一下默认的ImageView的效果,布局文件如下activity_main_2.xml:

<?xml version="1.0" encoding="utf-8"?>    


MainActivity2.java

public final class MainActivity2 extends Activity {    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.main_activity_2);        final ImageView imageView = (ImageView)findViewById(R.id.image);        ViewTreeObserver vto2 = imageView.getViewTreeObserver();        vto2.addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {            @Override            public void onGlobalLayout() {                imageView.getViewTreeObserver().removeGlobalOnLayoutListener(this);                Log.e("TestMeasure","w=" + imageView.getWidth() + "  h=" + imageView.getHeight());            }        });    }}


test.jpg(正方形998*998)



可以看到,布局文件设置ImageView充满了屏幕,高度自适应,那运行后是我们需要的效果吗?

结果令人失望,虽然ImageView的宽度充满了屏幕,但是图片并没有填满屏幕,这是为什么呢?


  • 原因分析

回头看看ActivityMain2.java中的打印我们看到了ImageView的宽高信息:

TestMeasure﹕ w=1080  h=998

ImageView的高度是和图片的高度一样的,998px。ImageView的宽度和屏幕宽度一样,1080px。

由于ImageView默认的scaleType是fitCenter,将图片按比例扩大(或缩放)到视图的宽(或高)然后居中显示,所以图片宽度没有充满屏幕的原因就是,ImageView的高度不够,它限制了图片的放大倍数。

  • 自定义ImageView
那如何才能将ImageView的高度放大,使得图片宽度刚好充满屏幕呢?答案肯定在onMeasure方法中。

public class ResizableImageView extends ImageView {    public ResizableImageView(Context context) {        super(context);    }    public ResizableImageView(Context context, AttributeSet attrs) {        super(context, attrs);    }    @Override    protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec){        Drawable d = getDrawable();        if(d!=null){            // ceil not round - avoid thin vertical gaps along the left/right edges            int width = MeasureSpec.getSize(widthMeasureSpec);            //高度根据使得图片的宽度充满屏幕计算而得            int height = (int) Math.ceil((float) width * (float) d.getIntrinsicHeight() / (float) d.getIntrinsicWidth());            setMeasuredDimension(width, height);        }else{            super.onMeasure(widthMeasureSpec, heightMeasureSpec);        }    }}

使用自定义的控件显示图片

    



更多相关文章

  1. Android中将layout_width或layout_height设置为0的情况
  2. Android让屏幕保持常亮,不熄屏的三种方法
  3. Android(安卓)URl网络获取图片
  4. android关于AlertDialog加入EditText无法弹出键盘的问题
  5. android上传图片到七牛云存储demo
  6. android 手机拍照后获取图片导致OOM问题
  7. Android:获取屏幕的宽度和高度
  8. Android(安卓)新的锁屏接口的实现
  9. 使用原始的HTTP拼凑请求的方式上传多张图片

随机推荐

  1. 自定义适配器的实现
  2. Gradle返回包不存在
  3. 与adb的连接已关闭,并且发生了严重错误[重
  4. Kotlin 学习之类和继承
  5. Android中轴旋转特效实现,制作别样的图片
  6. android基础之ProgressDiaLog使用:进度条
  7. android Editview中加小图标或者文字实现
  8. 在android中运行java main方法
  9. 使用线程设置后台进程以处理Android中的
  10. [Android Pro] Android 打包流程