Android RelativeLayout

本文介绍了一种使用Android的RelativeLayout实现梅花图案的方法。通过定义五个TextView组件,并利用布局属性如layout_centerInParent、layout_above等,使得这些组件呈现出梅花形状。此外,还展示了如何在Activity中动态设置组件间的间距。

RelativeLayout为相对布局,这种布局内的组件总是相对兄弟组件、父容器来确定的,在定义控件的位置时,需要参照其他控件的位置。

这个程序实现了一个梅花的相对布局
\

 

   <?xml version="1.0" encoding="utf-8"?> 
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
        android:orientation="vertical" 
        android:layout_width="fill_parent" 
        android:layout_height="fill_parent" 
        > 
    <!-- 定义该组件位于父容器中间 -->  
    <TextView  
        android:id="@+id/view01" 
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:background="@drawable/leaf" 
        android:layout_centerInParent="true" 
        /> 
    <!-- 定义该组件位于view01组件的上方  与view01左对齐--> 
    <TextView  
        android:id="@+id/view02" 
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:background="@drawable/leaf" 
        android:layout_above="@id/view01" 
        android:layout_alignLeft="@id/view01" 
        /> 
    <!-- 定义该组件位于view01组件的下方 --> 
    <TextView  
        android:id="@+id/view03"   
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:background="@drawable/leaf" 
        android:layout_below="@id/view01" 
        android:layout_alignLeft="@id/view01" 
        /> 
    <!-- 定义该组件位于view01组件的左边 --> 
    <TextView  
        android:id="@+id/view04" 
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:background="@drawable/leaf" 
        android:layout_toLeftOf="@id/view01" 
        android:layout_alignTop="@id/view01" 
        /> 
    <!-- 定义该组件位于view01组件的右边 --> 
    <TextView  
        android:id="@+id/view05" 
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:background="@drawable/leaf" 
        android:layout_toRightOf="@id/view01" 
        android:layout_alignTop="@id/view01" 
        />        
    </RelativeLayout> 
    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
       android:orientation="vertical"
       android:layout_width="fill_parent"
       android:layout_height="fill_parent"
     >
    <!-- 定义该组件位于父容器中间 --> 
    <TextView
       android:id="@+id/view01"
     android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:background="@drawable/leaf"
       android:layout_centerInParent="true"
     />
    <!-- 定义该组件位于view01组件的上方  与view01左对齐-->
    <TextView
       android:id="@+id/view02"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:background="@drawable/leaf"
       android:layout_above="@id/view01"
       android:layout_alignLeft="@id/view01"
     />
    <!-- 定义该组件位于view01组件的下方 -->
    <TextView
       android:id="@+id/view03" 
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:background="@drawable/leaf"
       android:layout_below="@id/view01"
       android:layout_alignLeft="@id/view01"
     />
    <!-- 定义该组件位于view01组件的左边 -->
    <TextView
       android:id="@+id/view04"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:background="@drawable/leaf"
       android:layout_toLeftOf="@id/view01"
       android:layout_alignTop="@id/view01"
     />
    <!-- 定义该组件位于view01组件的右边 -->
    <TextView
       android:id="@+id/view05"
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:background="@drawable/leaf"
       android:layout_toRightOf="@id/view01"
       android:layout_alignTop="@id/view01"
     />  
    </RelativeLayout>

在activity中动态设置控件的间距

import android.app.Activity; 
import android.os.Bundle; 
 
public class RelativeLayoutTest extends Activity 
{ 
    @Override 
    public void onCreate(Bundle savedInstanceState) 
    { 
        super.onCreate(savedInstanceState); 
        setContentView(R.layout.main); 
        findViewById(R.id.view01).setPadding(5, 5 , 5 , 5); //设置各个控件之间的间距  
        findViewById(R.id.view02).setPadding(5, 5 , 5 , 5); 
        findViewById(R.id.view03).setPadding(5, 5 , 5 , 5); 
        findViewById(R.id.view04).setPadding(5, 5 , 5 , 5); 
        findViewById(R.id.view05).setPadding(5, 5 , 5 , 5); 
    } 
} 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值