首页 > 代码库 > 使用padding值控制控件的隐藏与显示
使用padding值控制控件的隐藏与显示
在学自定义控件下拉刷新这一案例,控制ListView头条目和尾条目的显示隐藏时,就是设置其padding值的正负控制其的显示与消失。这并不是什么很大的知识点。只是一个小技巧,这里给大家分享一下。
这一使用,是否有限制:
在我的案例中,我分别使用了TextView、ImageView和LinearLayout作为显示隐藏的对象,成功控制其显示与隐藏。对于所有的View子类是否都适用,后期了解后,再补充。案例中使用paddingTop控制向上的消失与显示,当然你也可以使用另外三个,控制不同方向的显示与隐藏。
这是我的代码:
MainActivity:
1 package com.aimqq.showhide; 2 3 import android.os.AsyncTask; 4 import android.os.Bundle; 5 import android.os.Handler; 6 import android.os.SystemClock; 7 import android.app.Activity; 8 import android.view.MotionEvent; 9 import android.view.View; 10 import android.view.View.OnTouchListener; 11 import android.widget.ImageView; 12 import android.widget.LinearLayout; 13 import android.widget.RelativeLayout; 14 import android.widget.TextView; 15 16 public class MainActivity extends Activity { 17 18 private static final Integer HIDE = 1001; 19 private static final Integer SHOW = 1002; 20 private TextView content; 21 private int height; 22 boolean isStop; 23 private MyAsyncTask task; 24 private ImageView ic; 25 private int height2; 26 private LinearLayout lay; 27 private int height3; 28 29 @Override 30 protected void onCreate(Bundle savedInstanceState) { 31 super.onCreate(savedInstanceState); 32 setContentView(R.layout.activity_main); 33 content = (TextView) findViewById(R.id.tv_content); 34 ic = (ImageView) findViewById(R.id.iv_ic); 35 lay = (LinearLayout) findViewById(R.id.ll_lay); 36 // content.measure(0, 0); 37 // height = content.getMeasuredHeight(); 38 // ic.measure(0, 0); 39 // height2 = ic.getMeasuredHeight(); 40 lay.measure(0, 0); 41 height3 = lay.getMeasuredHeight(); 42 } 43 44 public void show(View v) { 45 stopPreTask(); 46 task = new MyAsyncTask(); 47 isStop = false; 48 task.execute(-height3, 0, SHOW); 49 } 50 51 public void hide(View v) { 52 stopPreTask(); 53 isStop = false; 54 task = new MyAsyncTask(); 55 task.execute(0, height3, HIDE); 56 } 57 58 private void stopPreTask() { 59 if (task != null) { 60 isStop = true; 61 } 62 task = null; 63 } 64 65 public class MyAsyncTask extends AsyncTask<Integer, Integer, Void> { 66 67 @Override 68 protected void onPreExecute() { 69 70 } 71 72 @Override 73 protected Void doInBackground(Integer... params) { 74 if (params[2] == HIDE) { 75 for (int i = params[0]; i <= params[1]; i++) { 76 if (isStop) { 77 break; 78 } 79 publishProgress(-i); 80 SystemClock.sleep(10); 81 } 82 } else if (params[2] == SHOW) { 83 for (int i = params[0]; i <= params[1]; i++) { 84 if (isStop) { 85 break; 86 } 87 publishProgress(i); 88 SystemClock.sleep(10); 89 } 90 } 91 return null; 92 } 93 94 @Override 95 protected void onPostExecute(Void result) { 96 isStop = false; 97 } 98 99 @Override100 protected void onProgressUpdate(Integer... values) {101 if (isStop) {102 return;103 }104 lay.setPadding(0, values[0], 0, 0);105 lay.invalidate();106 }107 108 }109 }
布局代码:
1 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 2 xmlns:tools="http://schemas.android.com/tools" 3 android:layout_width="match_parent" 4 android:layout_height="match_parent" > 5 6 <LinearLayout 7 android:id="@+id/ll_lay" 8 android:layout_width="match_parent" 9 android:layout_height="wrap_content"10 android:layout_marginTop="45dp"11 android:orientation="vertical" >12 13 <TextView14 android:id="@+id/tv_content"15 android:layout_width="wrap_content"16 android:layout_height="wrap_content"17 android:layout_gravity="center_horizontal"18 android:text="看看我"19 android:textColor="#ff0000"20 android:textSize="25sp" />21 22 <ImageView23 android:id="@+id/iv_ic"24 android:layout_width="wrap_content"25 android:layout_height="wrap_content"26 android:layout_gravity="center_horizontal"27 android:src="http://www.mamicode.com/@drawable/ic_launcher" />28 </LinearLayout>29 30 <LinearLayout31 android:layout_width="match_parent"32 android:layout_height="wrap_content"33 android:layout_centerInParent="true"34 android:orientation="horizontal" >35 36 <Button37 android:layout_width="0dp"38 android:layout_height="wrap_content"39 android:layout_weight="1"40 android:onClick="show"41 android:text="显示" />42 43 <Button44 android:layout_width="0dp"45 android:layout_height="wrap_content"46 android:layout_weight="1"47 android:onClick="hide"48 android:text="隐藏" />49 </LinearLayout>50 51 </RelativeLayout>
效果图:
使用padding值控制控件的隐藏与显示
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。