Android入门第九篇之AlertDialog

本文详细介绍了Android中AlertDialog的应用方式,包括非Layout型和使用自定义Layout的对话框创建方法。通过示例代码展示了如何设置图标、标题、消息内容及按钮等。

时隔一年,又要准备做Android的开发了,最近复习和整理一下Android的知识。 这次要说的是AlertDialog,这种对话框会经常遇到。AlertDialog跟WIN32开发中的Dialog不一样,AlertDialog是非阻塞的,而阻塞的对话框用的是PopupWindow。

 

main.xml的源码:

  1. <? xml   version = "1.0"   encoding = "utf-8" ?>   
  2. < LinearLayout   xmlns:android = "http://schemas.android.com/apk/res/android"   
  3.     android:orientation = "vertical"   
  4.     android:layout_width = "fill_parent"   
  5.     android:layout_height = "fill_parent"   
  6.     >   
  7.   
  8. < Button   android:id = "@+id/Button01"   android:layout_height = "wrap_content"   android:text = "非Layout型对话框"   android:layout_width = "fill_parent" > </ Button >   
  9. < Button   android:id = "@+id/Button02"   android:layout_height = "wrap_content"   android:text = "Layout型对话框"   android:layout_width = "fill_parent" > </ Button > < View   android:id = "@+id/View01"   android:layout_width = "wrap_content"   android:layout_height = "wrap_content" > </ View >   
  10.   
  11. </ LinearLayout >   
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <Button android:id="@+id/Button01" android:layout_height="wrap_content" android:text="非Layout型对话框" android:layout_width="fill_parent"></Button> <Button android:id="@+id/Button02" android:layout_height="wrap_content" android:text="Layout型对话框" android:layout_width="fill_parent"></Button><View android:id="@+id/View01" android:layout_width="wrap_content" android:layout_height="wrap_content"></View> </LinearLayout>

下图是非Layout型对话框,直接使用AlertDialog

下图是使用了Layout的对话框,可以自定义控件,实现更复杂的对话框

dialoglayout.xml的源码:

  1. <? xml   version = "1.0"   encoding = "utf-8" ?>   
  2.   
  3. < LinearLayout   xmlns:android = "http://schemas.android.com/apk/res/android"   
  4.     android:layout_width = "fill_parent"   android:layout_height = "wrap_content"   
  5.     android:orientation = "vertical" >   
  6.     < EditText   android:layout_height = "wrap_content"   
  7.         android:layout_width = "fill_parent"   android:layout_marginLeft = "20dip"   
  8.         android:layout_marginRight = "20dip"   android:textAppearance = "?android:attr/textAppearanceMedium"   android:id = "@+id/edtInput" />   
  9. </ LinearLayout >   
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="wrap_content" android:orientation="vertical"> <EditText android:layout_height="wrap_content" android:layout_width="fill_parent" android:layout_marginLeft="20dip" android:layout_marginRight="20dip" android:textAppearance="?android:attr/textAppearanceMedium" android:id="@+id/edtInput"/> </LinearLayout>

程序源码:

  1. package  com.testAlertDialog;  
  2.   
  3. import  android.app.Activity;  
  4. import  android.app.AlertDialog;  
  5. import  android.content.Context;  
  6. import  android.content.DialogInterface;  
  7. import  android.os.Bundle;  
  8. import  android.view.Gravity;  
  9. import  android.view.LayoutInflater;  
  10. import  android.view.View;  
  11. import  android.view.View.OnClickListener;  
  12. import  android.widget.Button;  
  13. import  android.widget.EditText;  
  14. import  android.widget.PopupWindow;  
  15.   
  16.   
  17. public   class  testAlertDialog  extends  Activity {  
  18.     Button btnShowDialog;  
  19.     Button btnShowDialog_Layout;  
  20.     /** Called when the activity is first created. */   
  21.     @Override   
  22.     public   void  onCreate(Bundle savedInstanceState) {  
  23.         super .onCreate(savedInstanceState);  
  24.         setContentView(R.layout.main);  
  25.         //定义按钮   
  26.         btnShowDialog=(Button)this .findViewById(R.id.Button01);  
  27.         btnShowDialog.setOnClickListener(new  ClickEvent());  
  28.         btnShowDialog_Layout=(Button)this .findViewById(R.id.Button02);  
  29.         btnShowDialog_Layout.setOnClickListener(new  ClickEvent());  
  30.     }  
  31.       
  32.       
  33.     //统一处理按键事件   
  34.     class  ClickEvent  implements  OnClickListener{  
  35.   
  36.         @Override   
  37.         public   void  onClick(View v) {  
  38.             // TODO Auto-generated method stub   
  39.             if (v==btnShowDialog)  
  40.                 showDialog(testAlertDialog.this );  
  41.                   
  42.             else   if (v==btnShowDialog_Layout)  
  43.                 showDialog_Layout(testAlertDialog.this );  
  44.               
  45.         }  
  46.   
  47.     }  
  48.   
  49.     //显示基本的AlertDialog   
  50.     private   void  showDialog(Context context) {  
  51.         AlertDialog.Builder builder = new  AlertDialog.Builder(context);  
  52.         builder.setIcon(R.drawable.icon);  
  53.         builder.setTitle("Title" );  
  54.         builder.setMessage("Message" );  
  55.         builder.setPositiveButton("Button1" ,  
  56.                 new  DialogInterface.OnClickListener() {  
  57.                     public   void  onClick(DialogInterface dialog,  int  whichButton) {  
  58.                         setTitle("点击了对话框上的Button1" );  
  59.                     }  
  60.                 });  
  61.         builder.setNeutralButton("Button2" ,  
  62.                 new  DialogInterface.OnClickListener() {  
  63.                     public   void  onClick(DialogInterface dialog,  int  whichButton) {  
  64.                         setTitle("点击了对话框上的Button2" );  
  65.                     }  
  66.                 });  
  67.         builder.setNegativeButton("Button3" ,  
  68.                 new  DialogInterface.OnClickListener() {  
  69.                     public   void  onClick(DialogInterface dialog,  int  whichButton) {  
  70.                         setTitle("点击了对话框上的Button3" );  
  71.                     }  
  72.                 });  
  73.         builder.show();  
  74.     }  
  75.   
  76.   
  77.     //显示基于Layout的AlertDialog   
  78.     private   void  showDialog_Layout(Context context) {  
  79.         LayoutInflater inflater = LayoutInflater.from(this );  
  80.         final  View textEntryView = inflater.inflate(  
  81.                 R.layout.dialoglayout, null );  
  82.         final  EditText edtInput=(EditText)textEntryView.findViewById(R.id.edtInput);  
  83.         final  AlertDialog.Builder builder =  new  AlertDialog.Builder(context);  
  84.         builder.setCancelable(false );  
  85.         builder.setIcon(R.drawable.icon);  
  86.         builder.setTitle("Title" );  
  87.         builder.setView(textEntryView);  
  88.         builder.setPositiveButton("确认" ,  
  89.                 new  DialogInterface.OnClickListener() {  
  90.                     public   void  onClick(DialogInterface dialog,  int  whichButton) {  
  91.                         setTitle(edtInput.getText());  
  92.                     }  
  93.                 });  
  94.         builder.setNegativeButton("取消" ,  
  95.                 new  DialogInterface.OnClickListener() {  
  96.                     public   void  onClick(DialogInterface dialog,  int  whichButton) {  
  97.                         setTitle("" );  
  98.                     }  
  99.                 });  
  100.         builder.show();  
  101.     }  

内容概要:本文介绍了一个基于多传感器融合的定位系统设计方案,采用GPS、里程计和电子罗盘作为定位传感器,利用扩展卡尔曼滤波(EKF)算法对多源传感器数据进行融合处理,最终输出目标的滤波后位置信息,并提供了完整的Matlab代码实现。该方法有效提升了定位精度与稳定性,尤其适用于存在单一传感器误差或信号丢失的复杂环境,如自动驾驶、移动采用GPS、里程计和电子罗盘作为定位传感器,EKF作为多传感器的融合算法,最终输出目标的滤波位置(Matlab代码实现)机器人导航等领域。文中详细阐述了各传感器的数据建模方式、状态转移与观测方程构建,以及EKF算法的具体实现步骤,具有较强的工程实践价值。; 适合人群:具备一定Matlab编程基础,熟悉传感器原理和滤波算法的高校研究生、科研人员及从事自动驾驶、机器人导航等相关领域的工程技术人员。; 使用场景及目标:①学习和掌握多传感器融合的基本理论与实现方法;②应用于移动机器人、无人车、无人机等系统的高精度定位与导航开发;③作为EKF算法在实际工程中应用的教学案例或项目参考; 阅读建议:建议读者结合Matlab代码逐行理解算法实现过程,重点关注状态预测与观测更新模块的设计逻辑,可尝试引入真实传感器数据或仿真噪声环境以验证算法鲁棒性,并进一步拓展至UKF、PF等更高级滤波算法的研究与对比。
内容概要:文章围绕智能汽车新一代传感器的发展趋势,重点阐述了BEV(鸟瞰图视角)端到端感知融合架构如何成为智能驾驶感知系统的新范式。传统后融合与前融合方案因信息丢失或算力需求过高难以满足高阶智驾需求,而基于Transformer的BEV融合方案通过统一坐标系下的多源传感器特征融合,在保证感知精度的同时兼顾算力可行性,显著提升复杂场景下的鲁棒性与系统可靠性。此外,文章指出BEV模型落地面临大算力依赖与高数据成本的挑战,提出“数据采集-模型训练-算法迭代-数据反哺”的高效数据闭环体系,通过自动化标注与长尾数据反馈实现算法持续进化,降低对人工标注的依赖,提升数据利用效率。典型企业案例进一步验证了该路径的技术可行性与经济价值。; 适合人群:从事汽车电子、智能驾驶感知算法研发的工程师,以及关注自动驾驶技术趋势的产品经理和技术管理者;具备一定自动驾驶基础知识,希望深入了解BEV架构与数据闭环机制的专业人士。; 使用场景及目标:①理解BEV+Transformer为何成为当前感知融合的主流技术路线;②掌握数据闭环在BEV模型迭代中的关键作用及其工程实现逻辑;③为智能驾驶系统架构设计、传感器选型与算法优化提供决策参考; 阅读建议:本文侧重技术趋势分析与系统级思考,建议结合实际项目背景阅读,重点关注BEV融合逻辑与数据闭环构建方法,并可延伸研究相关企业在舱泊一体等场景的应用实践。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值