本文实例为大家分享了Android用户注册界面的设计,供大家参考,具体内容如下

I. 实例目标

设计一个用户注册界面,在其中要使用到一些基础控件,如 文本框、编辑框、按钮、复选框等控件

II. 技术分析

首先在布局文件中使用控件的标记来配置所需要的各个控件,然后在 主Activity中获取到该控件,给其添加监听器来监听其操作,最后在控制台输出所操作的内容。

III. 实现步骤

在Eclipse中创建 Android项目,名称为 TestUserRegister 。设计一个用户注册界面,在其中要使用到 文本框、编辑框、按钮、单选按钮、复选框、列表选择框、列表视图、图片视图 等控件。

(1)在项目 res 目录下的 drawable_ldpi 文件夹中,放入两张名称分别为 logo5.jpg 和 background3.jpg 的图片,用于作为显示的 logo 图片和背景图片。

(2)在项目的res/values 目录中新建数组资源文件 arrays.xml ,在该文件中添加两个字符串数组,名称分别为 type 和 care,代码如下

学生

老师

白领

工程师

其他

1.保护用户个人信息

2.用户在本网站上不得发布违法信息

3.保护个人账号和密码安全

4.本网站所有权和解释权归本网站拥有

(3)在项目的res/layout 目录下修改 activity _main.xml 文件,首先将界面整体布局改为表格布局,并设置背景,之后添加一个图像视图作为 logo 图像显示,代码如下:

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="vertical"

android:background="@drawable/background3">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:src="@drawable/logo5"

android:id="@+id/imageView02"

android:layout_margin="5dp"

android:adjustViewBounds="true"

android:maxWidth="75dp"

android:maxHeight="60dp"/>

上述代码中,android:adjustViewBounds 属性用于设置 ImageView 是否调整自己的边界来保持所需显示图片的长度变化,为 true 时表示调整自己的边界来保持所需显示图片的长度变化; android:maxWidth 和 android:maxHeight 分别表示 ImageView 的最大宽度和最大高度。

(4)添加三个 TableRow 表格行,并在其中添加 3 个 文本框(TextView) 和 编辑框控件(EditText) ,用来显示和填写 用户名、密码 和 确认密码。具体代码如下:

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="用户名:"

android:layout_marginLeft="5dp"/>

android:layout_width="250dp"

android:layout_height="wrap_content"

android:hint="请输入用户名"

android:id="@+id/editText01"

android:singleLine="true"

android:inputType="textPersonName"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="密码:"

android:layout_marginLeft="5dp"/>

android:layout_width="250dp"

android:layout_height="wrap_content"

android:hint="请输入密码"

android:id="@+id/editText02"

android:singleLine="true"

android:inputType="textPassword"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="确认密码:"

android:layout_marginLeft="5dp"/>

android:layout_width="250dp"

android:layout_height="wrap_content"

android:hint="请输入密码"

android:id="@+id/editText03"

android:singleLine="true"

android:inputType="textPassword"/>

在上述代码中,EditText 控件中的 android:singleLine = “true” 表示单行输入文本, android:inputType=”textPersonName” 表示输入类型为用户名。 android:inputType=”textPassword” 表示输入的内容为密码,将用 “ . ” 代替输入的内容,避免密码泄露。

(5)添加一个线性布局,在其中添加一个文本框控件(TextView)和一个单选按钮组(RadioGroup) , 其中在单选按钮组中添加两个单选按钮控件,其中线性布局的 android:orientation 属性设置为 “horizontal”,具体代码如下

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:orientation="horizontal"

android:layout_marginTop="10dp">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_marginLeft="5dp"

android:layout_gravity="center_vertical"

android:text="请选择您的性别" />

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:orientation="horizontal"

android:id="@+id/sex">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="男"

android:id="@+id/radioButton1"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="女"

android:id="@+id/radioButton2"/>

(6)添加一个线性布局,在其中添加一个文本框(TextView) 和 一个列表选择框控件(Spinner),线性布局的 android:orientation 属性设置为 “horizontal” ,其中列表选择框的 android:entries 属性为 “@array/type”,代码如下

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:orientation="horizontal"

android:layout_marginTop="10dp">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="请选择您的身份"

android:layout_marginLeft="5dp"/>

android:entries="@array/type"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:id="@+id/spinner"/>

(7)添加一个文本框控件(TextView) 、列表视图控件(ListView) 、 复选框控件(CheckBox) 和 一个普通按钮控件(Button) ,代码如下

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="服务条款"

android:textSize="27sp"

android:gravity="center_horizontal"/>

android:id="@+id/listView"

android:entries="@array/care"

android:layout_width="wrap_content"

android:layout_height="wrap_content"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:id="@+id/checkBox"

android:text="我同意上述条款"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:id="@+id/reg"

android:text="注册"

android:gravity="center_horizontal"

android:visibility="invisible"/>

上述代码中,TextView控件的 android:gravity=”center_horizontal” 表示文本框控件在屏幕中水平放置;普通按钮中的 android:visibility 属性表示该控件是否可见,在这里设置的是不可见。

(8)activity_main.xml文件完整代码

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:orientation="vertical"

android:background="@drawable/background3">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:src="@drawable/logo5"

android:id="@+id/imageView02"

android:layout_margin="5dp"

android:adjustViewBounds="true"

android:maxWidth="75dp"

android:maxHeight="60dp"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="用户名:"

android:layout_marginLeft="5dp"/>

android:layout_width="250dp"

android:layout_height="wrap_content"

android:hint="请输入用户名"

android:id="@+id/editText01"

android:singleLine="true"

android:inputType="textPersonName"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="密码:"

android:layout_marginLeft="5dp"/>

android:layout_width="250dp"

android:layout_height="wrap_content"

android:hint="请输入密码"

android:id="@+id/editText02"

android:singleLine="true"

android:inputType="textPassword"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="确认密码:"

android:layout_marginLeft="5dp"/>

android:layout_width="250dp"

android:layout_height="wrap_content"

android:hint="请输入密码"

android:id="@+id/editText03"

android:singleLine="true"

android:inputType="textPassword"/>

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:orientation="horizontal"

android:layout_marginTop="10dp">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_marginLeft="5dp"

android:layout_gravity="center_vertical"

android:text="请选择您的性别" />

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:orientation="horizontal"

android:id="@+id/sex">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="男"

android:id="@+id/radioButton1"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="女"

android:id="@+id/radioButton2"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:orientation="horizontal"

android:layout_marginTop="10dp">

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="请选择您的身份"

android:layout_marginLeft="5dp"/>

android:entries="@array/type"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:id="@+id/spinner"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:text="服务条款"

android:textSize="27sp"

android:gravity="center_horizontal"/>

android:id="@+id/listView"

android:entries="@array/care"

android:layout_width="wrap_content"

android:layout_height="wrap_content"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:id="@+id/checkBox"

android:text="我同意上述条款"/>

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:id="@+id/reg"

android:text="注册"

android:gravity="center_horizontal"

android:visibility="invisible"/>

(9)在MainActivity.java 文件中,获取到复选框控件、普通按钮控件、单选按钮组控件和列表选择框控件,并为它们添加监听器,代码如下

import android.os.Bundle;

import android.util.Log;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.AdapterView;

import android.widget.AdapterView.OnItemSelectedListener;

import android.widget.ArrayAdapter;

import android.widget.Button;

import android.widget.CheckBox;

import android.widget.CompoundButton;

import android.widget.CompoundButton.OnCheckedChangeListener;

import android.widget.EditText;

import android.widget.ListView;

import android.widget.RadioButton;

import android.widget.RadioGroup;

import android.widget.Spinner;

import android.app.Activity;

public class MainActivity extends Activity {

private Button reg = null;

private int location = -1;

private Spinner spinner = null;

private CheckBox checkBox = null;

private EditText editText01 = null ;

private EditText editText02 = null;

private EditText editText03 = null;

private RadioButton radio =null ;

private ListView listView = null;

private RadioGroup sex;

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//找到关心的控件

reg = (Button) findViewById(R.id.reg);

spinner = (Spinner) findViewById(R.id.spinner);

checkBox = (CheckBox) findViewById(R.id.checkBox);

editText01 = (EditText) findViewById(R.id.editText01);

editText02 = (EditText) findViewById(R.id.editText02);

editText03 = (EditText) findViewById(R.id.editText03);

listView = (ListView) findViewById(R.id.listView);

sex = (RadioGroup) findViewById(R.id.sex);

ArrayAdapter adapter = ArrayAdapter.createFromResource(this, R.array.care, android.R.layout.simple_spinner_item);

listView.setAdapter(adapter);//适配器与列表视图关联

//为复选框控件添加监听器

checkBox.setOnCheckedChangeListener(new checkBoxOnCheckedChangeListener ());

sex.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {

public void onCheckedChanged(RadioGroup group, int checkedId) {

radio = (RadioButton) findViewById(checkedId);

}

});

spinner.setOnItemSelectedListener(new spinnerOnItemSelectedListener());

reg.setOnClickListener(new regOnClickListener());

}

class regOnClickListener implements OnClickListener{

public void onClick(View v) {

Log.i("您输入的用户名为:", editText01.getText().toString());

Log.i("您输入的密码为:", editText02.getText().toString());

Log.i("您输入的确认密码为:", editText03.getText().toString());

if (radio != null) {

Log.i("您选择的性别为:", radio.getText().toString());

}else {

Log.i("您选择的性别为:", "无");

}

Log.i("您选择的身份为:", spinner.getItemAtPosition(location).toString());

}

}

class spinnerOnItemSelectedListener implements OnItemSelectedListener{

public void onItemSelected(AdapterView> parent, View view,

int position, long id) {

//获取下拉列表框控件选中的位置

location = position;

}

public void onNothingSelected(AdapterView> parent) {

}

}

//复选框控件监听器

class checkBoxOnCheckedChangeListener implements OnCheckedChangeListener{

public void onCheckedChanged(CompoundButton buttonView,

boolean isChecked) {

if (isChecked) {

reg.setVisibility(View.VISIBLE);

}else {

reg.setVisibility(View.INVISIBLE);

}

}

}

}

在上述代码中,通过下拉列表框控件的监听器来获取所选内容的位置,然后赋值给 location 变量;在复选框控件的监听器中,如果该复选框被选中,则注册按钮显示可见,否则不可见。

IV. 运行

未填写信息前

填写信息并点击注册后

控制台输出信息

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

android注册界面高级,Android用户注册界面简单设计相关推荐

  1. android注册文件打开,Android项目实战系列—基于博学谷(三)注册与登录模块

    由于这个模块内容较多,篇幅较长,请耐心阅读. 注册与登录模块分为三个部分 [x] [欢迎界面]() [x] [注册界面]() [x] [登录界面]() 一.欢迎界面 1.创建工程,命名为BoXueGu ...

  2. android网游开发之socket的简单设计和实现

    对于普通应用的网络模块一般使用http文本协议,在android开发中使用http协议比较简单,sdk已经做了很好的封装了.而在游戏开发中,可以结合使用http和socket,当然了http协议底层也 ...

  3. android 属性动画高级,Android高级UI开发(二十五)属性动画实战案例之流浪大师与乔帮主...

    在上一篇文章里我们介绍了属性动画的基础知识,今天我们综合运用属性动画的知识来完成一个动画案例.首先,看一下这个动画效果: 1.  分析这个动画案例 第一个动画(浏览大师的动画)是:当点击顶部" ...

  4. android中注册用户界面,Android用户注册界面

    搜索热词 先给大家展示下界面效果图,感觉满意,请参考实现代码. Main.xml源码 android:layout_width="match_parent" android:lay ...

  5. Android 注册登入界面完美设计

    今天没啥事情做,就想着复习复习android,不然快把android给忘记了,于是乎就干起来.边学边复习边做做,正好我手上有一些自己爬虫的数据,想着没事干的时候可以做做一个小商城,当作练练手. 开发环 ...

  6. Android常见的高级组件搭建移动应用界面

    Android常见的高级组件结合可以搭建移动应用常见的界面结构,如下图所示: 上述的界面可以发现有侧滑菜单,界面的主内容区顶部可以显示Home键.应用标题以及菜单.在底部有导航栏方便导航.通过侧滑菜单 ...

  7. Android开发学习之路--UI之简单聊天界面

    学了很多的ui的知识,这里就来实现个聊天的界面,首先来实现个layout的xml,代码如下: <?xml version="1.0" encoding="utf-8 ...

  8. Java仿小米计算器源码_xiaomi-Calculator 仿照小米的计算器功能,作为一个Android的初学者可以参考,界面简单大方。 259万源代码下载- www.pudn.com...

    文件名称: xiaomi-Calculator下载  收藏√  [ 5  4  3  2  1 ] 开发工具: Java 文件大小: 795 KB 上传时间: 2016-06-13 下载次数: 0 提 ...

  9. Android布局之线性布局LinearLayout(二) ----简单模仿ios端小米计算器主界面UI

    Android布局之线性布局LinearLayout(二) ----简单模仿ios端小米计算器主界面UI   今天老师的要求是让用LinearLayout布局做自己手机自带的计算器的UI设计,因为io ...

最新文章

  1. 职场,18个细节决定成败[转载]
  2. 成功解决Please use the NLTK Downloader to obtain the resource:
  3. 游戏开发中 UI 是由谁来完成的?
  4. java阻塞超时_JAVA防线程阻塞(超时控制)
  5. Vue004_条件渲染
  6. MYSQL--事务处理
  7. Java中的变量数据类型补充
  8. 【Trie】【HDU1247】【Hat’s Wordsfd2】
  9. 实时数据处理环境搭建flume+kafka+storm:4.storm安装配置
  10. keil5兼容keil4操作
  11. Obsidian关系图谱如何让节点可以手动拖动
  12. fnl数据下载之requests,urllib等安装
  13. 静态成员变量与静态成员函数的声明与定义
  14. 全国社会媒体处理大会即将召开,一文详解四天议程精华
  15. 源代码防泄密加密介绍
  16. 路由宝刷华硕rt-n14u_如何在2019年取消硬砖路由器的砖块化(以华硕RT-N16为例)
  17. [原]简易Windows密码查看器
  18. 文件操作opendir()/readdir()/closedir()/stat()
  19. 戴尔t410服务器cpu型号,戴尔PowerEdge T410 最新第11代服务器
  20. 【对数】YY(jzoj 1438)

热门文章

  1. the code place where the binding is converted to final value displayed in u
  2. 在SAP云平台ABAP编程环境上编写第一段ABAP程序
  3. how to render AET extension field as code list
  4. SAP ABAP实用技巧介绍系列之 在xslt里call ABAP method
  5. SAP CRM WebClient UI CL_BSP_MESSAGES
  6. 如何设置wiki权限
  7. SAP专家通过调试的方式解决过的SAP UI5问题列表
  8. SAP CRM产品主数据工作流相关调试
  9. 一个用JavaScript生成思维导图(mindmap)的github repo
  10. via logo html,HTML5 Audio Description (via screenreader)