前言

  这篇博客将举例说明Intent各种各样的用法.

判断Intent是否为null

if (intent.resolveActivity(getPackageManager())!=null) { //判断Intent是否为null
// Intent不为空
}else{
// Intent为空
}

判断Intent的指定Key是否为空

if(intent.hasExtra("key")){
//查看有没有指定的key
}

清除Intent里指定key里面的值

intent.removeExtra("key");//清除intent里指定key里面的值

更新Intent

在一些特殊情况下,比如在多次向上向下重复传值的情况或者在使用singleTask的启动模式的情况,在activity可能依然保存之前Intent,这个时候我们就需要更新Intent,以保证我们使用的是最新的Intent 里面有最新的值:

//操作很简单,我们只需要在我们需要更新Intent的activity里面重写onNewIntent方法,
//并且将里面的intent导入setIntent以更新我们整个活动的activity,
//这个方法在活动从暂停到恢复时会自动调用
@Override
protected void onNewIntent(Intent intent) {
super.onNewIntent(intent);
setIntent(intent);
}

Intent传值

//传值方法
Intent intent = new Intent(OneActivity.this,TwoActivity.class);
intent.putExtra("key","value"); //key 和 值
startActivity(intent);
//取值方法
Intent getIntentData = getIntent();
String value = getIntentData.getStringExtra("key");

Intent使用Bundle传值

public static String [] PhoneAndTime = new String[2];
//new 新的Intent
Intent data = new Intent(MainActivity.this, Demo_1.class);
//用Bundle 携带数组
Bundle bundle = new Bundle();
bundle.putStringArray("phone_data", PhoneAndTime);
//将 data Intent 添加Bundle
data.putExtras(bundle);
startActivity(data); //取值方法
Bundle bundle = this.getIntent().getExtras();
String [] data = bundle.getStringArray("phone_data");

Intent传递实体类(序列化)

首先要序列化我们需要传递的实体类,接口 implements Serializable 来实现类的序列化.注意!内部类无法序列化

public class DemoBase implements Serializable {
private Integer type;
private String content; public Integer getType() {
return type;
} public void setType(Integer type) {
this.type = type;
} public String getContent() {
return content;
} public void setContent(String content) {
this.content = content;
}
}

传出

DemoBase base = new DemoBase();
base.setType(1);
base.setContent("内容");
Intent intent = new Intent(MainActivity.this, DemoActivity.class);
intent.putExtra("DemoBase", base);
startActivity(intent);

接收

Intent intent = getIntent();
DemoBase base = (DemoBase) intent.getSerializableExtra("DemoBase");

第二种 Android的序列化Parcelable

public class DemoDataBean implements Parcelable {
private String id; protected DemoDataBean(Parcel in) {
id = in.readString();
} public static final Creator<DemoDataBean> CREATOR = new Creator<DemoDataBean>() {
@Override
public DemoDataBean createFromParcel(Parcel in) {
return new DemoDataBean(in);
} @Override
public DemoDataBean[] newArray(int size) {
return new DemoDataBean[size];
}
}; public String getId() {
return id;
} public void setId(String id) {
this.id = id;
} @Override
public int describeContents() {
return 0;
} @Override
public void writeToParcel(Parcel dest, int flags) {
dest.writeString(id);
}
}

Intent向上传值

//首先我们假设有一个OneActivity 和 TwoActivity ,现在OneActivity启动TwoActivity后,我们希望TwoActivity给OneActivity传值(这个传值过程就叫向上传值)

//首先在OneActivity里发送数据请求码
Intent intent = new Intent(OneActivity.this,TwoActivity.class);
startActivityForResult(intent,1);//第二个值是请求码Key
//--------------------------TwoActivity里的操作--------------------------------
//向上传值
Intent intent = new Intent();
intent.putExtra("key","value");
setResult(RESULT_OK,intent);//第一个参数是系统的KEY ,判断传值是否成功
finish();
//-------------------OneActivity里的数据回调操作(重写这个方法)------------------------

@Override   //参数解释 第一个参数:请求码回调,第二个参数是系统KEY的处理结果,第三个参数携带了数据的Intent
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
switch (requestCode){
case ENTER_GALLERY:
if(resultCode == RESULT_OK){
//参数TwoActivity活动传值的KEY
String value = data.getStringExtra("key"); }
break;
default:
break;
}
super.onActivityResult(requestCode, resultCode, data);
}

Intent数据请求与数据回调

数据请求

//点击后进入相机
public void enterCamera(){
//MediaStore 多媒体存储 ACTION活动 IMAGE 图片 CAPTURW捕获
Intent intentGallery = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
/* 多媒体存储,额外制造 从文件里获取路径(获取外部存储目录 图片名称head.jpg)
将图片设置名称并且保存到外部存储空间里
*/
File file = new File(mImageFilePath);
if (!file.exists()){
file.mkdirs();
}
intentGallery.putExtra(MediaStore.EXTRA_OUTPUT,
Uri.fromFile(new File(file, mTempImage)));
//跳转页面启动相册,携带数据请求码
startActivityForResult(intentGallery,ENTER_CAMERA);
}

数据回调

/*
从Intent中返回请求数据的方法,活动退出后运行这个方法(注意这个方法,是在需要回调值的activity里重写的方法)
*/
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
switch (requestCode){
/*
相册选中图片后的数据回调
*/
case ENTER_GALLERY: //请求码
if(resultCode == RESULT_OK){ //RESULT_OK 系统默认成功键值
cropPhoto(data.getData()); // 裁剪图片
}
break; .........

intent是经常要用到页面牵转,传递数据,调用外部程序,系统功能等等,下面是一些常用intent示例

从google搜索内容

Intent intent = new Intent();
intent.setAction(Intent.ACTION_WEB_SEARCH);
intent.putExtra(SearchManager.QUERY,"searchString")
startActivity(intent);

浏览网页

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=dsaddr=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);

跳转到联系人

    Intent intentPhone = new Intent(Intent.ACTION_CALL, Uri.parse("tel:" + phoneNumber));
startActivity(intentPhone);

调用发短信的程序

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);
String body="this is sms demo";
Intent mmsintent = new Intent(Intent.ACTION_SENDTO, Uri.fromParts("smsto", number, null));
mmsintent.putExtra(Messaging.KEY_ACTION_SENDTO_MESSAGE_BODY, body);
mmsintent.putExtra(Messaging.KEY_ACTION_SENDTO_COMPOSE_MODE, true);
mmsintent.putExtra(Messaging.KEY_ACTION_SENDTO_EXIT_ON_SENT, true);
startActivity(mmsintent);

发送彩信

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);
StringBuilder sb = new StringBuilder();
sb.append("file://");
sb.append(fd.getAbsoluteFile());
Intent intent = new Intent(Intent.ACTION_SENDTO, Uri.fromParts("mmsto", number, null));
// Below extra datas are all optional.
intent.putExtra(Messaging.KEY_ACTION_SENDTO_MESSAGE_SUBJECT, subject);
intent.putExtra(Messaging.KEY_ACTION_SENDTO_MESSAGE_BODY, body);
intent.putExtra(Messaging.KEY_ACTION_SENDTO_CONTENT_URI, sb.toString());
intent.putExtra(Messaging.KEY_ACTION_SENDTO_COMPOSE_MODE, composeMode);
intent.putExtra(Messaging.KEY_ACTION_SENDTO_EXIT_ON_SENT, exitOnSent);
startActivity(intent);

发送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 apk卸载Apk

Uri uri = Uri.fromParts("package", strPackageName, null);
Intent it = new Intent(Intent.ACTION_DELETE, uri);
startActivity(it);

install apk安装Apk

    private void installApk(String path) {
Intent intent = new Intent(Intent.ACTION_VIEW);
File apkFile = new File(path); if(Build.VERSION.SDK_INT>= Build.VERSION_CODES.N) {
Uri contentUri = FileProvider.getUriForFile(mContext,mContext.getPackageName()+".provider",apkFile);
intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.addFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION);
intent.setDataAndType(contentUri,
"application/vnd.android.package-archive");
}else{ intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
intent.setDataAndType(Uri.fromFile(apkFile),"application/vnd.android.package-archive"); }
mContext.startActivity(intent);
}

打开照相机

            Intent i = new Intent(Intent.ACTION_CAMERA_BUTTON, null);
this.sendBroadcast(i);
long dateTaken = System.currentTimeMillis();
String name = createName(dateTaken) + ".jpg";
fileName = folder + name;
ContentValues values = new ContentValues();
values.put(Images.Media.TITLE, fileName);
values.put("_data", fileName);
values.put(Images.Media.PICASA_ID, fileName);
values.put(Images.Media.DISPLAY_NAME, fileName);
values.put(Images.Media.DESCRIPTION, fileName);
values.put(Images.ImageColumns.BUCKET_DISPLAY_NAME, fileName);
Uri photoUri = getContentResolver().insert(
MediaStore.Images.Media.EXTERNAL_CONTENT_URI, values); Intent inttPhoto = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
inttPhoto.putExtra(MediaStore.EXTRA_OUTPUT, photoUri);
startActivityForResult(inttPhoto, 10);

从gallery图库选取图片

方式1:

申请

Intent i = new Intent();
i.setType("image/*");
i.setAction(Intent.ACTION_GET_CONTENT);
startActivityForResult(i, GALLERY_RESULT_CODE);

返回

    @Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == GALLERY_RESULT_CODE && resultCode == RESULT_OK) {
Uri uri = data.getData();
try {
InputStream inputStream = getContentResolver().openInputStream(uri);
} catch (FileNotFoundException e) {
e.printStackTrace();
}
}
}

方式2:

申请

Intent intent = new Intent();
intent.setType("image/*");
intent.setDataAndType(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, "image/*");
getActivity().startActivityForResult(intent, GALLERY_RESULT_CODE);

返回

    @Override
protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) {
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == GALLERY_RESULT_CODE && resultCode == RESULT_OK){
Uri uri = data.getData();
Log.e("调试_临时_log", "this_" + uri.getPath());
String filePath = uri.getPath();
}
}

打开录音机

Intent mi = new Intent(Media.RECORD_SOUND_ACTION);
startActivity(mi);

显示应用详细列表

Uri uri = Uri.parse("market://details?id=app_id");
Intent it = new Intent(Intent.ACTION_VIEW, uri);
startActivity(it);
//where app_id is the application ID, find the ID
//by clicking on your application on Market home
//page, and notice the ID from the address bar

寻找应用

Uri uri = Uri.parse("market://search?q=pname:pkg_name");
Intent it = new Intent(Intent.ACTION_VIEW, uri);
startActivity(it);
//where pkg_name is the full package path for an application

打开联系人列表

            <1>
Intent i = new Intent();
i.setAction(Intent.ACTION_GET_CONTENT);
i.setType("vnd.android.cursor.item/phone");
startActivityForResult(i, REQUEST_TEXT); <2>
Uri uri = Uri.parse("content://contacts/people");
Intent it = new Intent(Intent.ACTION_PICK, uri);
startActivityForResult(it, REQUEST_TEXT);

打开其他应用

            Intent i = new Intent();
ComponentName cn = new ComponentName("com.yellowbook.android2",
"com.yellowbook.android2.AndroidSearch");
i.setComponent(cn);
i.setAction("android.intent.action.MAIN");
startActivityForResult(i, RESULT_OK);

调用系统编辑添加联系人(高版本SDK有效)

Intent it = newIntent(Intent.ACTION_INSERT_OR_EDIT);
it.setType("vnd.android.cursor.item/contact");
//it.setType(Contacts.CONTENT_ITEM_TYPE);
it.putExtra("name","myName");
it.putExtra(android.provider.Contacts.Intents.Insert.COMPANY, "organization");
it.putExtra(android.provider.Contacts.Intents.Insert.EMAIL,"email");
it.putExtra(android.provider.Contacts.Intents.Insert.PHONE,"homePhone");
it.putExtra(android.provider.Contacts.Intents.Insert.SECONDARY_PHONE,
"mobilePhone");
it.putExtra( android.provider.Contacts.Intents.Insert.TERTIARY_PHONE,
"workPhone");
it.putExtra(android.provider.Contacts.Intents.Insert.JOB_TITLE,"title");
startActivity(it);

调用系统编辑添加联系人(全有效)

Intent intent = newIntent(Intent.ACTION_INSERT_OR_EDIT);
intent.setType(People.CONTENT_ITEM_TYPE);
intent.putExtra(Contacts.Intents.Insert.NAME, "My Name");
intent.putExtra(Contacts.Intents.Insert.PHONE, "+1234567890"); intent.putExtra(Contacts.Intents.Insert.PHONE_TYPE,Contacts.PhonesColumns.TYPE_MOBILE);
intent.putExtra(Contacts.Intents.Insert.EMAIL, "com@com.com");
intent.putExtra(Contacts.Intents.Insert.EMAIL_TYPE, Contacts.ContactMethodsColumns.TYPE_WORK);
startActivity(intent);

裁剪图片

Intent intent = new Intent(Intent.ACTION_GET_CONTENT, null);
intent.setType("image/*"); //这个参数是确定要选择的内容为图片,
intent.putExtra("crop", "circle"); //设置了参数,就会调用裁剪,如果不设置,就会跳过裁剪的过程。
intent.putExtra("aspectX", 33); //这个是裁剪时候的 裁剪框的 X 方向的比例。
intent.putExtra("aspectY",43); //同上Y 方向的比例. (注意: aspectX, aspectY ,两个值都需要为 整数,如果有一个为浮点数,就会导致比例失效。)
//设置aspectX 与 aspectY 后,裁剪框会按照所指定的比例出现,放大缩小都不会更改。如果不指定,那么 裁剪框就可以随意调整了。
intent.putExtra("outputX", 50); //返回数据的时候的 X 像素大小。
intent.putExtra("outputY", 100); //返回的时候 Y 的像素大小。
//以上两个值,设置之后会按照两个值生成一个Bitmap, 两个值就是这个bitmap的横向和纵向的像素值,如果裁剪的图像和这个像素值不符合,那么空白部分以黑色填充。
intent.putExtra("noFaceDetection", true); // 是否去除面部检测, 如果你需要特定的比例去裁剪图片,那么这个一定要去掉,因为它会破坏掉特定的比例。
intent.putExtra("return-data", true); //是否要返回值。 一般都要。我第一次忘加了,总是取得空值,囧!
startActivityForResult(intent, 1);

intent action大全

    android.intent.action.ALL_APPS
android.intent.action.ANSWER
android.intent.action.ATTACH_DATA
android.intent.action.BUG_REPORT
android.intent.action.CALL
android.intent.action.CALL_BUTTON
android.intent.action.CHOOSER
android.intent.action.CREATE_LIVE_FOLDER
android.intent.action.CREATE_SHORTCUT
android.intent.action.DELETE
android.intent.action.DIAL
android.intent.action.EDIT
android.intent.action.GET_CONTENT
android.intent.action.INSERT
android.intent.action.INSERT_OR_EDIT
android.intent.action.MAIN
android.intent.action.MEDIA_SEARCH
android.intent.action.PICK
android.intent.action.PICK_ACTIVITY
android.intent.action.RINGTONE_PICKER
android.intent.action.RUN
android.intent.action.SEARCH
android.intent.action.SEARCH_LONG_PRESS
android.intent.action.SEND
android.intent.action.SENDTO
android.intent.action.SET_WALLPAPER
android.intent.action.SYNC
android.intent.action.SYSTEM_TUTORIAL
android.intent.action.VIEW
android.intent.action.VOICE_COMMAND
android.intent.action.WEB_SEARCH
android.net.wifi.PICK_WIFI_NETWORK
android.settings.AIRPLANE_MODE_SETTINGS
android.settings.APN_SETTINGS
android.settings.APPLICATION_DEVELOPMENT_SETTINGS
android.settings.APPLICATION_SETTINGS
android.settings.BLUETOOTH_SETTINGS
android.settings.DATA_ROAMING_SETTINGS
android.settings.DATE_SETTINGS
android.settings.DISPLAY_SETTINGS
android.settings.INPUT_METHOD_SETTINGS
android.settings.INTERNAL_STORAGE_SETTINGS
android.settings.LOCALE_SETTINGS
android.settings.LOCATION_SOURCE_SETTINGS
android.settings.MANAGE_APPLICATIONS_SETTINGS
android.settings.MEMORY_CARD_SETTINGS
android.settings.NETWORK_OPERATOR_SETTINGS
android.settings.QUICK_LAUNCH_SETTINGS
android.settings.SECURITY_SETTINGS
android.settings.SETTINGS
android.settings.SOUND_SETTINGS
android.settings.SYNC_SETTINGS
android.settings.USER_DICTIONARY_SETTINGS
android.settings.WIFI_IP_SETTINGS
android.settings.WIFI_SETTINGS
android.settings.WIRELESS_SETTINGS

附录

String

"android.intent.action.ADD_SHORTCUT"

动作:在系统中添加一个快捷方式。.

String

"android.intent.action.ALL_APPS"

动作:列举所有可用的应用。

String

"android.intent.action.ANSWER"

动作:处理拨入的电话。

String

"android.intent.action.BUG_REPORT"

动作:显示 activity 报告错误。

String

"android.intent.action.CALL"

动作:拨打电话,被呼叫的联系人在数据中指定。

String

"android.intent.action.CLEAR_CREDENTIALS"

动作:清除登陆凭证 (credential)。

String

"android.intent.action.VIEW"

动作:和 VIEW_ACTION 相同,是在数据上执行的标准动作。

String

"android.intent.action.DELETE"

动作:从容器中删除给定的数据。

String

"android.intent.action.DIAL"

动作:拨打数据中指定的电话号码。

String

"android.intent.action.EDIT"

动作:为制定的数据显示可编辑界面。

String

"android.intent.action.EMERGENCY_DIAL"

动作:拨打紧急电话号码。

String

"android.intent.action.LOGIN"

动作:获取登录凭证。

String

"android.intent.action.MAIN"

动作:作为主入口点启动,不需要数据。

String

"android.intent.action.PICK"

动作:从数据中选择一个项目item,将被选中的项目返回。

String

"android.intent.action.PICK_ACTIVITY"

动作:选择一个activity,返回被选择的activity的类名

String

"android.intent.action.RUN"

动作:运行数据(指定的应用),无论它(应用)是什么。

String

"android.intent.action.SENDTO"

动作:向 data 指定的接收者发送一个消息。

String

"android.intent.action.GET_CONTENT"

动作:让用户选择数据并返回。

String

"android.intent.action.INSERT"

动作:在容器中插入一个空项 (item)。

String

"android.intent.action.SETTINGS"

动作:显示系统设置。输入:无。

String

"android.intent.action.VIEW"

动作:向用户显示数据。

String

"android.intent.action.WALLPAPER_SETTINGS"

动作:显示选择墙纸的设置界面。输入:无。

String

"android.intent.action.WEB_SEARCH"

动作:执行 web 搜索。

String

"android.intent.action.SYNC"

动作:执行数据同步。

String

"android.intent.action.SERVICE_STATE"

广播:电话服务的状态已经改变。

String

"android.intent.action.TIMEZONE_CHANGED"

广播:时区已经改变。

String

"android.intent.action.TIME_SET"

广播:时间已经改变(重新设置)。

String

"android.intent.action.TIME_TICK"

广播:当前时间已经变化(正常的时间流逝)。

String

"android.intent.action.UMS_CONNECTED"

广播:设备进入 USB 大容量存储模式。

String

"android.intent.action.UMS_DISCONNECTED"

广播:设备从 USB 大容量存储模式退出。

String

"android.intent.action.WALLPAPER_CHANGED"

广播:系统的墙纸已经改变。

String

"android.intent.action.XMPP_CONNECTED"

广播:XMPP 连接已经被建立。

String

"android.intent.action.XMPP_DI

广播:XMPP 连接已经被断开。

String

"android.intent.action.SIG_STR"

广播:电话的信号强度已经改变。

String

"android.intent.action.BATTERY_CHANGED"

广播:充电状态,或者电池的电量发生变化。

String

"android.intent.action.BOOT_COMPLETED"

广播:在系统启动后,这个动作被广播一次(只有一次)

String

"android.intent.action.DATA_ACTIVITY"

广播:电话的数据活动(data activity)状态已经改变

String

"android.intent.action.DATA_STATE"

广播:电话的数据连接状态已经改变。

String

"android.intent.action.DATE_CHANGED"

广播:日期被改变。

String

"android.server.checkin.FOTA_CANCEL"

广播:取消所有被挂起的 (pending) 更新下载。

String

"android.server.checkin.FOTA_INSTALL"

广播:更新已经被确认,马上就要开始安装。

String

"android.server.checkin.FOTA_READY"

广播:更新已经被下载,可以开始安装。

String

"android.server.checkin.FOTA_RESTART"

广播:恢复已经停止的更新下载。

String

"android.server.checkin.FOTA_UPDATE"

广播:通过 OTA 下载并安装操作系统更新。

String

"android.intent.action.MEDIABUTTON"

广播:用户按下了“Media Button”。

String

"android.intent.action.MEDIA_BAD_REMOVAL"

广播:扩展卡从SD卡插槽拔出,但是挂载点还没unmount。

String

"android.intent.action.MEDIA_EJECT"

广播:用户想要移除扩展介质(拔掉扩展卡)。

String

"android.intent.action.MEDIA_MOUNTED"

广播:扩展介质被插入,而且已经被挂载。

String

"android.intent.action.MEDIA_REMOVED"

广播:扩展介质被移除。

String

"android.intent.action.MEDIA_SCANNER_FINISHED"

广播:已经扫描完介质的一个目录。

String

"android.intent.action.MEDIA_SCANNER_STARTED"

广播:开始扫描介质的一个目录。

String

"android.intent.action.MEDIA_SHARED"

广播:扩展介质的挂载被解除 (unmount)

String

"android.intent.action.MEDIA_UNMOUNTED"

广播:扩展介质存在,但是还没有被挂载 (mount)。

String

"android.intent.action.MWI"

广播:电话的消息等待(语音邮件)状态已经改变。

String

"android.intent.action.PACKAGE_ADDED"

广播:设备上新安装了一个应用程序包。

String

"android.intent.action.PACKAGE_REMOVED"

广播:设备上删除了一个应用程序包。

String

"android.intent.action.PHONE_STATE"

广播:电话状态已经改变。

String

"android.intent.action.PROVIDER_CHANGED"

广播:更新将要(真正)被安装。

String

"android.intent.action.PROVISIONING_CHECK"

广播:要求provisioning service下载最新的设置

String

"android.intent.action.SCREEN_OFF"

广播:屏幕被关闭。

String

"android.intent.action.SCREEN_ON"

广播:屏幕已经被打开。

String

"android.intent.action.NETWORK_TICKLE_RECEIVED"

广播:设备收到了新的网络 "tickle" 通知。

String

"android.intent.action.STATISTICS_REPORT"

广播:要求 receivers 报告自己的统计信息。

String

"android.intent.action.STATISTICS_STATE_CHANGED"

广播:统计信息服务的状态已经改变。

String

"android.intent.action.CFF"

广播:语音电话的呼叫转移状态已经改变。

String

"android.intent.action.CONFIGURATION_CHANGED"

广播:设备的配置信息已经改变,参见 Resources.Configuration

String

"android.intent.category.ALTERNATIVE"

类别:说明activity是用户正在浏的数据的一个可选操作。

String

"android.intent.category.WALLPAPER"

类别:这个 activity 能过为设备设置墙纸。

String

"android.intent.category.UNIT_TEST"

类别:应该被用作单元测试(通过 test harness 运行)。

String

"android.intent.category.TEST"

类别:作为测试目的使用,不是正常的用户体验的一部分。

String

"android.intent.category.TAB"

类别:activity应该在TabActivity中作为一个tab使用

String

"android.intent.category.SAMPLE_CODE"

类别:To be used as an sample code example (not part of the normal user experience).

String

"android.intent.category.PREFERENCE"

类别:activity是一个设置面板 (preference panel)。

String

"android.intent.category.HOME"

类别:主屏幕 (activity),设备启动后显示的第一个 activity。

String

"android.intent.category.BROWSABLE"

类别:能够被浏览器安全使用的 activities 必须支持这个类别。

String

"android.intent.category.DEFAULT"

类别:如果 activity 是对数据执行确省动作(点击, center press)的一个选项,需要设置这个类别。

String

"android.intent.category.DEVELOPMENT_PREFERENCE"

类别:说明 activity 是一个设置面板 (development preference panel).

String

"android.intent.category.EMBED"

类别:能够在上级(父)activity 中运行。

String

"android.intent.category.FRAMEWORK_INSTRUMENTATION_TEST"

类别:To be used as code under test for framework instrumentation tests.

String

"android.intent.category.GADGET"

类别:这个 activity 可以被嵌入宿主 activity (activity that is hosting gadgets)。

String

"android.intent.category.LAUNCHER"

类别:Activity 应该被显示在顶级的 launcher 中。

String

"android.intent.category.SELECTED_ALTERNATIVE"

类别:对于被用户选中的数据,activity 是它的一个可选操作。

int

8 0x00000008

启动标记:和 NEW_TASK_LAUNCH 联合使用,禁止将已有的任务改变为前景任务 (foreground)。

int

4 0x00000004

启动标记:设置以后,activity 将成为历史堆栈中的第一个新任务(栈顶)。

int

1 0x00000001

启动标记:设置以后,新的 activity 不会被保存在历史堆栈中。

int

2 0x00000002

启动标记:设置以后,如果 activity 已经启动,而且位于历史堆栈的顶端,将不再启动(不重新启动) activity。

int

16 0x00000010

启动标记:如果这个标记被设置,而且被一个已经存在的 activity 用来启动新的 activity,已有 activity 的回复目标 (reply target) 会被转移给新的 activity。

String

"android.intent.extra.INTENT"

附加数据:和 PICK_ACTIVITY_ACTION 一起使用时,说明用户选择的用来显示的 activity;和 ADD_SHORTCUT_ACTION 一起使用的时候,描述要添加的快捷方式。

String

"android.intent.extra.LABEL"

附加数据:大写字母开头的字符标签,和 ADD_SHORTCUT_ACTION 一起使用。

String

"android.intent.extra.TEMPLATE"

附加数据:新记录的初始化模板。

Creator

android 开发 Intent使用技巧点的更多相关文章

  1. Android开发——ListView使用技巧总结(二)

    0.  前言 Android中的ListView是用的比较多的控件之一,在上一篇Android开发--ListView使用技巧总结(一)中对ListView的ViewHolder机制.优化卡顿方式以及 ...

  2. Android开发——ListView使用技巧总结(一)

    )还有一点就是要控制异步任务的执行频率,因为当用户频繁的上下滑动,会瞬间产生上百个异步任务,会带来无意义的大量的UI更新操作,因此可以考虑在列表滑动时停止进行异步任务,直到列表停下来. //判断列表的 ...

  3. Android开发--Intent的使用(1)启动活动

    Android系统是目前世界上市场占有率最高的移动操作系统,近年来,Android开发也越来越炙手可热. 在Android开发中,我们使用Intent进行活动Activity之间穿梭. 当我们点击启动 ...

  4. Android开发Intent应用概述

    原文: http://bbs.gfan.com/android-93448-1-1.html 今天,我们来研究一下Intent,没错,就是前面说过的比较难理解的那个东西,希望通过这篇文章之后,你发现前 ...

  5. Android开发的小技巧,在Android Studio中使用Designtime Layout Attributes

    在编写xml文件时,为了预览效果,经常会使用默认填上一些内容,比如TextView时,随便写上一个text <TextView ... android:text="Name:" ...

  6. Android开发--Intent的应用

    1.概述 Intent负责对应用中一次操作的动作,动作涉及的数据,附加的数据进行描述,起到媒介的作用.通过Intent对象指定一个activity,利用startActivity或 startActi ...

  7. Android 开发-Intent传递普通字符串

    假设A传递id到B中 ActivityA: Intent intent=new Intent();    intent.setClass(ActivityA.this,ActivityB.class) ...

  8. android开发之调试技巧 分类: android 学习笔记 2015-07-18 21:30 140人阅读 评论(0) 收藏

    我们都知道,android的调试打了断点之后运行时要使用debug as->android application 但是这样的运行效率非常低,那么我们有没有快速的方法呢? 当然有. 我们打完断点 ...

  9. android开发之调试技巧

    我们都知道,android的调试打了断点之后运行时要使用debug as->android application 但是这样的运行效率非常低,那么我们有没有快速的方法呢? 当然有. 我们打完断点 ...

随机推荐

  1. .net core WebApi Monitor实现并发同步

    在.net中,还可以使用Monitor实现线程并发同步.Monitor类是纯托管且完全可移植,并且可能会在操作系统资源需求方面更加高效. Monitor的锁对象尽可能使用引用对象,如果是字符串或值对象 ...

  2. mysql-8.0.12-winx64 解压版安装(转)

    1.官网下载 https://dev.mysql.com/downloads/mysql/ 2.解压到一个合适的目录 3.配置环境变量 path : bin的目录(必须配置) MYSQL_HOME:m ...

  3. 移动端H5拍照代码实现及外网部署

    最近的工作中,遇到了一个需求:对于无APP登陆权限的人员,提供拍照上传功能,以便生成更完善的出工记录.经研究讨论,决定实现的机制为:由合法的人员登陆APP认领相关工作任务,并生成当天当工作的唯一二维码 ...

  4. cocos-lua3.17 cocos studio lua动画使用

    这里只贴具体使用代码,资源请使用自己的. 这里的资源是cocos studio导出的lua文件,其中就有root和动画 function GameLayer:playLhAni() local ani ...

  5. TensorFlow 神经网络相关函数

    TensorFlow 激活函数 激活操作提供用于神经网络的不同类型的非线性.这些包括平滑的非线性(sigmoid,tanh,elu,softplus,和softsign),连续的,但不是到处可微函数( ...

  6. BCP导出数据到EXCEL

    SET @FilePath='D:\TEST.xls' SET @sql='bcp "SELECT * FROM XXX.dbo.XXX WITH(NOLOCK) WHERE XXX=''X ...

  7. element-ui Select 清空model,页面没有清空选中项的问题

    业务场景: 在dialog 每次打开时, 选择应用程序要初始化为空. 最初的做法为: 监听dialog的show状态,当show为false时,设置selectApp为空这样写时,虽然selectAp ...

  8. 1.python+appium环境配置

    环境部署 本博客以32位的Windows 7操作系统为例介绍Appium+Python的环境搭建步骤 1.安装Node.js 访问 https://nodejs.org/en/download/,下载 ...

  9. kettle在本地执行向远程hdfs执行转换错误"Couldn't open file hdfs"

    kettle在本地执行向远程hdfs执行转换时,会出现以下错误: ToHDFS.0 - ERROR (version 7.1.0.0-12, build 1 from 2017-05-16 17.18 ...

  10. PTA——洗牌

    PTA 7-43 Shuffling Machine #include<stdio.h> int main() { int i,n,*result; scanf("%d" ...