首页 > 其他 > 详细

ViewPage设置自适应

时间:2015-12-23 16:14:30      阅读:305      评论:0      收藏:0      [点我收藏+]

项目中用到ViewPage做轮播图操作,类似于下面这种:

技术分享

  大部分朋友都有类似的需求,创建一个轮播图ViewPage,宽度填充父窗体match_parent,高度自适应wrap_content,但是ViewPage使用的时候会有一个问题,ViewPager无法wrap_content,一旦wrap_content则全屏,估计是系统的测量方法有问题;

其他也有类似的需求,比如一个图片列表,如下:

 

技术分享

      有类似的需求,要求保持图片宽高比,然后宽度拉伸至屏幕宽度,这个时候,就必须用到自定义控件了,在此,分享一段自己写的自定义测量

      1. @Override
        protectedvoidonMeasure(intwidthMeasureSpec,intheightMeasureSpec){
            //获取到宽度的模式
            int width_mode=MeasureSpec.getMode(widthMeasureSpec);
            //获取到屏幕的宽度
            int width_size=MeasureSpec.getSize(widthMeasureSpec);
            //高度的大小
            int height_size=0;
            //说明是填充父窗体
            doublescale=203.0/381.00;
            if(width_mode==MeasureSpec.EXACTLY){
                height_size=(int)(width_size*scale+0.5f);
            }
            widthMeasureSpec=MeasureSpec.makeMeasureSpec(width_size,MeasureSpec.EXACTLY);
          heightMeasureSpec=MeasureSpec.makeMeasureSpec(height_size,MeasureSpec.EXACTLY);
          super.onMeasure(widthMeasureSpec,heightMeasureSpec);
        }    

         

 这段代码的意思是获取系统宽高,然后计算比例 
 doublescale=203.0/381.00;

  这个需要各位童鞋自己去设定图片的宽高,一般是直接找美工美眉确定好上线后的图片大小,然后写入进去; 

  最后强行设置该view的宽高,实现了等比缩放,不仅能填充,还能自适应比例

  该代码在所有的view上都有效,不限于viewpager 

最后,希望能够帮助大家在Android开发的路上越走越远!!





ViewPage设置自适应

原文:http://www.cnblogs.com/Android-MR-wang/p/5070060.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!