在本文中,您将会了解到关于onActivityResult()不适用于Android的新资讯,同时我们还将为您解释onactivityresult不执行的相关在本文中,我们将带你探索onActivit
在本文中,您将会了解到关于onActivityResult() 不适用于 Android的新资讯,同时我们还将为您解释onactivityresult不执行的相关在本文中,我们将带你探索onActivityResult() 不适用于 Android的奥秘,分析onactivityresult不执行的特点,并给出一些关于android activity fragment onactivityResult问题、Android Activity Results API代替onActivityResult处理页面数据、android onActivityResult、Android onActivityResult intent==null的实用技巧。
本文目录一览:- onActivityResult() 不适用于 Android(onactivityresult不执行)
- android activity fragment onactivityResult问题
- Android Activity Results API代替onActivityResult处理页面数据
- android onActivityResult
- Android onActivityResult intent==null
onActivityResult() 不适用于 Android(onactivityresult不执行)
如何解决onActivityResult() 不适用于 Android?
我正在尝试使用 onActivityResult 发送标题,我已经查看了相同任务的 google 实现,但它对我不起作用。有人可以帮忙吗?
mainActivity 中 onActivityResult 的代码。
public void onActivityResult(int requestCode,int resultCode,Intent data){
super.onActivityResult(requestCode,resultCode,data);
System.out.println("There is something coming to this function" + requestCode);
if(requestCode == NEW_TITLE_ACTIVITY_REQUEST_CODE && resultCode == RESULT_OK){
Title title = new Title(data.getStringExtra(notesSection.EXTRA_REPLY));
mTitleviewmodel.insert(title);
}else{
Toast.makeText(getApplicationContext(),R.string.empty_not_saved,Toast.LENGTH_LONG).show();
}
}
我的notesSection活动中的代码。
finishFab.setonClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
// System.out.println("Button Has Been Clicked From Notes Section");
Intent replyIntent = new Intent();
if (TextUtils.isEmpty(titleEdit.getText())){
// System.out.println("Empty?");
setResult(RESULT_CANCELED,replyIntent);
}else{
// System.out.println("Sending Something Supposedly");
String title = titleEdit.getText().toString();
// System.out.println("Sending " + title);
replyIntent.putExtra(EXTRA_REPLY,title);
setResult(RESULT_OK,replyIntent);
}
finish();
// startActivity(new Intent(notesSection.this,MainActivity.class));
}
});
仅供参考:当我在 onActivityResult 函数中打印某些内容时,我的运行终端上没有显示任何内容,我不知道为什么会这样,但我认为由于某种原因没有到达该函数。如有必要,我将发送更多代码。 谢谢。
解决方法
在你的第一个活动中尝试像这样开始第二个活动
static int NEW_TITLE_ACTIVITY_REQUEST_CODE = 1;
@Override
protected void onCreate(Bundle savedInstanceState) {
---
---
---
// i assume you are starting activity on some button click
// so add following line in you button on click event
startActivityForResult(new Intent(MainActivity.this,notesSection.class),NEW_TITLE_ACTIVITY_REQUEST_CODE);
}
然后在您的第一个活动中覆盖以下方法
@Override
public void onActivityResult(int requestCode,int resultCode,@Nullable Intent data) {
if (resultCode == Activity.RESULT_OK && requestCode == NEW_TITLE_ACTIVITY_REQUEST_CODE)
{
// do whatever you want
}
}
同时在点击监听器上更新你的完成工厂
finishFab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Intent replyIntent = new Intent();
if (TextUtils.isEmpty(titleEdit.getText())){
setResult(RESULT_CANCELED,replyIntent);
}
else{
replyIntent.putExtra("TITLE",titleEdit.getText().toString());
setResult(RESULT_OK,replyIntent);
}
finish();
}
});
,
实际上,这个程序最近发生了变化。您可能需要查看 official documentation,以便您可以根据需要实施它。
android activity fragment onactivityResult问题
fragment 收不到 onActivityResult的问题
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
}
若activity 中返回true,则fragment就无法收到了
Android Activity Results API代替onActivityResult处理页面数据
onActivityResult
@SuppressWarnings("deprecation") @Override @CallSuper protected void onActivityResult(int requestCode, int resultCode, @Nullable Intent data) { mFragments.noteStateNotSaved(); super.onActivityResult(requestCode, resultCode, data); }
Activity Results API的使用
在最新beta版本中谷歌推荐使用Activity Results API来处理页面数据的处理。通过新的 Activity Result API,我们可以单独的类中处理结果回调,真正做到 单一职责 。
1.在app下的build.gradle中加入依赖:
implementation ''androidx.activity:activity-ktx:1.2.0-beta01''
implementation ''androidx.fragment:fragment-ktx:1.3.0-beta01''
2.自定义ActivityResultContract
自定义ActivityResultContract,用来处理两个activity互传数据的处理,替代onActivityResult方法 其中ActivityResultContract<String, String>第一个泛型参数表示输入的参数类型,即要带到下一个Activity的数据类型, 第二个泛型参数表示输出参数类型,即第二个Activity回传第一个Activity的数据类型。
class CustomActivityResultContract : ActivityResultContract<String, String>() { override fun createIntent(context: Context, input: String?): Intent { //要传到下一个activity中的数据,从A activity中带到B activity中的数据。 return Intent(context, SecondActivity::class.java).putExtra("name", input) } override fun parseResult(resultCode: Int, intent: Intent?): String { //从activity回传的数据 val result = intent?.getStringExtra("result") //从B activity中回传的数据。 if (resultCode == Activity.RESULT_OK && result != null) { return "$result" } return "" } }
3.注册ActivityResult协议
在A activity中注册ActivityResult协议,使用我们刚刚定义的CustomActivityResultContract。
registerForActivityResult方法有两个参数,第一个参数是传入对应的Contract,第二个参数是回调结果callback。
private val activityLauncher = registerForActivityResult(CustomActivityResultContract()) { //第二个页面关闭后回到第一个页面的回调方法 tvName.text = it }
4.调用launch方法开启界面跳转
使用第三步我们生成的启动器对象的launch方法来启动界面跳转,launch方法需要传入一个输入参数,也就是需要带到下一个页面的参数,可以是任意对象:
btnStartSecond.setOnClickListener { //点击跳转到SecondActivity activityLauncher.launch("我是第一个页面传过去的参数") }
5.使用谷歌内置的 ActivityResultContract来进行页面跳转
还可以通过ActivityResultContracts类来调用谷歌为我们内置的Contract,其中包含来各种常用的Contract
- @StartActivityForResult: 通用的Contract,不做任何转换,Intent作为输入,ActivityResult作为输出,这也是最常用的一个协定。
- @RequestMultiplePermissions: 用于请求一组权限
- @RequestPermission: 用于请求单个权限
- @TakePicturePreview: 调用MediaStore.ACTION_IMAGE_CAPTURE拍照,返回值为Bitmap图片
- @TakePicture: 调用MediaStore.ACTION_IMAGE_CAPTURE拍照,并将图片保存到给定的Uri地址,返回true表示保存成功。
- @TakeVideo: 调用MediaStore.ACTION_VIDEO_CAPTURE 拍摄视频,保存到给定的Uri地址,返回一张缩略图。
- @PickContact: 从通讯录APP获取联系人
- @GetContent: 提示用选择一条内容,返回一个通过ContentResolver#openInputStream(Uri)访问原生数据的Uri地址(content://形式) 。默认情况下,它增加了Intent#CATEGORY_OPENABLE, 返回可以表示流的内容。
- @CreateDocument: 提示用户选择一个文档,返回一个(file:/http:/content:)开头的Uri。
- @OpenMultipleDocuments: 提示用户选择文档(可以选择多个),分别返回它们的Uri,以List的形式。
- @OpenDocumentTree: 提示用户选择一个目录,并返回用户选择的作为一个Uri返回,应用程序可以完全管理返回目录中的文档。
一般情况下使用StartActivityForResult就可以满足大部分需求啦。
private val activityResultLauncher = registerForActivityResult(ActivityResultContracts.StartActivityForResult()) { if (it.resultCode == RESULT_OK) { val result = intent?.getStringExtra("result") tvName.text = result } } btnStartSecond.setOnClickListener { //点击跳转到SecondActivity val intent = Intent(this, SecondActivity::class.java) intent.putExtra("name", "我是第一个页面传过去的参数") activityResultLauncher.launch(intent) }
使用系统内置的ActivityResultContract可以很方便的实现页面间传值来,这样也可以实现解偶操作了。
到此这篇关于Android Activity Results API代替onActivityResult处理页面数据的文章就介绍到这了,更多相关Android Activity Results API内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
- Android Activity View加载与绘制流程深入刨析源码
- Android Activity启动流程刨析
- Android开发Activity毛玻璃背景效果
- Android开发Activity的生命周期详解
- Android巧用Fragment解耦onActivityResult详解
- Android中两个类让你再也不用实现onActivityResult()
- Android onActivityResult和setResult方法详解及使用
android onActivityResult
android onActivityResult 在 activityfinish 后居然不调用,onActivityResult 居然在 activity 初始化的Android onActivityResult intent==null
首先我先描述一下常规步骤:
1.启动一个新activity
startActivityForResult(intent, 3);
2.结束新启动的activity 放置数据
Intent intent = new Intent();
intent.putExtra("isDel", false);
setResult(Activity.RESULT_OK, intent);
3.接收数据
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
if (requestCode == 3 ) {
data.getBooleanExtra("isDel", false);
//你的操作
}
}
今天遇到的问题是 在第三步 无法获取 data ,data一直为null
怎么回呢 第一次使用就出问题,不太甘心,又看了一遍代码,发现了问题所在,
我在填写数据之前,调用了 this.finish(); 看来我还是有些粗心!大家注意不要犯这个小错误~,错误虽然低级,但是也要防着点!
祝大家code no bug!
今天关于onActivityResult() 不适用于 Android和onactivityresult不执行的讲解已经结束,谢谢您的阅读,如果想了解更多关于android activity fragment onactivityResult问题、Android Activity Results API代替onActivityResult处理页面数据、android onActivityResult、Android onActivityResult intent==null的相关知识,请在本站搜索。
本文标签: