(1)闹钟
-
创建闹钟(ACTION_SET_ALARM)
示例Intent:
public void createAlarm(String message, int hour, int minutes)
{
Intent intent = new Intent(AlarmClock.ACTION_SET_ALARM)
.putExtra(AlarmClock.EXTRA_MESSAGE, message) //用于标识闹钟的自定义消息
.putExtra(AlarmClock.EXTRA_HOUR, hour) //闹钟的小时
.putExtra(AlarmClock.EXTRA_MINUTES, minutes); //闹钟的分钟
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
注:为了调用ACTION_SET_ALARM,应用必须在清单文件中注册SET_ALARM权限:
<uses-permission android:name="com.android.alarm.permission.SET_ALARM" />
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.SET_ALARM" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
-
创建定时器(ACTION_SET_TIMER)
示例Intent:
public void startTimer(String message, int seconds)
{
Intent intent = new Intent(AlarmClock.ACTION_SET_TIMER)
.putExtra(AlarmClock.EXTRA_MESSAGE, message) //用于标识定时器的自定义消息
.putExtra(AlarmClock.EXTRA_LENGTH, seconds) //以秒为单位的定时器定时长度
.putExtra(AlarmClock.EXTRA_SKIP_UI, true); //一个布尔型值,用于指定响应定时器的应用在设置定时器时是否应跳过其 UI。
//若为 true,则应用应跳过任何确认 UI,直接启动指定的定时器。
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
注:为了调用ACTION_SET_TIMER,应用必须在清单文件中注册SET_ALARM权限:
<uses-permission android:name="com.android.alarm.permission.SET_ALARM" />
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.SET_TIMER" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
-
显示所有闹铃(ACTION_SHOW_ALARMS)
尽管调用此 Intent 的应用并不多(使用它的主要是系统应用),但任何充当闹钟的应用都应实现此 Intent 过滤器,并通过显示现有闹铃列表作出响应。
注:此 Intent 是在 Android 4.4(API 级别 19)中添加的。
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.SHOW_ALARMS" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
(2)日历
-
添加日历事件
(使用 ACTION_INSERT操作,并指定具有 Events.CONTENT_URI的数据 URI)
示例 Intent:
public void addEvent(String title, String location, Calendar begin, Calendar end)
{
Intent intent = new Intent(Intent.ACTION_INSERT)
.setData(Events.CONTENT_URI) //指定内容URI
.putExtra(Events.TITLE, title) //事件标题
.putExtra(Events.EVENT_LOCATION, location) //事件地点
.putExtra(CalendarContract.EXTRA_EVENT_BEGIN_TIME, begin) //事件的开始时间(从新纪年开始计算的毫秒数)
.putExtra(CalendarContract.EXTRA_EVENT_END_TIME, end); //事件的结束时间(从新纪年开始计算的毫秒数)
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.INSERT" />
<data android:mimeType="vnd.android.cursor.dir/event" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
(3)相机
-
拍摄照片或视频并将其返回
( ACTION_IMAGE_CAPTURE 或 ACTION_VIDEO_CAPTURE)
如需打开相机应用并接收拍摄的照片或视频,可使用 ACTION_IMAGE_CAPTURE或 ACTION_VIDEO_CAPTURE操作。此外,还可在 EXTRA_OUTPUT extra 中指定希望相机将照片或视频保存到的 URI 位置。
示例 Intent:
static final int REQUEST_IMAGE_CAPTURE = 1;
static final Uri mLocationForPhotos;
public void capturePhoto(String targetFilename)
{
Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); //使用相机拍照
intent.putExtra(MediaStore.EXTRA_OUTPUT, //设置相机应用应将照片或视频文件保存到的 URI 位置
Uri.withAppendedPath(mLocationForPhotos, targetFilename));
if (intent.resolveActivity(getPackageManager()) != null) //确认存在对应Activity组件再开启
{
//通过startActivityForResult获得Intent中返回缩小尺寸的照片副本(缩略图)
startActivityForResult(intent, REQUEST_IMAGE_CAPTURE);
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == RESULT_OK)
{
//拍照获得的副本(缩略图)以Bitmap形式保存在名为 "data"的 extra 字段中
Bitmap thumbnail = data.getParcelable("data");//获得副本Bitmap
//此外,还可以通过URI访问原始尺寸的照片或视频,该URI为上面通过EXTRA_OUTPUT设置的URI
// Do other work with full size photo saved in mLocationForPhotos
...
}
}
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.media.action.IMAGE_CAPTURE" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
处理此 Intent 的Activity 应检查传入Intent中有无EXTRA_OUTPUT extra,然后将拍摄的图像或视频保存在该 extra 指定的位置,并调用带Intent的setResult(),该 Intent 将经过压缩的缩略图包括在名为 "data"的 extra中,注意相关权限的注册。
-
以静态图像或视频模式启动相机应用(INTENT_ACTION_STILL_IMAGE_CAMERA或INTENT_ACTION_VIDEO_CAMERA)
假如仅仅是调用系统照相机拍照,不关心拍照结果,则可用静态图像模式下启动相机,该action所启动的Intent只是打开相机,不做任何处理,且将停留在相机应用里,拍完一张照片后不返回原来的应用,并将照片保存到系统的默认照片保存路径。
示例 Intent:
public void capturePhoto()
{
Intent intent = new Intent(MediaStore.INTENT_ACTION_STILL_IMAGE_CAMERA);
//Intent intent = new Intent(MediaStore.INTENT_ACTION_VIDEO_CAMERA);
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivityForResult(intent); //确认存在对应Activity组件再开启
}
}
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<!--若为视频模式此处应为"android.media.action.VIDEO_CAMERA"-->
<action android:name="android.media.action.STILL_IMAGE_CAMERA" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
(4)联系人
-
选择联系人
(使用ACTION_PICK操作,并将 MIME 类型指定为Contacts.CONTENT_TYPE)
示例 Intent:
static final int REQUEST_SELECT_CONTACT = 1;
public void selectContact()
{
Intent intent = new Intent(Intent.ACTION_PICK);
intent.setType(ContactsContract.Contacts.CONTENT_TYPE);
if (intent.resolveActivity(getPackageManager()) != null)
{
//回调的结果Intent包含指向所选联系人的 content:URI,
//响应会利用Contacts Provide API 为我们的应用授予该联系人的临时读取权限,
//即使我们的应用不具READ_CONTACTS权限也没有关系。
startActivityForResult(intent, REQUEST_SELECT_CONTACT); //确认存在对应Activity组件再开启
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == REQUEST_SELECT_CONTACT && resultCode == RESULT_OK)
{
Uri contactUri = data.getData(); //取出包含指向所选联系人的 content:URI,读取该联系人的详情并不需要READ_CONTACTS权限
// Do something with the selected contact at contactUri
...
}
}
-
选择特定联系人数据(使用ACTION_PICK操作,并指定特定 MIME 类型)
如需让用户选择某一条联系人信息,如电话号码、电子邮件地址或其他数据类型,需使用ACTION_PICK操作,并指定MIME 类型为下列其中一个内容类型:
- CommonDataKinds.Phone.CONTENT_TYPE——从有电话号码的联系人中选取
- CommonDataKinds.Email.CONTENT_TYPE——从有电子邮件地址的联系人中选取
- CommonDataKinds.StructuredPostal.CONTENT_TYPE——从有邮政地址的联系人中选取
- ContactsContract下众多其他 CONTENT_TYPE值中的一个
如果只需要检索一种类型的联系人数据,则此方法要比上一部分中使用的MIME 类型Contacts.CONTENT_TYPE更高效,因为结果可让我们直接访问所需数据,无需对联系人提供程序执行更复杂的查询。
示例 Intent:
static final int REQUEST_SELECT_PHONE_NUMBER = 1;
public void selectContact()
{
// Start an activity for the user to pick a phone number from contacts
Intent intent = new Intent(Intent.ACTION_PICK);
intent.setType(CommonDataKinds.Phone.CONTENT_TYPE);//从有电话号码的联系人中选取
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivityForResult(intent, REQUEST_SELECT_PHONE_NUMBER); //确认存在对应Activity组件再开启
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == REQUEST_SELECT_PHONE_NUMBER && resultCode == RESULT_OK)
{
Uri contactUri = data.getData(); //得到指向所选联系人数据的 content:URI
String[] projection = new String[]{CommonDataKinds.Phone.NUMBER};
Cursor cursor = getContentResolver().query(contactUri, projection,
null, null, null); //从联系人提供程序中查询电话号码
if (cursor != null && cursor.moveToFirst()) { //若cursor的返回值有效,取出查询到的电话号码
int numberIndex = cursor.getColumnIndex(CommonDataKinds.Phone.NUMBER);
String number = cursor.getString(numberIndex);
//对取出的电话号码进行一些操作
...
}
}
}
由于查询出来的cursor的初始位置是指向第一条记录的前一个位置的,故使用cursor.moveToFirst()函数来指向查询结果的第一个位置。一般通过判断cursor.moveToFirst()的值为true或false来确定查询结果是否为空。
-
查看联系人(使用ACTION_VIEW操作,并使用 content:URI 作为 Intent 数据指定联系人)
初次检索联系人URI 的方法主要有两种:
- 使用ACTION_PICK返回的联系人 URI,如上述所示(此方法不需要任何应用权限)
- 直接访问所有联系人的列表(此方法需要 READ_CONTACTS权限)
示例 Intent:
public void viewContact(Uri contactUri)
{
Intent intent = new Intent(Intent.ACTION_VIEW, contactUri);//无需指定MIME类型,该类型可以从联系人URI中推断得出
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent);
}
}
-
编辑现有联系人(ACTION_EDIT操作+data+extra)
如需编辑已知联系人,需使用ACTION_EDIT操作,使用 content:URI 作为 Intent 数据指定联系人,并将 extra 中由常量指定的任何已知联系人信息包括在ContactsContract.Intents.Insert中
示例 Intent:
public void editContact(Uri contactUri, String email)
{
Intent intent = new Intent(Intent.ACTION_EDIT);
intent.setData(contactUri);
//可使用ContactsContract.Intents.Insert中定义的一个或多个extra,来填充联系人详情字段
intent.putExtra(Intents.Insert.EMAIL, email);
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
-
插入联系人(ACTION_INSERT操作+type+extra)
如需插入新联系人,需使用ACTION_INSERT操作,将Contacts.CONTENT_TYPE指定为 MIME 类型,并将 extra 中由常量指定的任何已知联系人信息包括在ContactsContract.Intents.Insert中。
示例 Intent:
public void insertContact(String name, String email)
{
Intent intent = new Intent(Intent.ACTION_INSERT);
intent.setType(Contacts.CONTENT_TYPE);
//可使用ContactsContract.Intents.Insert中定义的一个或多个extra
intent.putExtra(Intents.Insert.NAME, name);
intent.putExtra(Intents.Insert.EMAIL, email);
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
(5)电子邮件
-
撰写带有可选附件的电子邮件
如需撰写电子邮件,可根据其是否包括附件使用以下其中一项操作(action):
- ACTION_SENDTO(适用于不带附件)
- ACTION_SEND(适用于带一个附件)
- ACTION_SEND_MULTIPLE(适用于带多个附件)
并使用下列 extra 键加入收件人和主题等电子邮件详情: - Intent.EXTRA_EMAIL
包含所有“主送”收件人电子邮件地址的字符串数组。 - Intent.EXTRA_CC
包含所有“抄送”收件人电子邮件地址的字符串数组。 - Intent.EXTRA_BCC
包含所有“密件抄送”收件人电子邮件地址的字符串数组。 - Intent.EXTRA_SUBJECT
包含电子邮件主题的字符串。 - Intent.EXTRA_TEXT
包含电子邮件正文的字符串。 - Intent.EXTRA_STREAM
指向附件的 Uri。如果使用的是 ACTION_SEND_MULTIPLE 操作,应将其改为包含多个 Uri对象的 ArrayList。
示例 Intent:
public void composeEmail(String[] addresses, String subject, Uri attachment)
{
Intent intent = new Intent(Intent.ACTION_SEND);
intent.setType("*/*");
intent.putExtra(Intent.EXTRA_EMAIL, addresses);
intent.putExtra(Intent.EXTRA_SUBJECT, subject);
intent.putExtra(Intent.EXTRA_STREAM, attachment);
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
如果您想确保 Intent 只由电子邮件应用(而非其他短信或社交应用)进行处理,则需使用 ACTION_SENDTO操作并加入 "mailto:"数据架构。例如:
public void composeEmail(String[] addresses, String subject)
{
Intent intent = new Intent(Intent.ACTION_SENDTO);
intent.setData(Uri.parse("mailto:")); // 只有电子邮件应用才能处理
intent.putExtra(Intent.EXTRA_EMAIL, addresses);
intent.putExtra(Intent.EXTRA_SUBJECT, subject);
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.SEND" />
<data android:type="*/*" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
<intent-filter>
<action android:name="android.intent.action.SENDTO" />
<data android:scheme="mailto" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
(6)文件存储
-
检索特定类型的文件(ACTION_GET_CONTENT操作+type)
如需请求用户选择文档或照片等文件并向我们的应用返回文件引用,需使用ACTION_GET_CONTENT操作并指定所需 MIME 类型。 返回的文件引用对 Activity 的当前生命周期而言是瞬态引用,因此如果想稍后进行访问,就必须导入可在稍后读取的副本。用户还可利用此 Intent 在进程中创建新文件(例如,用户可以不选择现有照片,而是用相机拍摄新照片)。
传送至onActivityResult()方法的结果 Intent 包括的数据具有指向该文件的 URI。该 URI 可以是任何类型,如 http:URI、file:URI 或 content:URI。 不过,如果想将可选择的文件限定为可从内容提供程序 (content:URI) 访问的文件,以及通过openFileDescriptor()以文件流形式提供的文件,则应该为 Intent 添加CATEGORY_OPENABLE类别。
在 Android 4.3(API 级别 18)及更高版本上,我们还可以通过为 Intent 添加EXTRA_ALLOW_MULTIPLE并将其设置为 true,允许用户选择多个文件。然后我们就可以在getClipData()返回的ClipData对象中访问每一个选定的文件。
用于获取照片的示例 Intent:
static final int REQUEST_IMAGE_GET = 1;public void selectImage()
{
Intent intent = new Intent(Intent.ACTION_GET_CONTENT);
intent.setType("image/*");
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivityForResult(intent, REQUEST_IMAGE_GET); //确认存在对应Activity组件再开启
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == REQUEST_IMAGE_GET && resultCode == RESULT_OK)
{
Bitmap thumbnail = data.getParcelable("data");
Uri fullPhotoUri = data.getData();
// Do work with photo saved at fullPhotoUri
...
}
}
用于返回照片的示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.GET_CONTENT" />
<data android:type="image/*" />
<category android:name="android.intent.category.DEFAULT" />
<category android:name="android.intent.category.OPENABLE" />
</intent-filter>
</activity>
-
打开特定类型的文件
(ACTION_OPEN_DOCUMENT或ACTION_CREATE_DOCUMENT,并指定 MIME 类型)
如果只想读取现有文件而不将其副本导入我们的应用,或者想就地打开和编辑文件,特别适合使用ACTION_OPEN_DOCUMENT操作(而不是使用ACTION_GET_CONTENT来导入应用的文件副本)。如果还需要允许用户创建应用可写入的新文档,可改用 ACTION_CREATE_DOCUMENT操作
注意: Intent 必须指定 MIME 类型,并且必须声明CATEGORY_OPENABLE类别。必要时,还可以使用EXTRA_MIME_TYPES extra 添加一个 MIME 类型数组来指定多个 MIME 类型——但这种情况下必须将setType()中的主 MIME 类型设置为 "*/*" - 用于获取照片的示例 Intent:
static final int REQUEST_IMAGE_OPEN = 1;
public void selectImage()
{
Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT);
intent.setType("image/*");
intent.addCategory(Intent.CATEGORY_OPENABLE);
//只有系统能接收到ACTION_OPEN_DOCUMENT, 所以此处不需要判断Activity是否存在
startActivityForResult(intent, REQUEST_IMAGE_OPEN);
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data)
{
if (requestCode == REQUEST_IMAGE_OPEN && resultCode == RESULT_OK)
{
Uri fullPhotoUri = data.getData();
// Do work with full size photo saved at fullPhotoUri
...
}
}
第三方应用实际上无法通过ACTION_OPEN_DOCUMENT操作响应 Intent,而是由系统接收此 Intent,然后在统一用户界面中显示各类应用提供的所有文件。
如需在该用户界面中提供我们的应用的文件,并允许其他应用打开它们,则必须实现一个DocumentsProvider,并加入一个PROVIDER_INTERFACE Intent 过滤器("android.content.action.DOCUMENTS_PROVIDER")。例如:
<provider ...
android:grantUriPermissions="true"
android:exported="true"
android:permission="android.permission.MANAGE_DOCUMENTS">
<intent-filter>
<action android:name="android.content.action.DOCUMENTS_PROVIDER" />
</intent-filter>
</provider>
(7)本地操作
-
叫车( ACTION_RESERVE_TAXI_RESERVATION操作)
示例 Intent:
public void callCar()
{
Intent intent = new Intent(ReserveIntents.ACTION_RESERVE_TAXI_RESERVATION);
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="com.google.android.gms.actions.RESERVE_TAXI_RESERVATION" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
-
地图(使用ACTION_VIEW操作,并在Intent 数据中指定位置信息)
指定位置信息表示方式有多种,这里举一个最简单的示例:"geo:47.6,-122.3",表示显示给定经度和纬度处的地图
示例 Intent:
public void showMap(Uri geoLocation)
{
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setData(geoLocation);
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<data android:scheme="geo" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
-
播放媒体文件(使用ACTION_VIEW操作,并在Intent 数据中指定位置信息)
示例 Intent:
public void playMedia(Uri file)
{
Intent intent = new Intent(Intent.ACTION_VIEW);
intent.setData(file);
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.VIEW" />
<data android:type="audio/*" />
<data android:type="application/ogg" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
-
拨打电话
(使用ACTION_DIAL或ACTION_CALL操作,并使用数据URI指定电话号码)
使用ACTION_DIAL操作拨打电话,会打开电话应用并显示电话号码,但用户必需按拨打电话按钮才能开始通话。
如需直接拨打电话,需使用ACTION_CALL操作,并使用数据URI指定电话号码。电话应用打开时便会拨打电话,用户无需按拨打电话按钮。ACTION_CALL操作需要在清单文件中添加 CALL_PHONE权限:<uses-permission android:name="android.permission.CALL_PHONE" />
示例 Intent:
public void dialPhoneNumber(String phoneNumber)
{
Intent intent = new Intent(Intent.ACTION_DIAL);
intent.setData(Uri.parse("tel:" + phoneNumber));
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
-
发送短信
(ACTION_SENDTO、ACTION_SEND或ACTION_SEND_MULTIPLE操作+extra)
如需发起短信或彩信,需使用ACTION_SENDTO(无附件发送)、ACTION_SEND(带附件的发送)或ACTION_SEND_MULTIPLE(带多个附件的发送)其中一个 Intent 操作,并使用下列 extra 键指定电话号码、主题和消息正文等消息详情。
示例 Intent:
public void composeMmsMessage(String message, Uri attachment)
{
Intent intent = new Intent(Intent.ACTION_SENDTO);
intent.setType(HTTP.PLAIN_TEXT_TYPE);
intent.putExtra("sms_body", message); //表示消息正文的字符串
intent.putExtra(Intent.EXTRA_STREAM, attachment); //指向附件的图像或视频的Uri
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
如果想确保 Intent 只由短信应用(而非其他电子邮件或社交应用)进行处理,则需使用ACTION_SENDTO操作并设置data "smsto:"。例如:
public void composeMmsMessage(String message, Uri attachment)
{
Intent intent = new Intent(Intent.ACTION_SEND);
intent.setData(Uri.parse("smsto:")); //确保只有短信应用进行处理
intent.putExtra("sms_body", message); //表示消息正文的字符串
intent.putExtra(Intent.EXTRA_STREAM, attachment); //指向附件的图像或视频的Uri
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent); //确认存在对应Activity组件再开启
}
}
示例 Intent 过滤器:
<activity ...>
<intent-filter>
<action android:name="android.intent.action.SEND" />
<data android:type="text/plain" />
<data android:type="image/*" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
-
设置
如需在应用要求用户更改内容时打开某个系统设置屏幕,可使用下列其中一个 Intent 操作打开与操作名称对应的设置屏幕:
- ACTION_SETTINGS
- ACTION_WIRELESS_SETTINGS
- ACTION_AIRPLANE_MODE_SETTINGS
- ACTION_WIFI_SETTINGS
- ACTION_APN_SETTINGS
- ACTION_BLUETOOTH_SETTINGS
- ACTION_DATE_SETTINGS
- ACTION_LOCALE_SETTINGS
- ACTION_INPUT_METHOD_SETTINGS
- ACTION_DISPLAY_SETTINGS
- ACTION_SECURITY_SETTINGS
- ACTION_LOCATION_SOURCE_SETTINGS
- ACTION_INTERNAL_STORAGE_SETTINGS
- ACTION_MEMORY_CARD_SETTINGS
示例 Intent:
public void openWifiSettings()
{
Intent intent = new Intent(Intent.ACTION_WIFI_SETTINGS); //打开Wifi设置界面
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent);
}
}
-
执行网页搜索(使用ACTION_WEB_SEARCH操作,并在extra中指定搜索字符串)
示例 Intent:
public void searchWeb(String query)
{
Intent intent = new Intent(Intent.ACTION_WEB_SEARCH);
intent.putExtra(SearchManager.QUERY, query);//在SearchManager.QUERY extra 中指定搜索字符串
if (intent.resolveActivity(getPackageManager()) != null)
{
startActivity(intent);
}
}