ScrollView子View为自定义View时需要注意的几点问题

ScrollView子View为自定义View时需要注意的几点问题       
        分类:            Android 504人阅读 评论(0) 收藏 举报


         在内容现实不全时,通常的做法是在布局中加入ScrollView,使其可以滚定显示。

         在使用ScrollView时需要注意以下几点:


1. ScrollView要求其只有一个子View。当有多个View时,可以使用LinearLayout等布局包含,使其直接子View只有一个。


2. 当ScrollView的子View为自定义View时,


  1. <span style="font-size: 14px;">   mScrollView = new ScrollView(this); 
  2.    ViewGroup.LayoutParams param = new ViewGroup.LayoutParams( 
  3.               ViewGroup.LayoutParams.WRAP_CONTENT, 
  4.             ViewGroup.LayoutParams.WRAP_CONTENT); 
  5.    mScrollView.setLayoutParams(param); 
  6.    mScrollView.addView((View) mMobileView);</span> 
   mScrollView = new ScrollView(this);
   ViewGroup.LayoutParams param = new ViewGroup.LayoutParams(
              ViewGroup.LayoutParams.WRAP_CONTENT,
            ViewGroup.LayoutParams.WRAP_CONTENT);
   mScrollView.setLayoutParams(param);
   mScrollView.addView((View) mMobileView);

  上边的代码中mMobileView 为自定义的View。此时子View的内容是不会显示的,需要通过以下两种方式的设置来显示子VIew

  方法一:mScrollView.setFillViewport(true); 本方法是使子View可以拉伸来填满整个屏幕

  方法二:在自定义View类中MobileView(class MobileView extends View)重写onMeasure方法

  1. <span style="font-size: 14px;">protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
  2.         // TODO Auto-generated method stub 
  3.         setMeasuredDimension(GlobalFun.BWScreenWidth, GlobalFun.BWScreenHeight); 
  4. //      super.onMeasure(widthMeasureSpec, heightMeasureSpec); 
  5.     }</span> 
protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
		// TODO Auto-generated method stub
		setMeasuredDimension(GlobalFun.BWScreenWidth, GlobalFun.BWScreenHeight);
//		super.onMeasure(widthMeasureSpec, heightMeasureSpec);
	}

调用setMeasuredDimension(GlobalFun.BWScreenWidth, GlobalFun.BWScreenHeight);来设置本View的宽和高,这样就会显示。注意宽度和高度必须大于设备的宽和高,此时才会滚动。


3.我遇到这样的情况,我自定义的View是全屏显示的,但是我又需要能够使当满足特定条件时,这个View能够指定其向上或者向下移动指定距离。这时我打算在再加一个子View实现占位的作用,从而实现宽和高为全屏的子View能够滚动。代码如下:

  1. <span style="font-size: 14px;">    mScrollView = new ScrollView(this); 
  2.       ViewGroup.LayoutParams param = new ViewGroup.LayoutParams( 
  3.             ViewGroup.LayoutParams.WRAP_CONTENT, 
  4.             ViewGroup.LayoutParams.WRAP_CONTENT); 
  5.       mScrollView.setLayoutParams(param); 
  6.  
  7.       mFillView = new FillView(this);//占位的View 
  8. //      mFillView.layout(l, t, r, b); 
  9.        
  10.       
  11.      mLinearLayoutMobileMain = new LinearLayout(this); 
  12.      LinearLayout.LayoutParams param3 = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT); 
  13.      mLinearLayoutMobileMain.setLayoutParams(param3); 
  14.      mLinearLayoutMobileMain.setOrientation(LinearLayout.VERTICAL); 
  15.       
  16.     
  17.      mLinearLayoutMobileMain.addView((View)mMobileView); 
  18.      mLinearLayoutMobileMain.addView(mFillView); 
  19.       
  20.      mScrollView.addView(mLinearLayoutMobileMain);</span> 
    mScrollView = new ScrollView(this);
      ViewGroup.LayoutParams param = new ViewGroup.LayoutParams(
      		ViewGroup.LayoutParams.WRAP_CONTENT,
			ViewGroup.LayoutParams.WRAP_CONTENT);
      mScrollView.setLayoutParams(param);

      mFillView = new FillView(this);//占位的View
//      mFillView.layout(l, t, r, b);
      
     
     mLinearLayoutMobileMain = new LinearLayout(this);
     LinearLayout.LayoutParams param3 = new LinearLayout.LayoutParams(LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);
     mLinearLayoutMobileMain.setLayoutParams(param3);
     mLinearLayoutMobileMain.setOrientation(LinearLayout.VERTICAL);
     
   
     mLinearLayoutMobileMain.addView((View)mMobileView);
     mLinearLayoutMobileMain.addView(mFillView);
     
     mScrollView.addView(mLinearLayoutMobileMain);

由于ScrollView只能有一个子View,所以使用LinearLayout包含这两个子VIew(mFillView 和mMobileView)。

FillView中的代码

  1. <span style="font-size: 14px;">public class FillView extends View { 
  2.  
  3.     public FillView(Context context) { 
  4.         super(context); 
  5.         // TODO Auto-generated constructor stub 
  6.     } 
  7.     @Override 
  8.     protected void onDraw(Canvas canvas) { 
  9.         // TODO Auto-generated method stub 
  10.         super.onDraw(canvas); 
  11.     } 
  12.     @Override 
  13.     protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { 
  14.         // TODO Auto-generated method stub 
  15. //      super.onMeasure(widthMeasureSpec, heightMeasureSpec); 
  16.         setMeasuredDimension(GlobalFun.BWScreenWidth, GlobalFun.BWScreenHeight); 
  17.     } 
  18.  
  19. </span> 
public class FillView extends View {

	public FillView(Context context) {
		super(context);
		// TODO Auto-generated constructor stub
	}
	@Override
	protected void onDraw(Canvas canvas) {
		// TODO Auto-generated method stub
		super.onDraw(canvas);
	}
	@Override
	protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
		// TODO Auto-generated method stub
//		super.onMeasure(widthMeasureSpec, heightMeasureSpec);
		setMeasuredDimension(GlobalFun.BWScreenWidth, GlobalFun.BWScreenHeight);
	}

}

设置mFillVIew的 宽和高是屏幕的宽和高,同时自定义的mMobileView的宽和高也是屏幕的宽和高,这样就达到了目的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值