一个demo。在xml布局中。某一行的高度为其它行的一半。之前用layout_weight,得出的效果也不太理想。
<?xml version="1.0" encoding="UTF-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#ff0000" android:layout_weight="2" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="1" android:textColor="@android:color/white" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#cccccc" android:layout_weight="2" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="2" android:textColor="@android:color/black" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#ddaacc" android:layout_weight="1" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="3" android:textColor="@android:color/black" /> </LinearLayout> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:background="#000" android:layout_weight="1" > <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="4" android:textColor="@android:color/white" /> </LinearLayout> </LinearLayout>
虽然有效果了,可是假设里面的内容过多的话,这个布局就不起作用了。
所以我们依据手机屏幕的大小 动态的设置它的高度。
public class HomeActivity extends Activity{ private LinearLayout homelayout; //父 private LinearLayout home1; private LinearLayout home2; private LinearLayout home3; private LinearLayout home4; boolean hasMeasured = false; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_home); home1 = (LinearLayout)findViewById(R.id.home_content_section1); home2 = (LinearLayout)findViewById(R.id.home_content_section2); home3 = (LinearLayout)findViewById(R.id.home_content_section3); home4 = (LinearLayout)findViewById(R.id.home_content_section4); homelayout = (LinearLayout)findViewById(R.id.home_content); ViewTreeObserver vto = homelayout.getViewTreeObserver(); vto.addOnPreDrawListener(new ViewTreeObserver.OnPreDrawListener() { @Override public boolean onPreDraw() { if (hasMeasured == false) { //获取homelayout的宽度和高度 int height = homelayout.getMeasuredHeight(); //int width = homelayout.getMeasuredWidth(); android.view.ViewGroup.LayoutParams lp1 =home1.getLayoutParams(); lp1.height=height*2/7; android.view.ViewGroup.LayoutParams lp2 =home2.getLayoutParams(); lp2.height=height*2/7; android.view.ViewGroup.LayoutParams lp3 =home3.getLayoutParams(); lp3.height=height*1/7; android.view.ViewGroup.LayoutParams lp4 =home4.getLayoutParams(); lp4.height=height*2/7; hasMeasured = true; } return true; } }); }
欢迎交流 http://blog.csdn.net/ycwol/article/details/41279923