Android控件大全以及各布局空间的使用方式

Android控件大全以及各布局空间的使用方式
Android控件大全以及各布局空间的使用方式

控件讲解

? 在Windows 下搭建Android 开发环境

? Android 项目的目录结构说明

? 写一个简单的Hello World 程序

一、在Windows 下搭建Android 开发环境

1、安装JDK (Java Development Kit)

https://www.360docs.net/doc/b61355447.html,/jdk6/

2、安装Android SDK

https://www.360docs.net/doc/b61355447.html,/sdk

3、安装Eclipse

https://www.360docs.net/doc/b61355447.html,/

4、打开Eclipse ,并安装其Android 插件(ADT)

打开菜单"Help" -> "Install New Software",在"Availabe Software" 中加入地址https://www.360docs.net/doc/b61355447.html,/android/eclipse/ ,然后安装ADT(Android Development Tools)

5、新建Android 项目

"New" -> Android Project,Project Name - 项目名称;Build Target - 编译项目的SDK 版本;Application name - 程序名称;Package name - 包名;Min SDK Version - 程序所支持的最低SDK 版本代号(2 对应 1.1,3 对应 1.5,4 对应 1.6)

6、运行Android 项目

打开菜单"Run" -> "Run Configurations" -> New launch configuration,设置启动项目名称,在Android 选项卡中选择启动项目,在Target 选项卡中设置模拟器

7、创建/使用模拟SD 卡

创建SD 卡,运行类似如下命令:mksdcard -l sdcard 512M d:\android\sdcard.img

模拟器中使用SD 卡,在项目配置的Target 选项卡的"Additional Emulator Command Line Options" 框中输入类似如下参数:-sdcard d:\android\sdcard.img

8、配置模拟器

运行类似如下命令:android create avd --name android15 --target 2。或者直接在菜单 "Window" -> "Android AVD Manager" 中配置模拟器

9、浏览模拟SD 卡中的内容

调试程序,在DDMS 中选择"File Explorer" ,在其中的 sdcard 目录下就是模拟SD 卡中的内容

10、查看日志LogCat

Window -> Show View -> Other -> Android -> LogCat

11、在模拟器中安装/卸载apk

安装apk 运行类似如下命令:adb install name.apk;卸载apk 运行类似如下命令:adb uninstall packagename(注:这里的参数是需要卸载的包名)

12、反编译Android 程序

解压apk 文件,取出其中的classes.dex 文件,运行类似如下命令:dexdump.exe -d classes.dex > dump.txt(其意思是将classes.dex dump 出来,并将反编译后的代码保存到指定的文本文件中)

13、人品不好是出现的某些错误的解决办法

如果出现类似如下的错误等

no classfiles specified

Conversion to Dalvik format failed with error 1

解决办法:Project -> Clean

出现Android SDK Content Loader 60% (一直卡在 60%)

解决办法:Project -> 去掉Build Automatically 前面的勾

14、查看SDK 源代码

先想办法搞到源代码,如这个地址https://www.360docs.net/doc/b61355447.html,/android.asp ,然后将其解压到SDK 根路径下的sources 文件夹内即可

二、Android 项目的目录结构

1、src - 用于放置源程序

2、gen - 自动生成R.java 文件,用于引用资源文件(即res 目录下的数据)

3、assets - 用于放置原始文件,Android 不会对此目录下的文件做任何处理,这是其与res 目录不同的地方

4、res/drawable - 用于放置图片之类的资源;res/layout - 用于放置布局用的xml 文件;res/values - 用于放置一些常量数据

5、AndroidManifest.xml - Android 程序的清单文件,相当于配置文件,配置应用程序名称、图标、Activity、Service、Receiver等

三、Hello World 程序

1、res/layout/main.xml

代码

android:orientation="vertical"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:id="@+id/layout"

>

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:text="@string/hello"

/>

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:id="@+id/txt"

/>

2、res/values/strings.xml

代码

layout 直接调用values 中的字符串

编程方式调用values 中的字符串

webabcd_hello

3、res/drawable 目录下放置一个名为icon.png 的图片文件

4、AndroidManifest.xml

代码

package="com.webabcd.hello"

android:versionCode="1"

android:versionName="1.0">

android:label="@string/app_name">

5、Main.java

代码

package com.webabcd.hello;

import android.app.Activity;

import android.os.Bundle;

import android.widget.LinearLayout;

import android.widget.TextView;

public class Main extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

// 将指定的布局文件作为Activity 所显示的内容

setContentView(https://www.360docs.net/doc/b61355447.html,yout.main);

// 动态地在指定的容器控件上添加新的控件

TextView txt = new TextView(this);

txt.setText("动态添加控件");

// setContentView(txt);

((LinearLayout)this.findViewById(https://www.360docs.net/doc/b61355447.html,yout)).addView(txt);

// 引用资源文件内的内容作为输出内容

TextView txt1 = (TextView)this.findViewById(R.id.txt);

txt1.setText(this.getString(R.string.hello2));

}

}

四、系出名门Android(2) - 布局(Layout)和菜单(Menu)

介绍

在Android 中各种布局的应用,以及菜单效果的实现

? 各种布局方式的应用,FrameLayout, LinearLayout, TableLayout, AbsoluteLayout, RelativeLayout

? 为指定元素配置上下文菜单,为应用程序配置选项菜单,以及多级菜单的实现

1、各种布局方式的演示(FrameLayout, LinearLayout, TableLayout,

AbsoluteLayout, RelativeLayout)

res/layout/main.xml

代码

layout_width - 宽。fill_parent: 宽度跟着父元素走;wrap_content: 宽度跟着本身的内容走;直接指定一个px 值来设置宽

layout_height - 高。fill_parent: 高度跟着父元素走;wrap_content: 高度跟着本身的内容走;直接指定一个px 值来设置高

-->

android:orientation="vertical" android:gravity="right"

android:layout_width="fill_parent" android:layout_height="fill_parent">

android:layout_width="fill_parent">

android:layout_height="wrap_content" android:text="Fram eLayout">

android:layout_height="wrap_content" android:text="Fram e Layout">

android:layout_height="wrap_content" android:text="@string/hello" />

android:layout_width="fill_parent" android:layout_height="wrap_content"

android:collapseColumns="1">

android:layout_height="wrap_content">

android:layout_weight="1" android:layout_height="wrap_content"

android:text="行1列1" />

android:layout_weight="1" android:layout_height="wrap_content"

android:text="行1列2" />

android:layout_weight="1" android:layout_height="wrap_content"

android:text="行1列3" />

android:layout_height="wrap_content">

android:layout_height="wrap_content" android:text="行2列1" />

android:layout_width="fill_parent">

android:layout_height="wrap_content" android:text="AbsoluteLayout"

android:layout_x="100px"

android:layout_y="100px" />

android:layout_width="fill_parent" android:layout_height="fill_parent">

android:layout_height="wrap_content" android:text="centerInParent=true"

android:layout_centerInParent="true" />

android:layout_height="wrap_content" android:text="marginLeft=20px"

android:layout_marginLeft="20px" />

android:layout_height="wrap_content" android:text="xxx"

android:layout_below="@id/abc" android:layout_alignRight="@id/abc" />

res/values/strings.xml

Hello Layout

webabcd_layout

Main.java

代码

package https://www.360docs.net/doc/b61355447.html,yout;

import android.app.Activity;

import android.os.Bundle;

public class Main extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(https://www.360docs.net/doc/b61355447.html,yout.main);

}

}

2、上下文菜单,选项菜单,子菜单

res/layout/main.xml

代码

android:orientation="vertical" android:layout_width="fill_parent"

android:layout_height="fill_parent">

android:layout_height="wrap_content" android:text="@string/hello_contextMenu" />

android:layout_height="wrap_content" android:text="@string/hello_subMenu" />

res/values/strings.xml

代码

Hello Context Menu

Hello Context Sub Menu

webabcd_menu

Main.java

代码

package com.webabcd.menu;

import android.app.Activity;

import android.os.Bundle;

import android.view.ContextMenu;

import android.view.Menu;

import android.view.MenuItem;

import android.view.SubMenu;

import android.view.View;

import android.view.ContextMenu.ContextMenuInfo;

import android.widget.TextView;

import android.widget.Toast;

// 演示两种菜单的实现方式:上下文菜单(通过在某元素上长按,来呼出菜单)和选项菜单(通过按手机上的菜单按钮,来呼出菜单)

public class Main extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(https://www.360docs.net/doc/b61355447.html,yout.main);

// 为R.id.txt1 注册一个上下文菜单(在此TextView 上长按,则会呼出上下文菜单)

// 具体呼出的菜单内容需要重写onCreateContextMenu 来创建

TextView txt1 = (TextView) this.findViewById(R.id.txt1);

this.registerForContextMenu(txt1);

// 为R.id.txt2 注册一个上下文菜单

TextView txt2 = (TextView) this.findViewById(R.id.txt2);

this.registerForContextMenu(txt2);

}

// 重写onCreateContextMenu 用以创建上下文菜单

// 重写onContextItemSelected 用以响应上下文菜单

@Override

public void onCreateContextMenu(ContextMenu menu, View v,

ContextMenuInfo menuInfo) {

super.onCreateContextMenu(menu, v, menuInfo);

// 创建R.id.txt1 的上下文菜单

if (v == (TextView) this.findViewById(R.id.txt1)) {

// ContextMenu.setIcon() - 设置菜单的图标

// ContextMenu.setHeaderTitle() - 设置菜单的标题

menu.setHeaderIcon(R.drawable.icon01);

menu.setHeaderTitle("我是菜单");

// 用ContextMenu.add() 来增加菜单项,返回值为MenuItem

// 第一个参数:组ID

// 第二个参数:菜单项ID

// 第三个参数:顺序号

// 第四个参数:菜单项上显示的内容

menu.add(1, 0, 0, "菜单1");

// MenuItem - 新增菜单项后的返回类型,针对菜单项的其他设置在此对象上操作

menu.add(1, 1, 1, "菜单2").setCheckable(true);

}

// 创建R.id.txt2 的上下文菜单(多级上下文菜单)

else if (v == (TextView) this.findViewById(R.id.txt2)) {

// ContextMenu.addSubMenu("菜单名称") - 用来添加子菜单。子菜单其实就是一个特殊的菜单

SubMenu sub = menu.addSubMenu("父菜单1");

sub.setIcon(R.drawable.icon01);

sub.add(0, 0, 0, "菜单1");

sub.add(0, 1, 1, "菜单2");

sub.setGroupCheckable(1, true, true);

SubMenu sub2 = menu.addSubMenu("父菜单2");

sub2.setIcon(R.drawable.icon01);

sub2.add(1, 0, 0, "菜单3");

sub2.add(1, 1, 1, "菜单4");

sub2.setGroupCheckable(1, true, false);

}

}

// 重写onCreateOptionsMenu 用以创建选项菜单

@Override

public boolean onCreateOptionsMenu(Menu menu) {

MenuItem menuItem = menu.add(0, 0, 0, "菜单111111111111111111111");

// MenuItem.setIcon() - 设置菜单项的图标

// MenuItem.setTitleCondensed() - 菜单的简标题,如果指定了简标题的话,菜单项上的标题将会以此简标题为准

// MenuItem.setAlphabeticShortcut() - 设置选中此菜单项的快捷键

// 注:菜单项超过6 个的话,第6 个菜单将会变为More 菜单,多余的菜单会在单击More 菜单之后显示出来

menuItem.setIcon(R.drawable.icon01);

menuItem.setTitleCondensed("菜单1");

menuItem.setAlphabeticShortcut('a');

menu.add(0, 1, 1, "菜单2").setIcon(R.drawable.icon02);

menu.add(0, 2, 2, "菜单3").setIcon(R.drawable.icon03);

menu.add(0, 3, 3, "菜单4");

menu.add(0, 4, 4, "菜单5");

menu.add(0, 5, 5, "菜单6");

menu.add(0, 6, 6, "菜单7").setIcon(R.drawable.icon04);

menu.add(0, 7, 7, "菜单8").setIcon(R.drawable.icon05);

return true;

}

// 重写onOptionsItemSelected 用以响应选项菜单

@Override

public boolean onOptionsItemSelected(MenuItem item) {

super.onOptionsItemSelected(item);

Toast.makeText(Main.this, "被单击的菜单项为:" + String.valueOf(item.getItemId()), Toast.LENGTH_SHORT).show();

return false;

}

}

对话框(Dialog)和通知(Notification)

作者:webabcd

介绍

在Android 中种对话框及各种通知效果的应用

? 常用对话框的使用,弹出式对话框、日期选择对话框、时间选择对话框、进度条对话框

? 通知(出现在通知列表)和提示性通知(Toast)的演示

3、常用对话框的演示

res/layout/main.xml

代码

android:orientation="vertical" android:layout_width="fill_parent"

android:layout_height="fill_parent">

android:layout_height="wrap_content">

res/layout/view.xml

代码

android:orientation="vertical" android:layout_width="fill_parent"

android:layout_height="fill_parent">

android:layout_width="wrap_content" android:layout_height="wrap_content">

res/values/array.xml

项目1

项目2

Main.java

代码

package com.webabcd.dialog;

import java.util.Calendar;

import android.app.Activity;

import android.app.AlertDialog;

import android.app.DatePickerDialog;

import android.app.Dialog;

import android.app.ProgressDialog;

import android.app.TimePickerDialog;

import android.app.DatePickerDialog.OnDateSetListener;

import android.app.TimePickerDialog.OnTimeSetListener;

import android.content.DialogInterface;

import android.content.DialogInterface.OnClickListener;

import android.os.Bundle;

import android.view.View;

import android.widget.DatePicker;

import android.widget.TextView;

import android.widget.TimePicker;

import android.widget.Button;

public class Main extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(https://www.360docs.net/doc/b61355447.html,yout.main);

// 弹出式对话框的Demo。先调用Builder(),在Create(),需要显示对话框的是后再调用show()

AlertDialog dialog = new AlertDialog.Builder(this).setTitle("弹出对话框").create();

dialog.show();

// 以下是各种对话框的Demo

MyButtonClickListener listener = new MyButtonClickListener();

Button btn1 = (Button) this.findViewById(R.id.btn1);

btn1.setText("简单的对话框的Demo");

btn1.setOnClickListener(listener);

Button btn2 = (Button) this.findViewById(R.id.btn2);

btn2.setText("包括常用设置的对话框(数据来自xml)");

btn2.setOnClickListener(listener);

Button btn3 = (Button) this.findViewById(R.id.btn3);

btn3.setText("弹出的对话框的内容是一个View");

btn3.setOnClickListener(listener);

Button btn4 = (Button) this.findViewById(R.id.btn4);

btn4.setText("日期选择对话框");

btn4.setOnClickListener(listener);

Button btn5 = (Button) this.findViewById(R.id.btn5);

btn5.setText("时间选择对话框");

btn5.setOnClickListener(listener);

Button btn6 = (Button) this.findViewById(R.id.btn6);

btn6.setText("进度条对话框");

btn6.setOnClickListener(listener);

}

class MyButtonClickListener implements View.OnClickListener {

@Override

public void onClick(View v) {

// 具体的对话框的实现可以通过重写onCreateDialog 完成

switch (v.getId()) {

case R.id.btn1:

Main.this.showDialog(0);

break;

case R.id.btn2:

Main.this.showDialog(1);

break;

case R.id.btn3:

Main.this.showDialog(2);

break;

case R.id.btn4:

Main.this.showDialog(3);

break;

case R.id.btn5:

Main.this.showDialog(4);

break;

case R.id.btn6:

Main.this.showDialog(5);

break;

}

}

}

@Override

public Dialog onCreateDialog(int id) {

switch (id) {

case 0:

// 一个简单的弹出对话框

return new AlertDialog.Builder(this).setTitle("这是一个简单的弹出对话框的Demo") .create();

case 1:

// 一个相对复杂的弹出对话框

return new AlertDialog.Builder(this)

.setTitle("标题") // 设置标题

// .setCustomTitle(View) // 以一个View 作为标题

.setIcon(R.drawable.icon01) // 设置标题图片

// .setMessage("信息") // 需要显示的弹出内容

.setPositiveButton("确定", new OnClickListener() { // 设置弹框的确认按钮所显示的文本,以及单击按钮后的响应行为

@Override

public void onClick(DialogInterface a0, int a1) {

TextView txtMsg = (TextView) Main.this.findViewById(R.id.txtMsg);

txtMsg.append("单击了对话框上的“确认”按钮\n");

}

})

.setItems(R.array.ary, new DialogInterface.OnClickListener() { // 弹框所显示的内容来自一个数组。数组中的数据会一行一行地依次排列

public void onClick(DialogInterface dialog, int which) {

}

})

// 其他常用方法如下

// .setMultiChoiceItems(arg0, arg1, arg2)

// .setSingleChoiceItems(arg0, arg1, arg2)

// .setNeutralButton(arg0, arg1)

// .setNegativeButton(arg0, arg1)

.create();

case 2:

// 弹出对话框为指定的View 的Demo

return new AlertDialog.Builder(this).setTitle("此对话框的内容是一个View")

.setView(this.findViewById(https://www.360docs.net/doc/b61355447.html,yout.view)).create();

case 3:

// 弹出日期选择对话框

Calendar c = Calendar.getInstance();

return new DatePickerDialog(this, new OnDateSetListener() {

@Override

public void onDateSet(DatePicker view, int year, int monthOfYear, int dayOfMonth) {

TextView txtMsg = (TextView) Main.this.findViewById(R.id.txtMsg);

txtMsg.append("新设置的日期为:" + String.valueOf(year) + "-"

+ String.valueOf(monthOfYear) + "-"

+ String.valueOf(dayOfMonth) + "\n");

}

}, c.get(Calendar.YEAR), c.get(Calendar.MONTH), c.get(Calendar.DATE));

case 4:

// 弹出时间选择对话框

Calendar c2 = Calendar.getInstance();

return new TimePickerDialog(this, new OnTimeSetListener() {

@Override

public void onTimeSet(TimePicker view, int hourOfDay, int minute) {

TextView txtMsg = (TextView) Main.this.findViewById(R.id.txtMsg);

txtMsg.append("新设置的时间为:"

+ String.valueOf(hourOfDay) + ":"

+ String.valueOf(minute) + "\n");

}

}, c2.get(Calendar.HOUR), c2.get(Calendar.MINUTE), true);

case 5:

// 弹出进度条对话框

ProgressDialog progress = new ProgressDialog(this);

progress.setMessage("loading...");

return progress;

default:

return null;

}

}

}

4、各种提示效果的演示

res/layout/main.xml

代码

android:orientation="vertical" android:layout_width="fill_parent"

android:layout_height="fill_parent">

res/layout/view.xml

代码

android:orientation="vertical" android:layout_width="fill_parent"

android:layout_height="fill_parent">

android:layout_height="wrap_content">

Main.java

代码

package com.webabcd.notification;

import android.app.Activity;

import android.app.Notification;

import android.app.NotificationManager;

import android.app.PendingIntent;

import android.content.Context;

import android.content.Intent;

import android.os.Bundle;

import android.util.Log;

import https://www.360docs.net/doc/b61355447.html,youtInflater;

import android.view.View;

import android.widget.Button;

import android.widget.TextView;

import android.widget.Toast;

public class Main extends Activity {

/** Called when the activity is first created. */

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(https://www.360docs.net/doc/b61355447.html,yout.main);

// 通过Tost.makeText().show() 来实现提示性的通知效果

// 短时间的提示性通知的Demo

Button btn1 = (Button) this.findViewById(R.id.btn1);

btn1.setText("短时间提示");

btn1.setOnClickListener(new Button.OnClickListener() {

public void onClick(View v) {

Toast.makeText(Main.this, "我是短时间提示", Toast.LENGTH_SHORT).show();

}

});

// 长时间的提示性通知的Demo

Button btn2 = (Button) this.findViewById(R.id.btn2);

btn2.setText("长时间提示");

btn2.setOnClickListener(new Button.OnClickListener() {

public void onClick(View v) {

Toast.makeText(Main.this, "我是长时间提示", Toast.LENGTH_LONG).show();

}

});

// 以一个View 作为提示性通知的Demo

Button btn3 = (Button) this.findViewById(R.id.btn3);

btn3.setText("以一个View 做提示");

btn3.setOnClickListener(new Button.OnClickListener() {

public void onClick(View v) {

View view = inflateView(https://www.360docs.net/doc/b61355447.html,yout.view);

TextView txtMsg = (TextView) view.findViewById(R.id.txtMsg);

txtMsg.setText("提示内容");

Toast toast = new Toast(Main.this);

toast.setView(view);

toast.setDuration(Toast.LENGTH_LONG);

toast.show();

}

});

Button btn4 = (Button) this.findViewById(R.id.btn4);

btn4.setText("发出一个通知(Notification)");

btn4.setOnClickListener(new Button.OnClickListener() {

public void onClick(View v) {

// 实例化通知管理器

NotificationManager nm = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);

// 指定单击通知后所打开的详细的通知页面(单击通知后打开NotificationView)

PendingIntent contentIntent = PendingIntent.getActivity(

Main.this, 0, new Intent(Main.this, NotificationView.class), 0);

// 实例化一个通知,并指定其图标和标题(在提示栏上显示)

Notification n = new Notification(R.drawable.icon01, "我是滚动的通知信息我是滚动的通知信息我是滚动的通知信息", System.currentTimeMillis());

// 设置通知的发送人和通知的详细内容(打开提示栏后在通知列表中显示)

n.setLatestEventInfo(Main.this, "通知发送人", "我是详细的通知信息我是详细的通知信息我是详细的通知信息", contentIntent);

// 100 毫秒延迟后,震动250 毫秒,暂停100 毫秒后,再震动500 毫秒

n.vibrate = new long[] { 100, 250, 100, 500 };

// 发出通知(其中第一个参数为通知标识符)

nm.notify(0, n);

}

});

}

// 将指定的xml 资源转换为一个View

private View inflateView(int resource) {

LayoutInflater vi = (LayoutInflater) getSystemService(https://www.360docs.net/doc/b61355447.html,YOUT_INFLATER_SERVICE);

return vi.inflate(resource, null);

}

// 打开详细通知页后此Activity 会被Pause,从详细通知页返回后此Activity 会被Resume @Override

protected void onPause() {

// TODO Auto-generated method stub

super.onPause();

Log.d("MyDebug", "onPause");

}

@Override

protected void onResume() {

// TODO Auto-generated method stub

super.onResume();

Log.d("MyDebug", "onResume");

}

android studio 控件常用属性

android studio 控件常用属性 下面是RelativeLayout各个属性 1.android:layout_above="@id/xxx" --将控件置于给定ID控件之上 2.android:layout_below="@id/xxx" --将控件置于给定ID控件之下 3. android:layout_toLeftOf="@id/xxx" --将控件的右边缘和给定ID控件的左边缘对齐 4.android:layout_toRightOf="@id/xxx" --将控件的左边缘和给定ID控件的右边缘对齐 5. android:layout_alignLeft="@id/xxx" --将控件的左边缘和给定ID控件的左边缘对齐 6.android:layout_alignTop="@id/xxx" --将控件的上边缘和给定ID控件的上边缘对齐 7.android:layout_alignRight="@id/xxx" --将控件的右边缘和给定ID控件的右边缘对齐 8.android:layout_alignBottom="@id/xxx" --将控件的底边缘和给定ID控件的底边缘对齐 9.android:layout_alignParentLeft="true" --将控件的左边缘和父控件的左边缘对齐 10. android:layout_alignParentTop="true" --将控件的上边缘和父控件的上边缘对齐 11. android:layout_alignParentRight="true" --将控件的右边缘和父控件的右边缘对齐 12.android:layout_alignParentBottom="true" --将控件的底边缘和父控件的底边缘对齐 13.android:layout_centerInParent="true" --将控件置于父控件的中心位置 14.android:layout_centerHorizontal="true" --将控件置于水平方向的中心位置 15.android:layout_centerVertical="true" --将控件置于垂直方向的中心位置 android:layout_width 设置组件的宽度 android:layout_height 设置组件的高度 android:id 给组件定义一个id值,供后期使用 android:background 设置组件的背景颜色或背景图片 android:text 设置组件的显示文字 android:textColor 设置组件的显示文字的颜色 android:layout_below 组件在参考组件的下面 android:alignTop 同指定组件的顶平行

Android常用控件

《Android基础应用》 Android常用控件 ?本章任务 ?使用Android开发使用时间组件 ?使用Android开发使用进度条组件 ?使用Android开发创建底部选项卡 ?本章目标 ?了解Android的组件层次结构 ?掌握常用的日期时间类控件 ?掌握常用的几个容器组件 1.Android组件的层次结构 UI组件都是View的子类,View有很多子类,它们之间存在树状的继承关系View及其子类结构图

TextView及其子类结构图

ViewGroup及其子类结构图 其下的子类一般作为容器或布局来使用 FrameLayout及其子类结构图 其下的子类通常作为容器或布局来使用

2.时间控件 2.1日期时间选择器 DatePicker组件可用于输入日期,TimePicker组件可用来选择时间,只能输入小时和分,默认12小时制 DatePicker ●使用onDateChangedListener监听器来获取用户的日期选择 ●使用init对组件进行初始化 ●使用getYear,getMonth,getDayOfMonth方法获得用户选择的年,月,日 TimePicker ●使用onTimeChangedListener监听器获取用户的时间选择 ●使用setIs24HourView设置是否以24小时制显示 ●使用getCurrentHour获得当前的小时数 ●使用getCurrentMinute获得当前的分钟数 示例

示例的实现结果

2.2时钟组件 AnalogClock组件用来以表盘的方式显示当前时间,该表只有时针和分针,DigitClock组件以数字的方式显示当前时间可以显示时分秒,由于DigitClock继承TextView,可以使用TextView 的属性 示例

Android界面开发之常用系统控件界面大合集

今天我用自己写的一个Demo 和大家详细介绍一个Android开发中遇到的一些常用系统控件的使用技巧。 1.文本框TextView TextView的作用是用来显示一个文本框,下面我用两种方式为大家呈现TextView,第一种是通过xml布局文件

呈现,第二种是通过代码来呈现,由此可见Android 的界面开发真的是非常灵活。 view plaincopy to clipboardprint? 1. public class TextViewActivity extends Activity { 2. @Override 3. protected void onCreate(Bundle savedInstanceState) { 4. setContentView(https://www.360docs.net/doc/b61355447.html,yout.textview);

5. 6. LinearLayout ll = (LinearLayout) findViewById(R.id.textviewll); 7. TextView textView = new TextView(this); 8. //设置显示文字 9. textView.setText("从代码中添加一个TextView"); 10. //设置显示颜色 11. textView.setTextColor(Color.WHITE); 12. //设置显示字体大小 13. textView.setTextSize(18); 14. //设置显示背景颜色 15. textView.setBackgroundColor(Color.BLUE); 16. //设置锚点位置 17. textView.setGravity(Gravity.CENTER_VERTICAL|Gravity.CE NTER_HORIZONTAL); 18. //把这个view加入到布局当中 19. ll.addView(textView); 20. 21. super.onCreate(savedInstanceState); 22. } 23. } 1. 2.

android常用控件大全

android常用控件大全 在Android中使用各种控件(View) DatePicker-日期选择控件 TimePicker-时间选择控件 ToggleButton-双状态按钮控件 EditText-可编辑文本控件 ProgressBar-进度条控件 SeekBar-可拖动的进度条控件 AutoCompleteTextView-支持自动完成功能的可编辑文本控件 MultiAutoCompleteTextView-支持自动完成功能的可编辑文本控件,允许输入多值(多值之间会自动地用指定的分隔符分开) ZoomControls-放大/缩小按钮控件 Include-整合控件 VideoView-视频播放控件 WebView-浏览器控件 RatingBar-评分控件 Tab-选项卡控件 Spinner-下拉框控件 Chronometer-计时器控件 ScrollView-滚动条控件 在Android中使用的Layout FrameLayout:里面只可以有一个控件,并且不能设计这个控件的位置,控件会放到左上角 LinearLayout:里面可以放多个控件,但是一行只能放一个控件

TableLayout:这个要和TableRow配合使用,很像html里面的table AbsoluteLayout:里面可以放多个控件,并且可以自己定义控件的x,y的位置 RelativeLayout:里面可以放多个控件,不过控件的位置都是相对位置 (Android界面布局好像还可以直接引用一些view,如ScrollView等) 常用控件: 1,EditText 主要函数:setText/getText设置/获取文本内容,setHint设置缺省显示内容; 2,RadioGroup,RadioButton RadioButton的isChecked()判断是否被选中 获取选中RadioButon的ID:设置 RadioGroup.setOnCheckedChangeListener方法 publiconCheckedChanged(RadioGroupgroup,intcheckedId)//checkedId 是选中RadioButton的ID 3,CheckBox isChecked()判断是否被选中 setOnCheckedChangeListener方法监视选中状态改变情况 4,Spinner a,显示数据 1),硬编码加载 通过setAdapter方法设置类型为 ArrayAdapter(Contextcontext,inttextViewResId,String[]objects) textViewResourceId:显示内容的ViewID默认设置为 https://www.360docs.net/doc/b61355447.html,yout.simple_spinner_item

Android开发日志—常用控件篇(android简介和容器控件)

Android开发日志—常用控件篇(容器控件) android简介: Android是一种基于Linux的自由及开放源代码的操作系统,主要使用于移动设备,如智能手机和平板电脑,由Google公司和开放手机联盟领导及开发。尚未有统一中文名称,中国大陆地区较多人使用“安卓”或“安致”。Android操作系统最初由Andy Rubin开发,主要支持手机。 Android的系统架构和其操作系统一样,采用了分层的架构。 Android结构 从架构图看,Android分为四个层,从高层到低层分别是应用程序层、应用程序框架层、系统运行库层和Linux内核层。开发人员也可以完全访问核心应用程序所使用的API框架。该应用程序的架构设计简化了组件的重用;任何一个应用程序都可以发布它的功能块并且任何其它的应用程序都可以使用其所发布的功能块(不过得遵循框架的安全性)。同样,该应用程序重用机制也使用户可以方便的替换程序组件。 隐藏在每个应用后面的是一系列的服务和系统, 其中包括; 丰富而又可扩展的视图(Views),可以用来构建应用程序,它包括列表(Lists),网格(Grids),文本框(Text boxes),按钮(Buttons),甚至可嵌入的web 浏览器。 内容提供器(Content Providers)使得应用程序可以访问另一个应用程序的数据(如联系人数据库),或者共享它们自己的数据 资源管理器(Resource Manager)提供非代码资源的访问,如本地字符串,图形,和布局文件(Layout files )。 通知管理器(Notification Manager) 使得应用程序可以在状态栏中显示自定义的提示信息。 活动管理器( Activity Manager) 用来管理应用程序生命周期并提供常用的导航回退功能。 Android开发四大组件分别是:活动(Activity):用于表现功能。服务(Service):后台运行服务,不提供界面呈现。广播接收器(BroadcastReceiver):用于接收广播。内容提供商(Content Provider):支持在多个应用中存储和读取数据,相当于数据库。 活动(当前界面视图):

实验二 android基本控件实验

实验二 android基本控件实验 【目的】 熟悉Android常用控件的基本操作,掌握它们的基本使用方法。了解控件之间的构成关系,熟悉适配器的使用原理。 【要求】 1、了解控件的继承关系; 2、掌握适配器的使用; 3、掌握信息提示的实现机制; 4、实现基本界面。 【原理】 1.控件类之间的关系 android.view.View类(视图类)呈现了最基本的UI构造块。View类是Android中的一个超类,几乎包含了所有的屏幕类型,主要负责绘制和事件处理。 Android中控件类的扩展结构如图所示。 View有众多的扩展者,它们大部分是在android.widget包中,这些继承者实际上就是Android 系统中的“控件”。View实际上就是各个控件的基类,创建交互式的图形用户界面的基础。View的直接继承者包括文本视图(TextView)、图像视图(ImageView)、进度条(ProgressBar)等。它们各自又有众多的继承者。每个控件除了继承父类功能之外,一般还具有自己的公有 方法、保护方法、XML属性等。 在Android中使用各种控件的一般情况是在布局文件中可以实现UI的外观,然后在Java文件中实现对各种控件的控制动作。控件类的名称也是它们在布局文件XML中使用的标签名称。

2.控件通用行为和属性 View是Android中所有控件类的基类,因此View中一些内容是所有控件类都具有的通用行为和属性。 提示:由于Java语言不支持多重继承,因此Android控件不可能以基本功能的“排列组合”的方式实现。在这种情况下,为了实现功能的复用,基类的功能往往做得较强,作为控件的祖先类,View所实现的功能也是最多的。 控件类经常在布局文件中使用,因此其可以使用XML属性(XMLAttributes),和Java代码经常具有对应关系。 View作为各种控件的基类,其XML属性所有控件通用,XML属性及其对应的方法如表1所示。 表1 View中的XML属性及其对应的方法 其中,android:id表示控件的标识,通常需要在布局文件中指定这个属性。View中与控件标识相关的几个方法如下所示: public int getId() // 获得控件的id(int类型)

Android基础-控件的使用

创建控件并添加监听器的过程: 1.xml中定义控件(

相关文档
最新文档