android组件通讯 Intent- 系统标准的Activity Action应用

简介:

标准的Activity Actions

 

  1. ACTION_M AIN 作为一个主要的进入口,而并不期望去接受数据
  2. ACTION_VIEW 向用户去显示数据
  3. ACTION_ATTACH_DATA 别用于指定一些数据应该附属于一些其他的地方,例如,图片数据应该附属于联系人
  4. ACTION_EDIT 访问已给的数据,提供明确的可编辑
  5. ACTION_PICK 从数据中选择一个子项目,并返回你所选中的项目
  6. ACTION_CHOOSER 显示一个activity选择器,允许用户在进程之前选择他们想要的
  7. ACTION_GET_CONTENT 允许用户选择特殊种类的数据,并返回(特殊种类的数据:照一张相片或录一段音)
  8. ACTION_DIAL 拨打一个指定的号码,显示一个带有号码的用户界面,允许用户去启动呼叫
  9. ACTION_CALL 根据指定的数据执行一次呼叫
  10. (ACTION_CALL在应用中启动一次呼叫有缺陷,多数应用ACTION_DIAL,ACTION_CALL不能用在紧急呼叫上,紧急呼叫可以用ACTION_DIAL来实现)
  11. ACTION_SEND 传递数据,被传送的数据没有指定,接收的action请求用户发数据
  12. ACTION_SENDTO 发送一跳信息到指定的某人
  13. ACTION_ANSWER 处理一个打进电话呼叫
  14. ACTION_INSERT 插入一条空项目到已给的容器
  15. ACTION_DELETE 从容器中删除已给的数据
  16. ACTION_RUN 运行数据,无论怎么
  17. ACTION_SYNC 同步执行一个数据
  18. ACTION_PICK_ACTIVITY 为以为的Intent选择一个Activity,返回别选中的类
  19. ACTION_SEARCH 执行一次搜索
  20. ACTION_WEB_SEARCH 执行一次web搜索
  21. ACTION_FACTORY_TEST 工场测试的主要进入点,

标准的广播Actions

  1. ACTION_TIME_TICK 当前时间改变,每分钟都发送,不能通过组件声明来接收,只有通过Context.registerReceiver()方法来注册
  2. ACTION_TIME_CHANGED 时间被设置
  3. ACTION_TIMEZONE_CHANGED 时间区改变
  4. ACTION_BOOT_COMPLETED 系统完成启动后,一次广播
  5. ACTION_PACKAGE_ADDED 一个新应用包已经安装在设备上,数据包括包名(最新安装的包程序不能接收到这个广播)
  6. ACTION_PACKAGE_CHANGED 一个已存在的应用程序包已经改变,包括包名
  7. ACTION_PACKAGE_REMOVED 一个已存在的应用程序包已经从设备上移除,包括包名(正在被安装的包程序不能接收到这个广播)
  8. ACTION_PACKAGE_RESTARTED 用户重新开始一个包,包的所有进程将被杀死,所有与其联系的运行时间状态应该被移除,包括包名(重新开始包程序不能接收到这个广播)
  9. ACTION_PACKAGE_DATA_CLEARED 用户已经清楚一个包的数据,包括包名(清除包程序不能接收到这个广播)
  10. ACTION_BATTERY_CHANGED 电池的充电状态、电荷级别改变,不能通过组建声明接收这个广播,只有通过Context.registerReceiver()注册
  11. ACTION_UID_REMOVED 一个用户ID已经从系统中移除

 

一、打电话、访问浏览器地图的Activity Action应用

程序文件

/Chapter06_Intent_SystemAction/src/com/amaker/ch06/app/MainActivity.java

 

 
  1. 代码  
  2.  
  3. package com.amaker.ch06.app;  
  4.  
  5. import android.app.ListActivity;  
  6. import android.content.Intent;  
  7. import android.net.Uri;  
  8. import android.os.Bundle;  
  9. import android.view.View;  
  10. import android.widget.ArrayAdapter;  
  11. import android.widget.ListView;  
  12.  
  13. public class MainActivity extends ListActivity {  
  14.     @Override  
  15.     public void onCreate(Bundle savedInstanceState) {  
  16.         super.onCreate(savedInstanceState);  
  17.         // 菜单项数组  
  18.         String[] menus = { "查看电话信息", "编辑电话信息", "显示拨打电话界面","直接打电话","访问浏览器","访问地图"};  
  19.         // 将菜单项数组设置为ListView的列表项展示  
  20.         setListAdapter(new ArrayAdapter<String>(this,  
  21.                 android.R.layout.simple_list_item_1, menus));  
  22.         getListView().setTextFilterEnabled(true);  
  23.     }  
  24.       
  25.     @Override  
  26.     protected void onListItemClick(ListView l, View v, int position, long id) {  
  27.         Intent intent = new Intent();  
  28.         Uri uri ;  
  29.         String data;  
  30.         switch (position) {  
  31.         // 查看_id 为1的用户电话信息  
  32.         case 0:  
  33.             data = "content://contacts/people/1";  
  34.             uri = Uri.parse(data);  
  35.             intent.setAction(Intent.ACTION_VIEW);  
  36.             intent.setData(uri);  
  37.             startActivity(intent);  
  38.             break;  
  39.         // 编辑_id 为1的用户电话信息  
  40.         case 1:  
  41.             data = "content://contacts/people/1";  
  42.             uri = Uri.parse(data);  
  43.             intent.setAction(Intent.ACTION_EDIT);  
  44.             intent.setData(uri);  
  45.             startActivity(intent);  
  46.             break;  
  47.         // 显示拨打电话界面  
  48.         case 2:  
  49.             data = "tel:13800138000";  
  50.             uri = Uri.parse(data);  
  51.             intent.setAction(Intent.ACTION_DIAL);  
  52.             intent.setData(uri);  
  53.             startActivity(intent);  
  54.             break;  
  55.         // 直接打电话  
  56.         case 3:  
  57.             data = "tel:13800138000";  
  58.             uri = Uri.parse(data);  
  59.             intent.setAction(Intent.ACTION_CALL);  
  60.             intent.setData(uri);  
  61.             startActivity(intent);  
  62.             break;  
  63.         // 访问浏览器  
  64.         case 4:  
  65.             data = "http://www.google.com";  
  66.             uri = Uri.parse(data);  
  67.             intent.setAction(Intent.ACTION_VIEW);  
  68.             intent.setData(uri);  
  69.             startActivity(intent);  
  70.             break;  
  71.         // 访问地图  
  72.         case 5:  
  73.             data = "geo:39.92,116.46";  
  74.             uri = Uri.parse(data);  
  75.             intent = new Intent(Intent.ACTION_VIEW,uri);  
  76.             startActivity(intent);  
  77.             break;  
  78.         default:  
  79.             break;  
  80.         }  
  81.     }  

布局文件

/Chapter06_Intent_SystemAction/res/layout/main.xml

 

 
  1. 代码  
  2.  
  3. <?xml version="1.0" encoding="utf-8"?> 
  4. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  5.     android:orientation="vertical" android:layout_width="fill_parent" 
  6.     android:layout_height="fill_parent"> 
  7.  
  8. <Button android:text="@+id/Button01" android:id="@+id/Button01" android:layout_width="wrap_content" android:layout_height="wrap_content"></Button> 
  9. </LinearLayout> 

清单文件

/Chapter06_Intent_SystemAction/AndroidManifest.xml

 

 
  1. 代码  
  2.  
  3. <?xml version="1.0" encoding="utf-8"?> 
  4. <manifest xmlns:android="http://schemas.android.com/apk/res/android" 
  5.       package="com.amaker.ch06.app" 
  6.       android:versionCode="1" 
  7.       android:versionName="1.0"> 
  8.     <application android:icon="@drawable/icon" android:label="@string/app_name"> 
  9.         <activity android:name=".MainActivity" 
  10.                   android:label="@string/app_name"> 
  11.             <intent-filter> 
  12.                 <action android:name="android.intent.action.MAIN" /> 
  13.                 <category android:name="android.intent.category.LAUNCHER" /> 
  14.             </intent-filter> 
  15.         </activity> 
  16.  
  17.     </application> 
  18.     <uses-sdk android:minSdkVersion="3" /> 
  19.  
  20. <uses-permission android:name="android.permission.CALL_PHONE"></uses-permission> 
  21. </manifest> 

 

本文转自linzheng 51CTO博客,原文链接:http://blog.51cto.com/linzheng/1080662

相关文章
|
15天前
|
移动开发 Java Android开发
构建高效Android应用:探究Kotlin与Java的性能差异
【4月更文挑战第3天】在移动开发领域,性能优化一直是开发者关注的焦点。随着Kotlin的兴起,其在Android开发中的地位逐渐上升,但关于其与Java在性能方面的对比,尚无明确共识。本文通过深入分析并结合实际测试数据,探讨了Kotlin与Java在Android平台上的性能表现,揭示了在不同场景下两者的差异及其对应用性能的潜在影响,为开发者在选择编程语言时提供参考依据。
|
16天前
|
数据库 Android开发 开发者
构建高效Android应用:Kotlin协程的实践指南
【4月更文挑战第2天】随着移动应用开发的不断进步,开发者们寻求更流畅、高效的用户体验。在Android平台上,Kotlin语言凭借其简洁性和功能性赢得了开发社区的广泛支持。特别是Kotlin协程,作为一种轻量级的并发处理方案,使得异步编程变得更加简单和直观。本文将深入探讨Kotlin协程的核心概念、使用场景以及如何将其应用于Android开发中,以提高应用性能和响应能力。通过实际案例分析,我们将展示协程如何简化复杂任务,优化资源管理,并为最终用户提供更加流畅的体验。
|
16天前
|
开发框架 安全 Android开发
探索安卓系统的新趋势:智能家居应用的蓬勃发展
随着智能家居概念的兴起,安卓系统在智能家居应用领域的应用日益广泛。本文将探讨安卓系统在智能家居应用开发方面的最新趋势和创新,以及其对用户生活的影响。
13 2
|
19天前
|
缓存 监控 Java
构建高效Android应用:从优化用户体验到提升性能
在竞争激烈的移动应用市场中,为用户提供流畅和高效的体验是至关重要的。本文深入探讨了如何通过多种技术手段来优化Android应用的性能,包括UI响应性、内存管理和多线程处理。同时,我们还将讨论如何利用最新的Android框架和工具来诊断和解决性能瓶颈。通过实例分析和最佳实践,读者将能够理解并实施必要的优化策略,以确保他们的应用在保持响应迅速的同时,还能够有效地利用系统资源。
|
20天前
|
Java Android开发
Android 开发获取通知栏权限时会出现两个应用图标
Android 开发获取通知栏权限时会出现两个应用图标
12 0
|
24天前
|
编解码 算法 Java
构建高效的Android应用:内存优化策略详解
随着智能手机在日常生活和工作中的普及,用户对移动应用的性能要求越来越高。特别是对于Android开发者来说,理解并实践内存优化是提升应用程序性能的关键步骤。本文将深入探讨针对Android平台的内存管理机制,并提供一系列实用的内存优化技巧,以帮助开发者减少内存消耗,避免常见的内存泄漏问题,并确保应用的流畅运行。
|
25天前
|
调度 数据库 Android开发
构建高效Android应用:Kotlin协程的实践与优化
在Android开发领域,Kotlin以其简洁的语法和平台友好性成为了开发的首选语言。其中,Kotlin协程作为处理异步任务的强大工具,它通过提供轻量级的线程管理机制,使得开发者能够在不阻塞主线程的情况下执行后台任务,从而提升应用性能和用户体验。本文将深入探讨Kotlin协程的核心概念,并通过实例演示如何在实际的Android应用中有效地使用协程进行网络请求、数据库操作以及UI的流畅更新。同时,我们还将讨论协程的调试技巧和常见问题的解决方法,以帮助开发者避免常见的陷阱,构建更加健壮和高效的Android应用。
32 4
|
27天前
|
移动开发 Java Android开发
构建高效Android应用:Kotlin协程的实践之路
【2月更文挑战第31天】 在移动开发领域,性能优化和流畅的用户体验一直是开发者追求的目标。随着Kotlin语言的流行,其异步编程解决方案——协程(Coroutines),为Android应用带来了革命性的并发处理能力。本文将深入探讨Kotlin协程的核心概念、设计原理以及在Android应用中的实际应用案例,旨在帮助开发者掌握这一强大的工具,从而提升应用的性能和响应能力。
|
28天前
|
安全 Android开发 开发者
构建高效Android应用:Kotlin与协程的完美结合
【2月更文挑战第30天】在移动开发领域,性能优化和流畅的用户体验是关键。本文深入探讨了如何通过结合Kotlin语言和协程技术来提升Android应用的性能和响应能力。我们将分析Kotlin的优势,介绍协程的基本概念,并通过实际案例展示如何在应用中实现协程以简化异步编程,从而提供更加高效的解决方案。
|
17天前
|
Java Android开发 开发者
构建高效Android应用:Kotlin协程的实践与优化
在响应式编程范式日益盛行的今天,Kotlin协程作为一种轻量级的线程管理解决方案,为Android开发带来了性能和效率的双重提升。本文旨在探讨Kotlin协程的核心概念、实践方法及其在Android应用中的优化策略,帮助开发者构建更加流畅和高效的应用程序。通过深入分析协程的原理与应用场景,结合实际案例,本文将指导读者如何优雅地解决异步任务处理,避免阻塞UI线程,从而优化用户体验。