百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Android通知形式 Toast、Notification、Dialog对话框

yuyutoo 2024-10-22 18:34 2 浏览 0 评论

通知系统

1.Toast

弹出形式: 界面的下半部分 弹出一段时间后自动消失

不会因为界面关闭而消失 不会响应用户事件

应用场景: 提示不需要用户响应的信息 eg:双击退出

e

实现

//得到通知对象 (1.上下文对象 2.内容 3.时长)

Toast.LENGTH_LONG :3.5s Toast.LENGTH_SHORT:2s

Toast toast = Toast.makeText(this, "再次点击,退出应用!", Toast.LENGTH_LONG);

//显示通知

toast.show();

另一种写法:

Toast.makeText(this, "再次点击,退出应用!", Toast.LENGTH_LONG).show();


Notification 状态栏上的通知

形式:显示在状态栏上 显示提示信息 点击跳转到 详情界面

下拉显示详细内容

应用场景:全局通知

eg:短信提醒 歌曲播放歌曲通知


2.3 API

实现步骤:

//1.获得通知管理器对象

manager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);

//3.设置通知上升信息(参数1.上升动画 2.提示信息 3.系统时间)

Notification notification=new Notification(R.drawable.ic_launcher, "10086通知来了!", System.currentTimeMillis());

//7.设置点击通知自动消失的标志位

notification.flags=Notification.FLAG_AUTO_CANCEL;

//6.意图 设置点击通知跳转的方向(界面)

Intent intent=new Intent(this, MainActivity.class);

//5.延时意图

PendingIntent contentIntent=PendingIntent.getActivity(this, 0, intent, 0);

//4.设置下拉信息(1.上下文对象2.标题3.详细内容4.延时意图)

notification.setLatestEventInfo(this, "详细内容标题 10086", "内容欠费 100元", contentIntent);

//2.发送通知

manager.notify(1, notification);


//取消通知

manager.cancel(1);


Dialog 对话框

弹出形式:

在界面的正中央 ,打断用户的操作

应用场景: 需要立即用户做出响应 eg: 检查更新 双击退出

警告对话框AlertDialog

实现步骤:

//1.获得对话框辅助类 建造者模式

AlertDialog.Builder builder = new AlertDialog.Builder(this);

//2.设置标题

builder.setTitle("检查更新")

//3.设置内容

.setMessage("1.解决了XXXBug \n 2.新增了XXX功能")

//4.设置图标

.setIcon(R.drawable.ic_launcher)

//5.设置积极按钮

.setPositiveButton("确定", new OnClickListener() {

@Override

public void onClick(DialogInterface dialog, int which) {

Toast.makeText(MainActivity.this, "开始下载新版本", Toast.LENGTH_SHORT).show();

}

})

.setNegativeButton("取消", null)//消极按钮

.setNeutralButton("中立按钮", null)//中立按钮

.show();

//获得对话框对象 弹出方式二

// AlertDialog create = builder.create();

// create.show();


shift+alt+l (快速封装局部) shift+alt+M (快速封装方法)

菜单系统

选项菜单OptionMenu

应用必有的功能,但一又不是经常使用


创建菜单的方式一:xml中创建

1.重写onCreateOptionsMenu


2添加菜单文件.xml

添加菜单

<item

android:id="@+id/action_settings" //菜单Id

android:orderInCategory="80" //菜单显示顺序

android:showAsAction="ifRoom"

android:title="设置"/>//设置内容


ifRoom:如果有空间就显示在 ActionBar

always:总是显示在ActionBar

never:总是不显示在ActionBar


菜单点击事件

重写onOptionsItemSelected()

//1.获得Item的ID

int itemId = item.getItemId();

switch (itemId) {

case R.id.action_settings:

Toast.makeText(this, "设置", Toast.LENGTH_SHORT).show();

break;


填菜单的方式二:代码中添加菜单 点击事件一样


//添加子菜单

SubMenu subMenu = menu.addSubMenu("子菜单");

subMenu.addSubMenu(0, 3, 0, "设置1");

subMenu.addSubMenu(0, 4, 0, "设置1");


contextMenu 上下文菜单

形式:长按控件弹出上下文菜单

1. //为控件设置上下文菜单事件

registerForContextMenu(mTv1);

2.添加菜单

重写onCreateContextMenu(0


3.菜单点击事件


选项菜单跟上下文菜单的区别

选项菜单 上下文菜单

1.弹出方式 按Menu 长按控件

2.显示位置 界面中间

3.作用区域 Activity 控件本身

4.退出方式 重按Menu键 重按back

重按back 重按本身

重按本身 重按上下文菜单以外的区域

重按选项菜单以外的区域

5.创建次数 界面存在创建一次 每长按一次控件就创建一次上下文菜单



UI控件

1.CheckBox 多选框

应用场景:问卷调查 免责声明 是否记住密码

xml:

<CheckBox

android:id="@+id/checkBox1"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:checked="true" true:选中 false:没有选中(默认)

android:text="记住密码" /> 文本


code:

//设置CheckBox选中状态

mBox.setChecked(true);

//获得CheckBox是否选中

boolean checked = mBox.isChecked();

//获得CheckBox的文本

String string = mBox.getText().toString();


CheckBox状态改变监听事件

mBox.setOnCheckedChangeListener(new OnCheckedChangeListener() {

@Override

public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {

//CheckBox改变时调用onCheckedChanged

Log.e("onCheckedChanged"+buttonView.getText().toString(), "isChecked"+isChecked);

}

});


Button

设置按钮是否可点击

xml:

android:enabled="true" 可点击 false :不可点击

code:

mButton.setEnabled(false)

相关推荐

史上最全的浏览器兼容性问题和解决方案

微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...

平面设计基础知识_平面设计基础知识实验收获与总结
平面设计基础知识_平面设计基础知识实验收获与总结

CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...

2025-02-21 16:01 yuyutoo

写作排版简单三步就行-工具篇_作文排版模板

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

写一个2048的游戏_2048小游戏功能实现

1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...

今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……

  最近的天气暖和得让很多小伙伴们喊“热”!!!  昨天的气温到底升得有多高呢?你家有没有榜上有名?...

CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式

之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...

柠檬科技肖勃飞:大数据风控助力信用社会建设

...

你的自我界限够强大吗?_你的自我界限够强大吗英文

我的结果:A、该设立新的界限...

行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?

行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...

让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华

去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...

2025-02-21 16:00 yuyutoo

今年国家综合性消防救援队伍计划招录消防员15000名

记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...

一起盘点最新 Chrome v133 的5大主流特性 ?

1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...

竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使

style="text-align:center;"data-mce-style="text-align:...

学物理能做什么?_学物理能做什么 卢昌海

作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...

你不知道的关于这只眯眼兔的6个小秘密
你不知道的关于这只眯眼兔的6个小秘密

在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...

2025-02-21 16:00 yuyutoo

取消回复欢迎 发表评论: