1、Spinner

提供一个快速的方法来从一组值中选择一个值。在默认状态Spinner显示当前选择的值。触摸Spinner与所有其他可用值显示一个下拉菜单,可以选择一个新的值。

  1. /**
  2. * 写死内容:
  3. * 只需在value内创建一个array,写上数据,在xml里引用
  4. */
  5.  
  6. <array name="city">
  7. <item>北京</item>
  8. <item>上海</item>
  9. <item>广州</item>
  10. <item>天津</item>
  11. <item>大连</item>
  12. </array>
  13.  
  14. <Spinner
  15. android:id="@+id/sp_Ct"
  16. android:layout_width="match_parent"
  17. android:layout_height="wrap_content"
  18. android:entries="@array/city" />

动态设置数据:

  1. sp_name = (Spinner) findViewById(R.id.sp_name);
  2. //通过适配器进行数据得绑定
  3. //方式一:
  4. //创建一个数组适配器(参数:上下文、下拉列表里的布局、显示下拉列表选项的组件ID、数据)
  5. ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
  6. android.R.layout.simple_list_item_1,android.R.id.text1,name);
  7. //方式二:
  8. ArrayAdapter adapter2 = ArrayAdapter.createFromResource(this,
  9. R.array.city,android.R.layout.simple_dropdown_item_1line);
  10. sp_name.setAdapter(adapter);

2、AutoCompleteTextView

  1. <AutoCompleteTextView
  2. android:id="@+id/auto"
  3. android:layout_width="match_parent"
  4. android:layout_height="wrap_content"
  5. android:completionThreshold="1"/>
  1. auto = (AutoCompleteTextView) findViewById(R.id.auto);
  2. /**
  3. * AutoCompleteTextView:用法与Spinner类似
    * 为了实现自动完成,必须提供建议的文本
  4. * android:completionThreshold这个属性控制匹配几个字符显示列表
  5. */
  6. ArrayAdapter adapter = new ArrayAdapter(this,android.R.layout.simple_list_item_1,android.R.id.text1,name);
  7. auto.setAdapter(adapter);

3、ProgressBar

在默写操作进度中的可视指示器,为用户呈现操作的进度,还有一个次要的进度条,用来显示进度,如在流媒体播放的缓冲区的进度

一个进度条也可不显示进度,在不确定模式下,进度条显示循环动画。这种模式常用于应用程序使用任务的长度是未知的进度条也就是一个表示运转的过程,例如发送短信,连接网络等,表示一个过程正在执行中。

两种展示方式:表盘形式(普通、大、小)和进度条填充形式,在layout定义时,需要通过设置style属性类设置展示方式

  1. <ProgressBar
  2. android:id="@+id/progress"
  3. android:layout_width="wrap_content"
  4. android:layout_height="wrap_content"/>
  5.  
  6. <ProgressBar
  7. android:id="@+id/progressBar"
  8. android:progress="50"
  9. style="?android:attr/progressBarStyleHorizontal"
  10. android:layout_width="match_parent"
  11. android:layout_height="wrap_content" />
  1. /*
  2. * xml重要属性:
  3. * android:max 进度条长度最大值
  4. * android:progress 进度条当前进度值
  5. * android:secondaryProgress 第二进度条进度值
  6. * android:progressBarStyle 默认进度条样式
  7. * android:progressBarStyleHorizontal 水平样式
  8. */
  1. /*
  2. * 重要方法:
  3. * getMax() 返回这个进度条的范围上限
  4. * getProgress() 返回当前进度值
  5. * getSecondaryProgress() 返回次要当前进度之
  6. * incrementProgressBy(int diff) 指定增加的进步--即步长
  7. * isIndeterminate() 指示进度条是否在不确定模式下
  8. * setVisibility(int v) 设置进度条是否可视
  9. */

创建对话框进度条

  1. //创建对话框进度条
  2. ProgressDialog pd = new ProgressDialog(this);
  3. pd.setMax(100);
  4. // pd.setIndeterminate(false);
  5. pd.setProgress(30);
  6. pd.setSecondaryProgress(70);
  7. //设置是否可以取消
  8. pd.setCancelable(true);
  9. pd.setTitle("下载中");
  10. pd.setMessage("正在下载中。。");
  11. pd.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
  12. pd.show();

设置标题进度条(该方法必须在setContentView方法之前)

  1. requestWindowFeature(Window.FEATURE_INDETERMINATE_PROGRESS);
  1. //显示标题栏进度条
  2. setProgressBarIndeterminate(true);

4、Dialog

  1. /**
  2. * 对话框指的是在当前Activity之上的一个小窗口.
  3. * 对话框一般用于提示信息和与当前应用程序直接相关的小功能
  4. * 处于对话框下面的Activity失去焦点 对话框接受所有用户的交互
  5. * @author Administrator
  6. *
  7. */
  1. //创建一个提示对话框的构造者
  2. AlertDialog.Builder dialog = new AlertDialog.Builder(this);
  3. dialog.setTitle("温馨提示");
  4. dialog.setMessage("1111");
  5. dialog.setIcon(R.mipmap.ic_launcher);
  6. dialog.setPositiveButton("确定", new DialogInterface.OnClickListener() {
  7. @Override
  8. public void onClick(DialogInterface dialogInterface, int i) {
  9. //选择之后的操作
  10. }
  11. })
  12. .setNegativeButton("取消", new DialogInterface.OnClickListener() {
  13. @Override
  14. public void onClick(DialogInterface dialogInterface, int i) {
  15. //选择之后的操作
  16. }
  17. })
  18. .show();
  1. AlertDialog.Builder alertDialog2 = new AlertDialog.Builder(MainActivity.this);
  2. alertDialog2.setTitle("提示");
  3. alertDialog2.setIcon(R.drawable.ic_launcher);
  4. /**
  5. * 1.按钮中显示的文本内容 2点击按钮时触发的事件
  6. * 在Android2.3.1平台下三个按钮的位置是固定的 分别在最左侧 右侧 居中
  7. * 在4.0平台下 setPositiveButton和setNegativeButton位置恰恰相反 分别置于最右侧和最左侧
  8. */
  9. alertDialog2.setMessage("亲,确定要退出吗?");
  10. alertDialog2.setPositiveButton("确定", new OnClickListener() {
  11.  
  12. @Override
  13. public void onClick(DialogInterface dialog, int which) {
  14. Toast.makeText(MainActivity.this, ""+which, Toast.LENGTH_SHORT).show();
  15.  
  16. }
  17. });
  18. alertDialog2.setNegativeButton("取消", new OnClickListener() {
  19.  
  20. @Override
  21. public void onClick(DialogInterface dialog, int which) {
  22. Toast.makeText(MainActivity.this, ""+which, Toast.LENGTH_SHORT).show();
  23.  
  24. }
  25. });
  26.  
  27. alertDialog2.setNeutralButton("再看看", new OnClickListener() {
  28.  
  29. @Override
  30. public void onClick(DialogInterface dialog, int which) {
  31. Toast.makeText(MainActivity.this, ""+which, Toast.LENGTH_SHORT).show();
  32.  
  33. }
  34. });
  35. alertDialog2.create();
  36. alertDialog2.show();
  37. break;
  1. //显示普通item列表的Dialog
  2. AlertDialog.Builder alertDialg3 = new AlertDialog.Builder(MainActivity.this);
  3. alertDialg3.setTitle("提示");
  4. alertDialg3.setIcon(R.drawable.a);
  5. final String[] colors = getResources().getStringArray(R.array.arrColors);
  6. alertDialg3.setItems(colors, new DialogInterface.OnClickListener() {
  7.  
  8. @Override
  9. public void onClick(DialogInterface dialog, int which) {// int which 被点击item的下标
  10. Toast.makeText(MainActivity.this, colors[which],Toast.LENGTH_SHORT).show();
  11.  
  12. }
  13. });
  14.  
  15. alertDialg3.create();
  16. alertDialg3.show();
  1. //显示Adapter适配器列表的Dialog
  2. list.clear();
  3. AlertDialog.Builder dialog4 = new AlertDialog.Builder(MainActivity.this);
  4. dialog4.setTitle("提示");
  5. dialog4.setIcon(R.drawable.a);
  6. int[] images = {R.drawable.pic1,R.drawable.pic2,R.drawable.pic3,R.drawable.pic4,R.drawable.pic5};
  7. for (int i = 0; i < images.length; i++) {
  8. Map<String, Object> map = new HashMap<String, Object>();
  9. map.put("Image", images[i]);
  10. map.put("Content", "item"+(i+1));
  11.  
  12. list.add(map);
  13. }
  14.  
  15. SimpleAdapter adapter = new SimpleAdapter(MainActivity.this, list, R.layout.item_dialog, new String[]{"Image","Content"}, new int[]{R.id.iamgeView,R.id.textView});
  16. dialog4.setAdapter(adapter, new DialogInterface.OnClickListener() {
  17.  
  18. @Override
  19. public void onClick(DialogInterface dialog, int which) {
  20. Toast.makeText(MainActivity.this, (String)list.get(which).get("Content"), Toast.LENGTH_SHORT).show();
  21.  
  22. }
  23. });
  24. dialog4.create();
  25. dialog4.show();
  1. //显示多选列表的Dialog
  2. AlertDialog.Builder dialog6 = new AlertDialog.Builder(MainActivity.this);
  3. dialog6.setTitle("选择颜色");
  4. dialog6.setIcon(R.drawable.a);
  5. dialog6.setMultiChoiceItems(R.array.arrColors, new boolean[]{true,true,false}, new OnMultiChoiceClickListener() {
  6.  
  7. @Override
  8. public void onClick(DialogInterface dialog, int which, boolean isChecked) {
  9.  
  10. }
  11. });
  12. dialog6.setPositiveButton("确定", new OnClickListener() {
  13.  
  14. @Override
  15. public void onClick(DialogInterface dialog, int which) {
  16. Toast.makeText(MainActivity.this, "选择完成", Toast.LENGTH_SHORT).show();
  17.  
  18. }
  19. });
  20.  
  21. dialog6.create().show();
  1. //显示日期选择的Dialog
  2. /**
  3. * 弹出日期选择对话框
  4. * 1.上下文对象
  5. * 2.设置日期时回调的方法
  6. * 3.默认的年份
  7. * 4.默认的月份
  8. * 5.默认的日期
  9. */
  10. DatePickerDialog datePickerDialog = new DatePickerDialog(MainActivity.this, new DatePickerDialog.OnDateSetListener() {
  11.  
  12. @Override
  13. public void onDateSet(DatePicker view, int year, int monthOfYear,
  14. int dayOfMonth) {
  15. Toast.makeText(MainActivity.this, year+"年"+(monthOfYear+1)+"月"+dayOfMonth+"日", Toast.LENGTH_SHORT).show();
  16.  
  17. }
  18. }, 2016, 5, 9);
  19.  
  20. datePickerDialog.show();
  1. // 显示日期选择的Dialog
  2. /**
  3. * 3.默认的小时
  4. * 4.默认的分钟
  5. * 5.是否已24小时计时法计时 true代表24h false代表12h
  6. */
  7. TimePickerDialog timePickerDialog = new TimePickerDialog(MainActivity.this, new TimePickerDialog.OnTimeSetListener() {
  8.  
  9. @Override
  10. public void onTimeSet(TimePicker view, int hourOfDay, int minute) {
  11. Toast.makeText(MainActivity.this, hourOfDay+"时"+minute+"分", Toast.LENGTH_SHORT).show();
  12.  
  13. }
  14. }, 14, 54, true);
  15. timePickerDialog.show();
  1. AlertDialog.Builder builder = new AlertDialog.Builder(MainDialog.this);
  2. LayoutInflater factory = LayoutInflater.from(this);
  3. final View textEntryView = factory.inflate(R.layout.test, null);
  4. builder.setIcon(R.drawable.icon);
  5. builder.setTitle("自定义输入框");
  6. builder.setView(textEntryView);
  7. builder.setPositiveButton("确定", new DialogInterface.OnClickListener() {
  8. public void onClick(DialogInterface dialog, int whichButton) {
  9.  
  10. EditText userName = (EditText) textEntryView.findViewById(R.id.etUserName);
  11. EditText password = (EditText) textEntryView.findViewById(R.id.etPassWord);
  12. showDialog("姓名 :" + userName.getText().toString() + "密码:" + password.getText().toString() );
  13. }
  14. });
  15. builder.setNegativeButton("取消", new DialogInterface.OnClickListener() {
  16. public void onClick(DialogInterface dialog, int whichButton) {
  17.  
  18. }
  19. });
  20. builder.create().show();

消除对话框

dismissDialog(int id)会保留这个对象

removeDialog(int id)会删除这个对象和清除状态

另外如果你在弹出窗口的时候希望返回键失效的话,则可以使用Builder.setCancelable(false),那么返回键就会不起作用了

cancel和dismiss方法的本质是一样的,都是从屏幕中删除Dialog,唯一的区别是调用cancel会调用DialogInterface.OnCancelListener.

Android 基础UI组件(二)的更多相关文章

  1. Android 基础UI组件(一)

    1.Toast //显示文字 Toast.makeText(this,"Toast显示文本",Toast.LENGTH_SHORT).show(); //显示图片 Toast to ...

  2. Android常见UI组件之ListView(二)——定制ListView

    Android常见UI组件之ListView(二)--定制ListView 这一篇接上篇.展示ListView中选择多个项及实现筛选功能~ 1.在位于res/values目录下的strings.xml ...

  3. Android基础测试题(二)

    今天给大家带来的是Android基础测试题(二) 题目要求: 定义一个5位长度的整型数组并初始化,然后构建方法根据用户传入的数字判断是否存在数组中,如果存在,返回所在位置,如果不存在,返回-1 首先第 ...

  4. Android之UI编程(二):表格布局

    表格布局(TableLayout)继承了LinearLayout,它的本质依然是线性布局管理器,表TableLayout采用行.列的形式来管理UI组件,它并不需要明确地声明暴行多少行.多少列,而是通过 ...

  5. Android 高级UI组件(二)

    1.ExpandableListView 显示垂直滚动两级列表的条目,只允许两个层次 整体思路: 要给ExpandableListView设置适配器,那么必须先设置数据源. 数据源,就是此处的适配器类 ...

  6. Android用户界面 UI组件--TextView及其子类(二) Button,selector选择器,sharp属性

    1.XML文件中的OnClick 属性可以指定在Activity中处理点击事件的方法,Activity中必须定义该属性指定的值作为方法的名字且有一个View类型的参数,表示此物件被点击. 2.使用se ...

  7. Android用户界面 UI组件--AdapterView及其子类(二) AdapterViewAnimator及其子类

    AdapterViewAnimator:当在视图间切换时会显示动画. android:animateFirstView 定义ViewAnimation首次显示时是否对当前视图应用动画. android ...

  8. Android 高级UI组件(三)

    一.popupWindow 1.AlertDialog和PopupWindow最关键的区别是AlertDialog不能指定显示位置,只能默认显示在屏幕最中间(当然也可以通过设置WindowManage ...

  9. Android用户界面 UI组件--AdapterView及其子类(一) ListView及各种Adapter详解

    ListView就是列表组件,一般通过继承ListActivity使用系统提供的ListView. 所有的AdapterView组件都需要有一个对应的Adapter作为适配器来显示列表中元素的布局方式 ...

随机推荐

  1. Linux cat文件正常,vim文件乱码

    cat: vim: 1.临时解决 vim 文件后,命令模式下执行: :set encoding=utf-8 2.永久解决 vi    配置文件路径:/etc/virc vim 配置文件路径:/etc/ ...

  2. Spark的安装及其配置

    1.Spark下载 https://archive.apache.org/dist/spark/ 2.上传解压,配置环境变量 配置bin目录 解压:tar -zxvf spark-2.4.5-bin- ...

  3. fabric运行记录

    创建第一个fabric网络 Generate Network Artifacts cd first-network 先关闭服务 ./byfn.sh -m down 然后创建 ./byfn.sh -m ...

  4. feign微服务调用携带浏览器信息(header、cookie)

    import feign.RequestInterceptor; import feign.RequestTemplate; import org.apache.commons.collections ...

  5. c++学习笔记3(内联函数)

    函数调用是有开销的,调用时需将参数放入栈中,返回地址也要放入,返回时还需从栈中取出,跳转返回地址去执行,需几条语句的时间,如果本身程序代码短,则会显得十分浪费,所以引入了内联函数的机制 写法:在函数前 ...

  6. IDEA 运行maven工程报错:No goals have been specified for this build.....解决办法

    出现这种错误可以在pom.xml里配置, 找到<build>标签在下面<plugins>标签上面加上<defaultGoal>compile</default ...

  7. Go语言核心36讲(Go语言实战与应用六)--学习笔记

    28 | 条件变量sync.Cond (下) 问题 1:条件变量的Wait方法做了什么? 在了解了条件变量的使用方式之后,你可能会有这么几个疑问. 1.为什么先要锁定条件变量基于的互斥锁,才能调用它的 ...

  8. 『学了就忘』Linux用户管理 — 52、用户组管理相关命令

    目录 1.添加用户组 2.删除用户组 3.把用户添加进组或从组中删除 4.有效组(了解) 1.添加用户组 添加用户组的命令是groupadd. 命令格式如下: [root@localhost ~]# ...

  9. 基于Docker搭建Maven私服Nexus,Nexus详解

    备注:首先在linux环境安装Java环境和Docker,私服需要的服务器性能和硬盘存储要高一点,内存不足可能到时启动失败,这里以4核8GLinux服务器做演示 一:基于Docker安装nexus3 ...

  10. [SQL Server]一列多行转换为字符串

    在 SQL Server 中,如何将多行数据变成一个字符串保存. skill 投石 挖矿 刮痧 上面三行数据想要得到结果为:投石,挖矿,刮痧 有两种方式: 拼接字符串. 使用 for XML 首先创建 ...