- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我的 RecyclerView 包含非常复杂的项目、多个按钮/图像/文本。为了访问每个按钮/图像,我在适配器类中设置了点击监听器。
但是现在我正在尝试添加设置联系人铃声的功能,但我遇到了问题。
我这样调用 onActivityResult 方法:
Intent contactIntent = new Intent(Intent.ACTION_PICK);
contactIntent.setType(ContactsContract.Contacts.CONTENT_TYPE);
contactIntent.putExtra("ITEM_POSITION", position);
((Activity) context).startActivityForResult(contactIntent, CONTACT_CHOOSER_ACTIVITY_CODE );
而且效果很好。但问题是:
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
switch (requestCode) {
....
...
...
}
}
我收到此错误:无法解析方法 'onActivityResult(int, int, android.content.Intent)'
有什么办法可以避免这种情况吗?或者是否可以在适配器类中使用此方法?如果不是我该怎么办?
最佳答案
你不能在任何 Adapter 类中使用它,这只是 Activity
中的一个方法,每个 extends Activity
的类都可以覆盖这个方法,但肯定不是适配器。
请参阅Overrides在Java中
对于 onActivityResult
,请参阅 Activity#onActivityResult(int, int, Intent)
对于像 RecyclerView.Adapter
这样的东西,您需要在您的适配器中定义一个接口(interface)并在您的 Activity 中实现该接口(interface)。
例如,这里是一个应用程序的代码,它将点击的项目及其位置的字符串发送到显示它的新 Activity:
主要 Activity :
public class MainActivity extends AppCompatActivity implements MyAdapter.CallbackInterface {
private static final int MY_REQUEST = 1001;
private static final String [] ITEMS = {"Item 1", "Item 2", "Item 3" ,"Item 4", "Item 5", "Item 6"};
private MyAdapter myAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// ... Adapter setup, simple LinearLayoutManager and String [] used
RecyclerView recyclerView = (RecyclerView) findViewById(R.id.rec_view);
myAdapter = new MyAdapter(this, ITEMS);
recyclerView.setHasFixedSize(true);
recyclerView.setLayoutManager(new LinearLayoutManager(this));
recyclerView.setAdapter(myAdapter);
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
switch(resultCode){
case RESULT_OK:
// ... Check for some data from the intent
if(requestCode == MY_REQUEST){
// .. lets toast again
int position = -1;
if(data != null){
position = data.getIntExtra("Position", 0);
}
if(position != -1) {
Toast.makeText(this, "Handled the result successfully at position " + position, Toast.LENGTH_SHORT).show();
}else{
Toast.makeText(this, "Failed to get data from intent" , Toast.LENGTH_SHORT).show();
}
}
break;
case RESULT_CANCELED:
// ... Handle this situation
break;
}
}
/**
* Interface Method which communicates to the Acitivty here from the {@link MyAdapter}
* @param position - the position
* @param text - the text to pass back
*/
@Override
public void onHandleSelection(int position, String text) {
Toast.makeText(this, "Selected item in list "+ position + " with text "+ text, Toast.LENGTH_SHORT).show();
// ... Start a new Activity here and pass the values
Intent secondActivity = new Intent(MainActivity.this, DetailActivity.class);
secondActivity.putExtra("Text",text);
secondActivity.putExtra("Position", position);
startActivityForResult(secondActivity, MY_REQUEST);
}
}
MainActivity 的 xml:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.divshark.recyclerviewsimpledemo.MainActivity">
<android.support.v7.widget.RecyclerView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/rec_view" />
</RelativeLayout>
我的适配器:
public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyHolder>{
private CallbackInterface mCallback;
private String [] mMyItems;
private Context mContext;
public interface CallbackInterface{
/**
* Callback invoked when clicked
* @param position - the position
* @param text - the text to pass back
*/
void onHandleSelection(int position, String text);
}
public MyAdapter(Context context, String [] myItems){
mContext = context;
mMyItems = myItems;
// .. Attach the interface
try{
mCallback = (CallbackInterface) context;
}catch(ClassCastException ex){
//.. should log the error or throw and exception
Log.e("MyAdapter","Must implement the CallbackInterface in the Activity", ex);
}
}
@Override
public int getItemCount() {
return mMyItems.length;
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public void onBindViewHolder(MyHolder holder, final int position) {
// Set the text for the View
holder.mTextView.setText(mMyItems[position]);
// Use your listener to pass back the data
holder.itemView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(mCallback != null){
mCallback.onHandleSelection(position, mMyItems[position]);
}
}
});
}
@Override
public MyHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = LayoutInflater.from(mContext).inflate(R.layout.list_item, parent, false);
return new MyHolder(view);
}
static class MyHolder extends RecyclerView.ViewHolder{
TextView mTextView;
public MyHolder(View itemView) {
super(itemView);
mTextView = (TextView) itemView.findViewById(R.id.tv_list_item);
}
}
}
适配器的布局:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="?listPreferredItemHeight">
<TextView
android:id="@+id/tv_list_item"
android:textColor="@android:color/black"
tools:text="Some Text Holder"
android:layout_marginLeft="16dp"
android:textSize="18sp"
android:layout_centerVertical="true"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</RelativeLayout>
和 DetailActivity:
public class DetailActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.detail_activity);
TextView textView = (TextView) findViewById(R.id.tv_detail_text);
if(getIntent() != null && getIntent().getExtras() != null) {
Bundle extras = getIntent().getExtras();
String text = extras.getString("Text");
int position = extras.getInt("Position");
textView.setText(String.format("%s at position %d", text, position));
// .. For this purpose set result okay and use position as part of data when Activity finishes
// Which will in turn invoke the onActivityResult method in the calling activity
Intent resultIntent = new Intent();
resultIntent.putExtra("Position", position);
setResult(RESULT_OK, resultIntent);
}
}
}
Detail Activity 的布局:
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent" android:layout_height="match_parent">
<TextView
android:id="@+id/tv_detail_text"
android:layout_gravity="center"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</FrameLayout>
祝你好运,编码愉快!
关于android - 适配器类中的 super.onActivityResult?安卓,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34340703/
问题比较Java,但是我想在Android中实现: 假设有 3 个或更多类相互扩展: class A { ... int color; ... } class B extend
我知道标题听起来有点奇怪,但这正是我愿意做的。简单解释:A类是B类的子类,B类也是C类的子类>. 现在,所有这些类都包含方法m()。在我的 A 类中,这是我唯一可以访问的类,因为其他类仅在运行时可用,
我有一个 UIViewController 类 A 和 B。 A 使用以下方式加载 B:[A.view addSubView B.view]。 B 有一个带有“后退”按钮的导航栏。我想在单击时返回到
我有以下(第三方)类结构。我们将调用第三方项目 ProjectSeriously,并注意我使用 System.out.println 代替其他复杂的功能(100 行代码) . class A {
在下面的代码中,我从 Game 扩展了 MyGame。我有两个问题: 我们是否需要为所有render()、dispose()、pause()调用super方法 和 resize(w,h)?很多人都没有
例如,假设我想在调用 super.viewDidLoad() 时跳过一级。所以我希望能够做这样的事情: override func viewDidLoad() { super.super.vi
public class Faculty extends Employee { public static void main(String[] args) { new Fac
假设我有: class Superclass { //fields... methodA() {...} methodB() {...} ... } class Subclass exte
这个问题在这里已经有了答案: Why is super.super.method(); not allowed in Java? (22 个答案) 关闭 9 年前。 我怀疑我想做的事情是否可行。我有
我有一个实现 Initializable 的类。 public abstract class ExampleClass implements Initializable { public vo
我想知道,我有这个大数组,是否可以只在内存中使用一次而不是每个线程一次?以 stackoverflow 上的标签为例。他们几乎从不改变,为什么不为他们留下一个内存点呢?甚至可能将该数组永久保存在内存中
假设这三个类具有这个简单的层次结构: class A { func foo() { print("A") } } class B: A { override fu
有没有办法在 TypeScript 中调用 super.super.methodName。我想避免调用super.methodName,但我想调用二祖的methodName方法。 谢谢。 最佳答案 T
这个问题已经有答案了: When do I use super()? (11 个回答) 已关闭 7 年前。 package Geometry; public abstract class Geomet
我必须执行and()在我的实现 Predicate 的业务对象上. 出现问题的代码是 and() 行调用: Predicate predicate = new M
我有一个实现接口(interface)的抽象父类(super class): public abstract class FooMatrix implements Matrix { publi
我有四个 UIView:viewA 是 Root View ,它有 viewB 作为它的 subview 。 viewB 将 viewC 作为其 subview ,而 viewC 将 viewD 作为
有什么区别: class Child(SomeBaseClass): def __init__(self): super(Child, self).__init__() 和:
我有一个通用接口(interface) interface ListList extends List> .由于某些原因,我无法转换 ListList至 List> .有什么方法可以做到吗?为什么它不
我想调用带有两个参数的父类(super class)的构造函数,所以我调用了 super(arguments),但是编译器说: “类 Person 中的构造函数 Person 不能应用于给定类型; 要
我是一名优秀的程序员,十分优秀!