常量 | Values |
String ADD_SHORTCUT_ACTION | 动作:在系统中添加一个快捷方式。. "android.intent.action.ADD_SHORTCUT" |
String ALL_APPS_ACTION | 动作:列举所有可用的应用。输入:无。 "android.intent.action.ALL_APPS" |
String ALTERNATIVE_CATEGORY | 类别:说明 activity 是用户正在浏览的数据的一个可选操作。 "android.intent.category.ALTERNATIVE" |
String ANSWER_ACTION | 动作:处理拨入的电话。 "android.intent.action.ANSWER" |
String BATTERY_CHANGED_ACTION | 广播:充电状态,或者电池的电量发生变化。 "android.intent.action.BATTERY_CHANGED" |
String BOOT_COMPLETED_ACTION | 广播:在系统启动后,这个动作被广播一次(只有一次)。 "android.intent.action.BOOT_COMPLETED" |
String BROWSABLE_CATEGORY | 类别:能够被浏览器安全使用的 activities 必须支持这个类别。 "android.intent.category.BROWSABLE" |
String BUG_REPORT_ACTION | 动作:显示 activity 报告错误。 "android.intent.action.BUG_REPORT" |
String CALL_ACTION | 动作:拨打电话,被呼叫的联系人在数据中指定。 "android.intent.action.CALL" |
String CALL_FORWARDING_STATE_CHANGED_ACTION | 广播:语音电话的呼叫转移状态已经改变。 "android.intent.action.CFF" |
String CLEAR_CREDENTIALS_ACTION | 动作:清除登陆凭证 (credential)。 "android.intent.action.CLEAR_CREDENTIALS" |
String CONFIGURATION_CHANGED_ACTION | 广播:设备的配置信息已经改变,参见 Resources.Configuration. "android.intent.action.CONFIGURATION_CHANGED" |
String DATA_ACTIVITY_STATE_CHANGED_ACTION | 广播:电话的数据活动(data activity)状态(即收发数据的状态)已经改变。 "android.intent.action.DATA_ACTIVITY" |
String DATA_CONNECTION_STATE_CHANGED_ACTION | 广播:电话的数据连接状态已经改变。 "android.intent.action.DATA_STATE" |
String DATE_CHANGED_ACTION | 广播:日期被改变。 "android.intent.action.DATE_CHANGED" |
String DEFAULT_ACTION | 动作:和 VIEW_ACTION 相同,是在数据上执行的标准动作。 "android.intent.action.VIEW" |
String DEFAULT_CATEGORY | 类别:如果 activity 是对数据执行确省动作(点击, center press)的一个选项,需要设置这个类别。 "android.intent.category.DEFAULT" |
String DELETE_ACTION | 动作:从容器中删除给定的数据。 "android.intent.action.DELETE" |
String DEVELOPMENT_PREFERENCE_CATEGORY | 类别:说明 activity 是一个设置面板 (development preference panel). "android.intent.category.DEVELOPMENT_PREFERENCE" |
String DIAL_ACTION | 动作:拨打数据中指定的电话号码。 "android.intent.action.DIAL" |
String EDIT_ACTION | 动作:为制定的数据显示可编辑界面。 "android.intent.action.EDIT" |
String EMBED_CATEGORY | 类别:能够在上级(父)activity 中运行。 "android.intent.category.EMBED" |
String EMERGENCY_DIAL_ACTION | 动作:拨打紧急电话号码。 "android.intent.action.EMERGENCY_DIAL" |
int FORWARD_RESULT_LAUNCH | 启动标记:如果这个标记被设置,而且被一个已经存在的 activity 用来启动新的 activity,已有 activity 的回复目标 (reply target) 会被转移给新的 activity。 16 0x00000010 |
String FOTA_CANCEL_ACTION | 广播:取消所有被挂起的 (pending) 更新下载。 "android.server.checkin.FOTA_CANCEL" |
String FOTA_INSTALL_ACTION | 广播:更新已经被确认,马上就要开始安装。 "android.server.checkin.FOTA_INSTALL" |
String FOTA_READY_ACTION | 广播:更新已经被下载,可以开始安装。 "android.server.checkin.FOTA_READY" |
String FOTA_RESTART_ACTION | 广播:恢复已经停止的更新下载。 "android.server.checkin.FOTA_RESTART" |
String FOTA_UPDATE_ACTION | 广播:通过 OTA 下载并安装操作系统更新。 "android.server.checkin.FOTA_UPDATE" |
String FRAMEWORK_INSTRUMENTATION_TEST_CATEGORY | 类别:To be used as code under test for framework instrumentation tests. "android.intent.category.FRAMEWORK_INSTRUMENTATION_TEST" |
String GADGET_CATEGORY | 类别:这个 activity 可以被嵌入宿主 activity (activity that is hosting gadgets)。 "android.intent.category.GADGET" |
String GET_CONTENT_ACTION | 动作:让用户选择数据并返回。 "android.intent.action.GET_CONTENT" |
String HOME_CATEGORY | 类别:主屏幕 (activity),设备启动后显示的第一个 activity。 "android.intent.category.HOME" |
String INSERT_ACTION | 动作:在容器中插入一个空项 (item)。 "android.intent.action.INSERT" |
String INTENT_EXTRA | 附加数据:和 PICK_ACTIVITY_ACTION 一起使用时,说明用户选择的用来显示的 activity;和 ADD_SHORTCUT_ACTION 一起使用的时候,描述要添加的快捷方式。 "android.intent.extra.INTENT" |
String LABEL_EXTRA | 附加数据:大写字母开头的字符标签,和 ADD_SHORTCUT_ACTION 一起使用。 "android.intent.extra.LABEL" |
String LAUNCHER_CATEGORY | 类别:Activity 应该被显示在顶级的 launcher 中。 "android.intent.category.LAUNCHER" |
String LOGIN_ACTION | 动作:获取登录凭证。 "android.intent.action.LOGIN" |
String MAIN_ACTION | 动作:作为主入口点启动,不需要数据。 "android.intent.action.MAIN" |
String MEDIABUTTON_ACTION | 广播:用户按下了“Media Button”。 "android.intent.action.MEDIABUTTON" |
String MEDIA_BAD_REMOVAL_ACTION | 广播:扩展介质(扩展卡)已经从 SD 卡插槽拔出,但是挂载点 (mount point) 还没解除 (unmount)。 "android.intent.action.MEDIA_BAD_REMOVAL" |
String MEDIA_EJECT_ACTION | 广播:用户想要移除扩展介质(拔掉扩展卡)。 "android.intent.action.MEDIA_EJECT" |
String MEDIA_MOUNTED_ACTION | 广播:扩展介质被插入,而且已经被挂载。 "android.intent.action.MEDIA_MOUNTED" |
String MEDIA_REMOVED_ACTION | 广播:扩展介质被移除。 "android.intent.action.MEDIA_REMOVED" |
String MEDIA_SCANNER_FINISHED_ACTION | 广播:已经扫描完介质的一个目录。 "android.intent.action.MEDIA_SCANNER_FINISHED" |
String MEDIA_SCANNER_STARTED_ACTION | 广播:开始扫描介质的一个目录。 "android.intent.action.MEDIA_SCANNER_STARTED" |
String MEDIA_SHARED_ACTION | 广播:扩展介质的挂载被解除 (unmount),因为它已经作为 USB 大容量存储被共享。 "android.intent.action.MEDIA_SHARED" |
String MEDIA_UNMOUNTED_ACTION | 广播:扩展介质存在,但是还没有被挂载 (mount)。 "android.intent.action.MEDIA_UNMOUNTED" |
String MESSAGE_WAITING_STATE_CHANGED_ACTION | 广播:电话的消息等待(语音邮件)状态已经改变。 "android.intent.action.MWI" |
int MULTIPLE_TASK_LAUNCH | 启动标记:和 NEW_TASK_LAUNCH 联合使用,禁止将已有的任务改变为前景任务 (foreground)。 8 0x00000008 |
String NETWORK_TICKLE_RECEIVED_ACTION | 广播:设备收到了新的网络 "tickle" 通知。 "android.intent.action.NETWORK_TICKLE_RECEIVED" |
int NEW_TASK_LAUNCH | 启动标记:设置以后,activity 将成为历史堆栈中的第一个新任务(栈顶)。 4 0x00000004 |
int NO_HISTORY_LAUNCH | 启动标记:设置以后,新的 activity 不会被保存在历史堆栈中。 1 0x00000001 |
String PACKAGE_ADDED_ACTION | 广播:设备上新安装了一个应用程序包。 "android.intent.action.PACKAGE_ADDED" |
String PACKAGE_REMOVED_ACTION | 广播:设备上删除了一个应用程序包。 "android.intent.action.PACKAGE_REMOVED" |
String PHONE_STATE_CHANGED_ACTION | 广播:电话状态已经改变。 "android.intent.action.PHONE_STATE" |
String PICK_ACTION | 动作:从数据中选择一个项目 (item),将被选中的项目返回。 "android.intent.action.PICK" |
String PICK_ACTIVITY_ACTION | 动作:选择一个 activity,返回被选择的 activity 的类(名)。 "android.intent.action.PICK_ACTIVITY" |
String PREFERENCE_CATEGORY | 类别:activity是一个设置面板 (preference panel)。 "android.intent.category.PREFERENCE" |
String PROVIDER_CHANGED_ACTION | 广播:更新将要(真正)被安装。 "android.intent.action.PROVIDER_CHANGED" |
String PROVISIONING_CHECK_ACTION | 广播:要求 polling of provisioning service 下载最新的设置。 "android.intent.action.PROVISIONING_CHECK" |
String RUN_ACTION | 动作:运行数据(指定的应用),无论它(应用)是什么。 "android.intent.action.RUN" |
String SAMPLE_CODE_CATEGORY | 类别:To be used as an sample code example (not part of the normal user experience). "android.intent.category.SAMPLE_CODE" |
String SCREEN_OFF_ACTION | 广播:屏幕被关闭。 "android.intent.action.SCREEN_OFF" |
String SCREEN_ON_ACTION | 广播:屏幕已经被打开。 "android.intent.action.SCREEN_ON" |
String SELECTED_ALTERNATIVE_CATEGORY | 类别:对于被用户选中的数据,activity 是它的一个可选操作。 "android.intent.category.SELECTED_ALTERNATIVE" |
String SENDTO_ACTION | 动作:向 data 指定的接收者发送一个消息。 "android.intent.action.SENDTO" |
String SERVICE_STATE_CHANGED_ACTION | 广播:电话服务的状态已经改变。 "android.intent.action.SERVICE_STATE" |
String SETTINGS_ACTION | 动作:显示系统设置。输入:无。 "android.intent.action.SETTINGS" |
String SIGNAL_STRENGTH_CHANGED_ACTION | 广播:电话的信号强度已经改变。 "android.intent.action.SIG_STR" |
int SINGLE_TOP_LAUNCH | 启动标记:设置以后,如果 activity 已经启动,而且位于历史堆栈的顶端,将不再启动(不重新启动) activity。 |
String STATISTICS_REPORT_ACTION | 广播:要求 receivers 报告自己的统计信息。 "android.intent.action.STATISTICS_REPORT" |
String STATISTICS_STATE_CHANGED_ACTION | 广播:统计信息服务的状态已经改变。 "android.intent.action.STATISTICS_STATE_CHANGED" |
String SYNC_ACTION | 动作:执行数据同步。 "android.intent.action.SYNC" |
String TAB_CATEGORY | 类别:这个 activity 应该在 TabActivity 中作为一个 tab 使用。 "android.intent.category.TAB" |
String TEMPLATE_EXTRA | 附加数据:新记录的初始化模板。 "android.intent.extra.TEMPLATE" |
String TEST_CATEGORY | 类别:作为测试目的使用,不是正常的用户体验的一部分。 "android.intent.category.TEST" |
String TIMEZONE_CHANGED_ACTION | 广播:时区已经改变。 "android.intent.action.TIMEZONE_CHANGED" |
String TIME_CHANGED_ACTION | 广播:时间已经改变(重新设置)。 "android.intent.action.TIME_SET" |
String TIME_TICK_ACTION | 广播:当前时间已经变化(正常的时间流逝)。 "android.intent.action.TIME_TICK" |
String UMS_CONNECTED_ACTION | 广播:设备进入 USB 大容量存储模式。 "android.intent.action.UMS_CONNECTED" |
String UMS_DISCONNECTED_ACTION | 广播:设备从 USB 大容量存储模式退出。 "android.intent.action.UMS_DISCONNECTED" |
String UNIT_TEST_CATEGORY | 类别:应该被用作单元测试(通过 test harness 运行)。 "android.intent.category.UNIT_TEST" |
String VIEW_ACTION | 动作:向用户显示数据。 "android.intent.action.VIEW" |
String WALLPAPER_CATEGORY | 类别:这个 activity 能过为设备设置墙纸。 "android.intent.category.WALLPAPER" |
String WALLPAPER_CHANGED_ACTION | 广播:系统的墙纸已经改变。 "android.intent.action.WALLPAPER_CHANGED" |
String WALLPAPER_SETTINGS_ACTION | 动作:显示选择墙纸的设置界面。输入:无。 "android.intent.action.WALLPAPER_SETTINGS" |
String WEB_SEARCH_ACTION | 动作:执行 web 搜索。 "android.intent.action.WEB_SEARCH" |
String XMPP_CONNECTED_ACTION | 广播:XMPP 连接已经被建立。 "android.intent.action.XMPP_CONNECTED" |
String XMPP_DISCONNECTED_ACTION | 广播:XMPP 连接已经被断开。 "android.intent.action.XMPP_DISCONNECTED" |
方法
Intent addCategory(String category) | 向 intent 添加新的类别。 |
Intent addLaunchFlags(int flags) | 向 intent 添加新的启动标记。 |
boolean filterEquals(Intent other) | 判断两个 intent 是否相等:检查他们是否有完全相同的意图(用于过滤)。 |
int filterHashCode() | 生成 intent 的哈希代码,该代码与 filterEquals 有同样的语义,即能用于进行 intent 比较。 |
String getAction() | 获取 intent 要执行的动作,如:VIEW_ACTION。 |
Set getCategories() | 获取 intent 对象所属的所有类别(集合)。 |
ComponentName getComponent() | 获取 intent 关联的具体组件。 |
ContentURI getData() | 获取 intent 对象要操作的数据 (URI)。 |
Object getExtra(String name, Object def) | 获取 intent 的扩展数据。 |
Object getExtra(String name) | 获取 intent 的扩展数据。 |
Bundle getExtras() | 获取 intent 的扩展数据 map。 |
static Intent getIntent(String uri) | 由 URI 创建 Intent。 |
int getLaunchFlags() | 获取 intent 的所有启动标记。 |
String getScheme() | 获取 intent 中数据的 sheme。 |
String getType() | 获取 intent 明确声明的数据类型(显式声明的 MIME 类型,不是推导出来的类型)。 |
boolean hasCategory(String category) | Intent 是否指定了类别。 |
Intent putExtra(String name, Object value) | 向 intent 添加扩展数据。 |
void putExtras(Intent src) | 将 src 中的所有扩展数据复制到 intent 中。 |
void putExtras(Bundle extras) | 向 intent 添加扩展数据。 |
void readFromParcel(Parcel in) | 无。 |
void removeCategory(String category) | 从 intent 删除一个类别。 |
void removeExtra(String name) | 从 intent 删除扩展数据。 |
ComponentName resolveActivity(PackageManager pm) | 取得用来处理这个 intent 的 activity 组件。 |
ActivityInfo resolveActivityInfo(PackageManager pm) | 取得用来处理这个 intent 的 activity 的信息 (PackageManager.ActivityInfo)。 |
String resolveType(ContentResolver resolver) | 取得 intent 的 MIME 数据类型。(判断顺序:intent 明确指定的类型;intent 数据隐式包含的数据类型) |
String resolveType(Context context) | 取得 intent 的 MIME 数据类型。(判断顺序:intent 明确指定的类型;intent 数据隐式包含的数据类型) |
String resolveTypeIfNeeded(ContentResolver resolver) | 如果 resolver 需要,返回 intent 的数据类型,否则返回空。 |
Intent setAction(String action) | 设置 intent 要执行的动作。 |
Intent setClass(Context packageContext, Class cls) | 设置运行 intent 的组件,和 setComponent 功能相同。 |
Intent setClassName(String packageName, String className) | 设置运行 intent 的组件,和 setComponent 功能相同。 |
Intent setClassName(Context packageContext, String className) | 设置运行 intent 的组件,和 setComponent 功能相同。 |
Intent setComponent(ComponentName component) | 设置运行 intent 的组件。 |
Intent setData(ContentURI data) | 设置处理 intent 的时候要操作的数据。 |
Intent setDataAndType(ContentURI data, String type) | 设置 intent 的数据和数据类型 (MIME)。 |
Intent setLaunchFlags(int flags) | 设置启动标记(用来控制 intent 被处理的方式)。 |
Intent setType(String type) | 设置明确的 MIME 数据类型。 |
String toString() | 为 intent 生成一个可读的字符串描述。 |
String toURI() | 无 |
void writeToParcel(Parcel out) | 无 |
Service
服务是在后台长时间运行的应用组件,不和用户直接进行交互。在每一个服务类的包的 AndroidManifest.xml 文件中,必须有一个相应的 <service> 声明。
服务必须用 Context.startService() 或者 Context.bindService() 启动。
和其它应用对象一样,服务运行在它们宿主进程的主线程里。这意味着,如果一个服务需要执行阻塞操作(比如网络操作)或者 CPU 敏感的操作(比如 MP3播放器),
它应该分离出一个线程来执行这样的操作。
=======================================================================
显示网页:
- Uri uri = Uri.parse("http://www.google.com");
- Intent it = new Intent(Intent.ACTION_VIEW,uri);
- startActivity(it);
显示地图:
- Uri uri = Uri.parse("geo:38.899533,-77.036476");
- Intent it = new Intent(Intent.Action_VIEW,uri);
- startActivity(it);
路径规划:
- Uri uri = Uri.parse("http://maps.google.com/maps?f=d&saddr=startLat%20startLng&daddr=endLat%20endLng&hl=en");
- Intent it = new Intent(Intent.ACTION_VIEW,URI);
- startActivity(it);
拨打电话:调用拨号程序
- Uri uri = Uri.parse("tel:xxxxxx");
- Intent it = new Intent(Intent.ACTION_DIAL, uri);
- startActivity(it);
- Uri uri = Uri.parse("tel.xxxxxx");
- Intent it =new Intent(Intent.ACTION_CALL,uri);
- //要使用这个必须在配置文件中加入<uses-permission id="android.permission.CALL_PHONE" />
发送SMS/MMS, 调用发送短信的程序
- Intent it = new Intent(Intent.ACTION_VIEW);
- it.putExtra("sms_body", "The SMS text");
- it.setType("vnd.android-dir/mms-sms");
- startActivity(it);
发送短信
- Uri uri = Uri.parse("smsto:0800000123");
- Intent it = new Intent(Intent.ACTION_SENDTO, uri);
- it.putExtra("sms_body", "The SMS text");
- startActivity(it);
发送彩信
- Uri uri = Uri.parse("content://media/external/images/media/23");
- Intent it = new Intent(Intent.ACTION_SEND);
- it.putExtra("sms_body", "some text");
- it.putExtra(Intent.EXTRA_STREAM, uri);
- it.setType("image/png");
- startActivity(it);
发送Email
- Uri uri = Uri.parse("mailto:xxx@abc.com");
- Intent it = new Intent(Intent.ACTION_SENDTO, uri);
- startActivity(it);
- Intent it = new Intent(Intent.ACTION_SEND);
- it.putExtra(Intent.EXTRA_EMAIL, "me@abc.com");
- it.putExtra(Intent.EXTRA_TEXT, "The email body text");
- it.setType("text/plain");
- startActivity(Intent.createChooser(it, "Choose Email Client"));
- Intent it=new Intent(Intent.ACTION_SEND);
- String[] tos={"me@abc.com"};
- String[] ccs={"you@abc.com"};
- it.putExtra(Intent.EXTRA_EMAIL, tos);
- it.putExtra(Intent.EXTRA_CC, ccs);
- it.putExtra(Intent.EXTRA_TEXT, "The email body text");
- it.putExtra(Intent.EXTRA_SUBJECT, "The email subject text");
- it.setType("message/rfc822");
- startActivity(Intent.createChooser(it, "Choose Email Client"));
- //添加附件
- Intent it = new Intent(Intent.ACTION_SEND);
- it.putExtra(Intent.EXTRA_SUBJECT, "The email subject text");
- it.putExtra(Intent.EXTRA_STREAM, "file:///sdcard/mysong.mp3");
- sendIntent.setType("audio/mp3");
- startActivity(Intent.createChooser(it, "Choose Email Client"));
播放多媒体
- Intent it = new Intent(Intent.ACTION_VIEW);
- Uri uri = Uri.parse("file:///sdcard/song.mp3");
- it.setDataAndType(uri, "audio/mp3");
- startActivity(it);
- Uri uri = Uri.withAppendedPath(MediaStore.Audio.Media.INTERNAL_CONTENT_URI, "1");
- Intent it = new Intent(Intent.ACTION_VIEW, uri);
- startActivity(it);
Uninstall 程序
- Uri uri = Uri.fromParts("package", strPackageName, null);
- Intent it = new Intent(Intent.ACTION_DELETE, uri);
- startActivity(it);
install apk
- Uri installUri = Uri.fromParts("package", "xxx", null);
- returnIt = new Intent(Intent.ACTION_PACKAGE_ADDED, installUri);