Android开发UI界面设计
ON 六 16 2011 IN ANDROID界面设计 BY ANDROID智能手机 | NO COMMENTS已有1420位网友关注
Android开发UI界面设计主要有两点:一是Android按钮(Button)的UI设计,二是:ListView以及GridView的UI设计。
按钮的状态:
按钮的状态:
我们一般搞UI设计,按钮通常有三个状态:normal(正常状态);focus(焦点状态),pressed(按下状态)。如下图所示:
android layout布局我们会在res/drawable目录下定义一个资源文件,比如我们本例中要用到的l,在里面定义三种状态,每种状态对应一张图片:
代码如下:
<?xml version=”1.0″ encoding=”utf-8″?>
<selector xmlns:android=”schemas.android/apk/res/android”>
<item android:state_window_focused=”false” android:drawable=”@drawable/handle_normal” />
<item android:state_focused=”true” android:drawable=”@drawable/handle_focused” />
<item android:state_pressed=”true” android:drawable=”@drawable/handle_pressed” />
</selector>
<selector xmlns:android=”schemas.android/apk/res/android”>
<item android:state_window_focused=”false” android:drawable=”@drawable/handle_normal” />
<item android:state_focused=”true” android:drawable=”@drawable/handle_focused” />
<item android:state_pressed=”true” android:drawable=”@drawable/handle_pressed” />
</selector>
而我们使用这个资源文件的用法只需要引用drawable里的资源文件(android:background=”@drawable/handle”)代码如下:
<Button
android:id=”@+id/handle”
android:layout_width=”wrap_content”
android:layout_height=”fill_parent”
android:background=”@drawable/handle”
/>
android:layout_width=”wrap_content”
android:layout_height=”fill_parent”
android:background=”@drawable/handle”
/>
Android中的层:
看过《盗梦空间》的人都知道,梦境有多少层,而Android中也有层次之分,在Android中第一层”梦境”,我们可以认为是壁纸。第二层就是应用的Activity,第三层就是放在Activity上的容器(ViewGroup以及它的子类FrameLayout,LinearLayout等布局对象),当然容器中还可以放容器,你也可以放到N层(最多放多少我还没验证过),总之最后一层就是那些继承于View的控件了(诸如,Button,TextView等.)
而ListView以及GridView中UI是怎么设计的呢,下面我们看一下效果图:
上图是一个ListView的效果图,正常状态下是白背景黑字体,当我们点击一列时会出现黄背景。这一效果是如何做到的呢?
ListView单元格显示的内容其实是我们事先定义在Layout目录下的一个布局文件,从这个效果来看,我们可以看出它一共有三个“层”
第一层容器(LinearLayout) 背景为白:
第二层也是容器(LinearLayout)当按下时,背景为黄,把第一层挡住(具体做法可以参照按钮):
第三层是控件(TextView)。
实例 :
上面说了一些,有些人肯定会云里雾里,所以我们直接来个实例,实例做完后,再看一下,效果会更好,大家按照步骤跟我来:
第一步:首先准备素材,准备三个按钮,以及ListView的背景图(上面三个按钮已经有了,下面
我只贴一个ListView背景图片):
第二步:新建一个Android工程,命名为UIDemo.目录结构如下图所示:
第三步:在res目录下新建一个drawable文件夹,定义两个资源文件一个是l另一个为l,其中l代码已经在上面贴出,l代码如下:
<?xml version=”1.0″ encoding=”utf-8″?>
<selector xmlns:android=”schemas.android/apk/res/android”>
<item android:state_pressed=”true” android:drawable=”@drawable/list_selector_background_pressed” />
</selector>
<selector xmlns:android=”schemas.android/apk/res/android”>
<item android:state_pressed=”true” android:drawable=”@drawable/list_selector_background_pressed” />
</selector>
第四步:修改l布局文件,这里我用到了SliddingDrawer控件,代码如下:
<?xml version=”1.0″ encoding=”utf-8″?>
<LinearLayout xmlns:android=”schemas.android/apk/res/android”
<LinearLayout xmlns:android=”schemas.android/apk/res/android”
android:orientation=”vertical”
android:layout_width=”fill_parent”
android:layout_height=”fill_parent”
>
<SlidingDrawer
android:id=”@+id/slidingdrawer”
android:layout_width=”fill_parent”
android:layout_height=”fill_parent”
android:orientation=”horizontal”
android:handle=”@+id/handle”
android:content=”@+id/content”>
<Button
android:id=”@+id/handle”
android:layout_width=”wrap_content”
android:layout_height=”fill_parent”
android:layout_width=”fill_parent”
android:layout_height=”fill_parent”
>
<SlidingDrawer
android:id=”@+id/slidingdrawer”
android:layout_width=”fill_parent”
android:layout_height=”fill_parent”
android:orientation=”horizontal”
android:handle=”@+id/handle”
android:content=”@+id/content”>
<Button
android:id=”@+id/handle”
android:layout_width=”wrap_content”
android:layout_height=”fill_parent”
android:background=”@drawable/handle”
/>
<ListView
android:id=”@+id/content”
android:layout_width=”fill_parent”
android:layout_height=”wrap_content”
/>
</SlidingDrawer>
</LinearLayout>
/>
<ListView
android:id=”@+id/content”
android:layout_width=”fill_parent”
android:layout_height=”wrap_content”
/>
</SlidingDrawer>
</LinearLayout>
我们这里用到了ListView控件,而我们ListView控件显示的内容我事先在layout目录下定义两个TextView,命名为l,代码如下(这里有三层哦!):
<?xml version=”1.0″ encoding=”utf-8″?>
<LinearLayout xmlns:android=”schemas.android/apk/res/android”
android:orientation=”vertical”
<LinearLayout xmlns:android=”schemas.android/apk/res/android”
android:orientation=”vertical”
android:layout_width=”fill_parent”
android:layout_height=”fill_parent”
android:background=”#ffffff”
>
<LinearLayout
android:orientation=”vertical”
android:layout_width=”fill_parent”
android:layout_height=”fill_parent”
android:background=”@drawable/listview_selected”
android:padding=”6px”
>
<TextView
android:id=”@+id/bookname”
android:layout_width=”fill_parent”
android:layout_height=”wrap_content”
android:layout_height=”fill_parent”
android:background=”#ffffff”
>
<LinearLayout
android:orientation=”vertical”
android:layout_width=”fill_parent”
android:layout_height=”fill_parent”
android:background=”@drawable/listview_selected”
android:padding=”6px”
>
<TextView
android:id=”@+id/bookname”
android:layout_width=”fill_parent”
android:layout_height=”wrap_content”
android:textSize=”20px”
android:textColor=”#000000″
/>
<TextView
android:id=”@+id/author”
android:layout_width=”fill_parent”
android:layout_height=”wrap_content”
android:textSize=”16px”
android:textColor=”#000000″
/>
</LinearLayout>
</LinearLayout>
android:textColor=”#000000″
/>
<TextView
android:id=”@+id/author”
android:layout_width=”fill_parent”
android:layout_height=”wrap_content”
android:textSize=”16px”
android:textColor=”#000000″
/>
</LinearLayout>
</LinearLayout>
第五步:修改主核心程序UIDemo.java,代码如下:
package com.tutor.uidemo;
import android.app.Activity;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
public class UIDemo extends Activity {
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
public class UIDemo extends Activity {
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论