android中的常见对话框
在android中对话框是一种常见的操作,常见的对话框有下面几种:
以下是xml布局文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" > <Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="click1"
android:text="显示通知对话框" /> <Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="click2"
android:text="显示单选对话框" /> <Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="click3"
android:text="显示多选对话框" /> <Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="click4"
android:text="显示运行进度对话框" /> <Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:onClick="click5"
android:text="显示运行进度条对话框" /> </LinearLayout>
实现代码:
显示对话框
public void click1(View view) {
AlertDialog.Builder builder = new Builder(this);
builder.setTitle("显示对话框");
builder.setIcon(R.drawable.ic_launcher);
builder.setMessage("你确定吗?");
builder.setPositiveButton("确定", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
Toast.makeText(MainActivity.this, "确定被点击了", Toast.LENGTH_LONG)
.show();
}
});
builder.setNegativeButton("取消", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
}
});
builder.show();
}
显示效果:
显示单选对话框
public void click2(View view) {
AlertDialog.Builder builder = new Builder(this);
builder.setTitle("单选对话框");
final String[] items = new String[] { "条目1", "条目2", "条目3" };
builder.setSingleChoiceItems(items, 1, new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
Toast.makeText(MainActivity.this, items[which] + "被选中了",
Toast.LENGTH_LONG).show();
dialog.dismiss();
}
});
builder.show();
}
显示效果:
显示多选对话框
public void click3(View view) {
AlertDialog.Builder builder = new Builder(this);
builder.setTitle("显示多选对话框");
final String[] items = new String[] { "条目1", "条目2", "条目3", "条目4" };
builder.setMultiChoiceItems(items, new boolean[] { true, false, false,
true }, new OnMultiChoiceClickListener() {
@Override
public void onClick(DialogInterface dialog, int which,
boolean isChecked) {
// TODO Auto-generated method stub
Toast.makeText(MainActivity.this, items[which] + isChecked,
Toast.LENGTH_LONG).show();
}
});
builder.setNegativeButton("取消", new OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
// TODO Auto-generated method stub
}
});
builder.show();
}
显示效果:
显示运行进度对话框
public void click4(View view) {
ProgressDialog dialog = new ProgressDialog(this);
dialog.setTitle("提醒");
dialog.setMessage("正在上传中");
dialog.show();
}
显示效果:
显示运行进度条对话框
public void click5(View view) {
final ProgressDialog dialog = new ProgressDialog(this);
dialog.setTitle("载入进度");
dialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);
dialog.setMax(100);
dialog.show();
new Thread() {
public void run() {
for (int i = 0; i < 100; i++) {
dialog.setProgress(i);
try {
Thread.sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
dialog.dismiss();
};
}.start();
}
显示效果:
最后补充一点假设是自己定义dialog的话假设你用的是
dialog.setContentView(R.layout.dialog_wait);那么就没有什么问题。
假设你是通过inflater来创建一个view
dialog.setContentView(view)
这样的方式来设置view的话。会遇到设置的dialog大小无效,view占满整个屏幕的情况。
这个时候就须要在代码中设置view的大小。
WindowManager.LayoutParams params=dialog.getWindow().getAttributes();
params.width=400;
params.height=400;
dialog.getWindow().setAttributes(params);
自己定义对话框显示在底部
看到非常多应用在分享到第三方平台的时候。屏幕底部显示一个对话框
这样就须要自己定义Dialog的属性了,让dialog显示在屏幕的底部。
public static void showShareDialog(final Activity activity) {
final AlertDialog dialog = new AlertDialog.Builder(activity).create();
dialog.show();
View view = View.inflate(activity, R.layout.view_dialog_share, null);
TextView tvWeixinFriend = (TextView) view.findViewById(R.id.share_wexin);
tvWeixinFriend.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
ShareManager.getInstance().shareToWeixinFriend(activity);
}
});
TextView tvWeixinCircle = (TextView) view.findViewById(R.id.share_pyq);
tvWeixinCircle.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
ShareManager.getInstance().shareToWeixinCircle(activity);
}
});
TextView tvWeibo = (TextView) view.findViewById(R.id.share_weibo);
tvWeibo.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
dialog.dismiss();
ShareManager.getInstance().shareToWeibo(activity);
}
});
WindowManager.LayoutParams lp = dialog.getWindow().getAttributes();
lp.width = ViewGroup.LayoutParams.MATCH_PARENT;
lp.gravity = Gravity.BOTTOM;
dialog.getWindow().setAttributes(lp);
dialog.setContentView(view);
}
以下是
view_dialog_share
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:background="@color/white"
android:orientation="horizontal"
android:paddingBottom="16dp"
android:paddingTop="16dp"> <TextView
android:id="@+id/share_wexin"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:drawablePadding="4dp"
android:drawableTop="@drawable/icon_share_weixin_friend"
android:gravity="center_horizontal"
android:text="微信好友" /> <TextView
android:id="@+id/share_pyq"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:drawablePadding="4dp"
android:drawableTop="@drawable/icon_share_weixin_circle"
android:gravity="center_horizontal"
android:text="朋友圈" /> <TextView
android:id="@+id/share_weibo"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:drawablePadding="4dp"
android:drawableTop="@drawable/icon_share_weibo"
android:gravity="center_horizontal"
android:text="微博" />
</LinearLayout>
android中的常见对话框的更多相关文章
- Android中的常见通信机制和Linux中的通信机制
Handler Handler是Android系统中的一种消息传递机制,起作用是应对多线程场景.将A进程的消息传递给B线程,实现异步消息处理.很多情况是将工作线程中需要更新UI的操作消息传递给UI主线 ...
- Android中的普通对话框、单选对话框、多选对话框、带Icon的对话框、以及自定义Adapter和自定义View对话框详解
对话框就是一个AlertDialog,但是一个简单的AlertDialog,我们却可以将它玩出许多花样来,下面我们就来一起总结一下AlertDialog的用法.看看各位童鞋在平时的工作中否都用到了Al ...
- Android中如何使用对话框(单选对话框和多选对话框)
在主XML中声明两个Button,声明Id package com.example.myapplication; import androidx.appcompat.app.AlertDialog; ...
- Android中的常见时区
方法: private void printTimeZone(){ String[] ids= TimeZone.getAvailableIDs(); for (int i = 0; i < i ...
- (转载)Android开发——Android中常见的4种线程池(保证你能看懂并理解)
0.前言 转载请注明出处:http://blog.csdn.net/seu_calvin/article/details/52415337 使用线程池可以给我们带来很多好处,首先通过线程池中线程的重用 ...
- Android开发——Android中常见的4种线程池(保证你能看懂并理解)
0.前言 转载请注明出处:http://blog.csdn.net/seu_calvin/article/details/52415337 使用线程池可以给我们带来很多好处,首先通过线程池中线程的重用 ...
- [Android]GOF23种设计模式 & Android中的设计模式
GOF23种设计模式 设计原则: 1. 单一职责原则(SRP):就一个类而言,应该仅有一个引起它变化的原因 2. 开放-封闭原则(OCP):软件实体(类.模块.函数等)应该可以扩展,但是不可修改.即对 ...
- Android中解析XML
XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能.今天就由我向大家介绍一下在Android平台下几种常见的XML解 ...
- Android中三种常用解析XML的方式(DOM、SAX、PULL)简介及区别
XML在各种开发中都广泛应用,Android也不例外.作为承载数据的一个重要角色,如何读写XML成为Android开发中一项重要的技能.今天就由我向大家介绍一下在Android平台下几种常见的XML解 ...
随机推荐
- iOS---->CADisplayLink、比NSTimer更精确的定时器
什么是CADisplayLink CADisplayLink是一个能让我们以和屏幕刷新率相同的频率将内容画到屏幕上的定时器.我们在应用中创建一个新的 CADisplayLink 对象,把它添加到一个r ...
- C++调用有道翻译API实现在线翻译之发声篇
大概半月前写了一篇博文:C++中使用Curl和JsonCpp调用有道翻译API实现在线翻译, 得到大家的热情捧场,有人看了文章说要是能发声不是更好,我觉得说的也是哈,能听到专家的标准发音,那该是多美的 ...
- 【bzoj3680】吊打XXX 随机化
题目描述 gty又虐了一场比赛,被虐的蒟蒻们决定吊打gty.gty见大势不好机智的分出了n个分身,但还是被人多势众的蒟蒻抓住了.蒟蒻们将n个gty吊在n根绳子上,每根绳子穿过天台的一个洞.这n根绳子有 ...
- Hadoop High Availability
Hadoop High Availability HA(High Available), 高可用,是保证业务连续性的有效解决方案, 通常通过设置备用节点的方式实现; 一般分为执行业务的称为活动节点(A ...
- mybatis学习(十二)——mybatis逆向工程
MyBatis Generator (MBG)是一个mabatis的代码生成器,能够根据表自动生成mapper接口,mapper.xml文件,javaBean文件. 1.MBG的下载 打开https: ...
- testng依赖
Testng提供了两种依赖实现 1.强制依赖:某个测试用例之前需要执行的依赖链中如果有一个失败,那么接下来所有的测试都不会被执行 2.顺序依赖(软依赖):顺序依赖的用处更多是用来检测一个测试链是否按照 ...
- 数表(bzoj 3529)
Description 有一张N×m的数表,其第i行第j列(1 < =i < =礼,1 < =j < =m)的数值为能同时整除i和j的所有自然数之和.给定a,计算数表中不大于a ...
- 【NOIP2016练习】T1 string (计数)
题意: 思路: ; ..]of int64; n,k,i:longint; ans,x,y:int64; s,t:ansistring; function c(x,y:longint):int64; ...
- CodeForces 424D: ...(二分)
题意:给出一个n*m的矩阵,内有一些数字.当你从一个方格走到另一个方格时,按这两个方格数字的大小,有(升,平,降)三种费用.你需要在矩阵中找到边长大于2的一个矩形,使得按这个矩形顺时针行走一圈的费用, ...
- javascript 对象初探 (三)--- 传递/比较对象
传递对象 当我们拷贝某个对象或者将对象传递给某个函数时,往往传递的都是该对象的引用.因此我们在该对象的引用上做任何改动,实际上都会影响到引用的原对象. var she = {num:1}; var h ...