- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我对我正在处理的应用程序的 RecyclerView 之一的 onClick 方法有疑问。奇怪的是,完全相同的逻辑适用于我的应用程序中的其他 recyclerviews,但这次的不同之处在于我正在解析 JSON 数据(这是我认为我遗漏了一些东西)。在模拟器或我的手机上根本没有检测到 onClick,甚至没有在 log cat 中记录任何内容(我使用的是 Android Studio 1.3.1),所以我完全感到困惑!我相信我在我的 Android list 文件(您将在下面找到)中定义了所有适当的权限和 Intent 过滤器。
这是我想从中触发 Intent 的回收器 View (intent = new Intent(context, AdminTeam.class); 未检测到此 OnClick - 它仅显示带有项目的回收器 View ,然后让我单击在每一行上,但没有任何反应!:
RecyclerViewAdapterNationalCommiitee.java
public class RecyclerViewAdapterNationalCommiitee extends RecyclerView.Adapter<RecyclerViewAdapterNationalCommiitee.MyViewHolder> {
private Context context;
private LayoutInflater inflater;
//private RecyclerViewAdapterAdminTeam ra;
//Variable for the on click Listener
private ClickListener clickListener;
List<SubInformation> data = Collections.emptyList();
//Passing in the array list argument
public RecyclerViewAdapterNationalCommiitee(Context context, List<SubInformation> data) {
this.context = context;
inflater = LayoutInflater.from(context);
//Setting the array list data to the argument passed in
this.data = data;
}
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//Inflating the row and getting the root of view of the custom row natcom (Linear Layout)
View view = inflater.inflate(R.layout.custom_row_natcom, parent, false);
//Passing the root view through as an argument
MyViewHolder holder = new MyViewHolder(view);
//Returning the view holder
return holder;
}
@Override
public void onBindViewHolder(MyViewHolder holder, int position) {
//This will get the current position of the Information object from the Information array
SubInformation current = data.get(position);
holder.title.setText(current.getTitle());
}
//Setting up a click listener which lets me set up an object that implements the interface
public void setClickListener(ClickListener clickListener) {
//Initialising the clickListener
this.clickListener = clickListener;
}
@Override
public int getItemCount() {
return data.size();
}
class MyViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener {
TextView title;
public MyViewHolder(View itemView) {
super(itemView);
//Here setting the id of the textview in the recycler view holder to be the list view from the custom_row xml
title = (TextView) itemView.
findViewById(R.id.listText);
}
@Override
public void onClick(View v) {
Intent intent = null;
switch (getAdapterPosition()) {
case 0:
//Toast.makeText(v.getContext(), "Default Case", Toast.LENGTH_SHORT).show();
//break;
intent = new Intent(context, AdminTeam.class);
//intent.putExtra("JSON Admin", ra.getItemCount());
break;
case 1:
Toast.makeText(v.getContext(), "Default Case", Toast.LENGTH_SHORT).show();
break;
default:
break;
}
//In order for an activity to begin, a context needs to be passed in
//context.startActivity(new Intent(context, Introduction.class));
context.startActivity(intent);
//If the method is not called (Error handling to avoid NULL POINTER EXCEPTION ERROR)
if (clickListener != null) {
//Trigger the appropriate call. getPosition will get the latest position of the item clicked by the user
clickListener.itemClicked(v, getAdapterPosition());
}
}
}
//Here, inside the adapter have made an interface. This interface is implemented in the Tab1 class Fragment.
public interface ClickListener {
void itemClicked(View view, int position);
}
}
国家委员会.java
public class NationalCommittee extends BaseActivity implements RecyclerViewAdapterNationalCommiitee.ClickListener {
private RecyclerView mRecyclerView;
//Creating an instance of the adapter object
private RecyclerViewAdapterNationalCommiitee adapter;
private static final int ITEM_COUNT = 2;
@Override
//public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
protected void onCreate(Bundle savedInstanceState){
super.onCreate(savedInstanceState);
setContentView(R.layout.national_committee);
//final View layout = inflater.inflate(R.layout.national_committee, container, false);
//Calling Activate Toolbar method (with the Back button enabled)
activateToolbarWithHomeEnabled();
//Instantiating the recycler view as defined in national_committee
mRecyclerView=(RecyclerView) findViewById(R.id.natcom_recycler_view);
//Adding item decoration. Recycler view divider
mRecyclerView.addItemDecoration(new DividerItemDecoration(this,DividerItemDecoration.VERTICAL_LIST));
//Initialising the adapter - Passing in the activity and the getData method
adapter=new RecyclerViewAdapterNationalCommiitee(this,getData());
//Here passing in the click listener into the Adapter. 'this' signifies that it is the fragment that handles the click listener.
//This is possible as the on Click Listener interface is being implemented.
adapter.setClickListener(this);
//Setting the adapter
mRecyclerView.setAdapter(adapter);
//Setting the Layout
//mRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity()));
mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
mRecyclerView.setItemAnimator(new DefaultItemAnimator());
//return layout;
}
//Creating an array list of information objects that can be passed into the recycler view
public static List<SubInformation> getData() {
List<SubInformation> data = new ArrayList<>();
//String array of text for the recycler view
String[] text = {"Admin Team", "Team Coordinators"};
//String[] subText = {"What is NHSF?", "Admin Team and Team Coordinators"};
//For loop to go through entire length of the menu string
//for(int i=0; i<menu.length; i++) {
for(int i=0; i<ITEM_COUNT; i++){
//Information current = new Information();
//Information subCurrent = new Information();
//current.title = text[i];
//subCurrent.subtitle = subText[i];
data.add(new SubInformation(text[i]));
}
return data;
}
@Override
public void itemClicked(View view, int position) {
}
}
这是我想从中触发 Intent 的 RecyclerView:
RecyclerViewAdapterAdminTeam.java
public class RecyclerViewAdapterAdminTeam extends RecyclerView.Adapter<RecyclerViewAdapterAdminTeam.MyViewHolder> {
private LayoutInflater inflater;
private AdminTeam activity;
//Variable for the on click Listener
//private ClickListener clickListener;
private List<JSONAdminItem> data = Collections.emptyList();
private Context mContext;
//Passing in the array list argument
public RecyclerViewAdapterAdminTeam(AdminTeam activity, Context context, List<JSONAdminItem> data){
this.mContext = context;
this.activity = activity;
inflater = LayoutInflater.from(context);
//Setting the array list data to the argument passed in
this.data = data;
}
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//Inflating the row and getting the root of view of the custom row natcom (Linear Layout)
View view = inflater.inflate(R.layout.custom_row, parent, false);
//Passing the root view through as an argument
MyViewHolder holder = new MyViewHolder(view);
//Returning the view holder
return holder;
}
@Override
public void onBindViewHolder(MyViewHolder holder, int position) {
//This will get the current position of the JSONAdminItem object from the array
JSONAdminItem adminItem = data.get(position);
//Setting the title to be the Admin Role (converting from JSON)
holder.title.setText(Html.fromHtml(adminItem.getAdminRole()));
//Setting the subtitle to be the Name (converting from JSON)
holder.subTitle.setText(Html.fromHtml(adminItem.getName()));
}
/*
//Setting up a click listener which lets me set up an object that implements the interface
public void setClickListener(ClickListener clickListener){
//Initialising the clickListener
this.clickListener=clickListener;
}
*/
@Override
public int getItemCount() {
return data.size();
//return (null != data ? data.size() : 0);
}
public interface ClickListener {
}
class MyViewHolder extends RecyclerView.ViewHolder {
TextView title;
TextView subTitle;
public MyViewHolder(View itemView) {
super(itemView);
//Here setting the id of the textview in the recycler view holder to be the list view from the custom_row xml
title = (TextView) itemView.
findViewById(R.id.listText);
subTitle = (TextView) itemView.findViewById(R.id.subTitle);
}
/*
@Override
public void onClick(View v) {
}
*/
}
/*
//Here, inside the adapter have made an interface. This interface is implemented in the Tab1 class Fragment.
public interface ClickListener {
void itemClicked(View view, int position);
}
*/
}
在这个类中,我正在做我的 JSON 解析,这是我希望从 RecyclerViewNationalCommittee.java 文件中的 onClick 中获取的类:
AdminTeam.java
public class AdminTeam extends BaseActivity implements RecyclerViewAdapterAdminTeam.ClickListener{
private RecyclerView mRecyclerView;
//Creating an instance of the adapter object
private RecyclerViewAdapterAdminTeam adapter;
private List<JSONAdminItem> AdminTeamList;
private AdminTeam activity;
//private static final int ITEM_COUNT = 5;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.admin_team);
//Calling Activate Toolbar method (with the Back button enabled)
activateToolbarWithHomeEnabled();
//Instantiating the recycler view as defined in admin_team
mRecyclerView = (RecyclerView) findViewById(R.id.adminteam_recycler_view);
//Adding item decoration. Recycler view divider
mRecyclerView.addItemDecoration(new DividerItemDecoration(this, DividerItemDecoration.VERTICAL_LIST));
//Initialising the adapter - Passing in the activity and the parsed Admin Team List
adapter = new RecyclerViewAdapterAdminTeam(activity, this, AdminTeamList);
//Setting the adapter
mRecyclerView.setAdapter(adapter);
//Setting the Layout
//mRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity()));
mRecyclerView.setLayoutManager(new LinearLayoutManager(this));
mRecyclerView.setItemAnimator(new DefaultItemAnimator());
//Downloading data from below url (Universal Resource Locator) to obtain data from the Admin database
final String url = "http://dbchudasama.webfactional.com/jsonscriptAdmin.php";
new AsyncHTTPTask().execute(url);
}
public class AsyncHTTPTask extends AsyncTask<String, Void, Integer> {
@Override
protected Integer doInBackground(String... params) {
Integer result = 0;
HttpURLConnection urlConnection;
try {
URL url = new URL(params[0]);
urlConnection = (HttpURLConnection) url.openConnection();
int statusCode = urlConnection.getResponseCode();
// 200 represents HTTP OK
if (statusCode == 200) {
BufferedReader r = new BufferedReader(new InputStreamReader(urlConnection.getInputStream()));
StringBuilder response = new StringBuilder();
String line;
while ((line = r.readLine()) != null) {
response.append(line);
}
parseResult(response.toString());
result = 1; // Successful
} else {
result = 0; //"Failed to fetch data!";
}
} catch (Exception e) {
Log.d("Exception Caught", e.getLocalizedMessage());
}
return result; //"Failed to fetch data!";
}
@Override
protected void onPostExecute(Integer result) {
super.onPostExecute(result);
//adapter.getItemCount();
if (result == 1) {
//Intent intent = getIntent();
//intent.getSerializableExtra("JSON Admin");
//Initialising the adapter - Passing in the activity and the parsed Admin Team List
adapter = new RecyclerViewAdapterAdminTeam(activity, AdminTeam.this, AdminTeamList);
//Setting the adapter
mRecyclerView.setAdapter(adapter);
} else {
Toast.makeText(AdminTeam.this, "Failed to fetch data!", Toast.LENGTH_SHORT).show();
}
}
}
//This method will parse the RAW data downloaded from the server
private void parseResult(String result) {
try {
//Converting into a JSON Object
JSONObject response = new JSONObject(result);
//Now converting this JSON Object into and a JSON Array
JSONArray AdminArrays = response.getJSONArray("Admin Arrays");
AdminTeamList = new ArrayList<>();
//String[] AdminRole = {};
for (int i = 0; i < AdminArrays.length(); i++) {
JSONObject AdminArrayObject = AdminArrays.getJSONObject(i);
JSONAdminItem item = new JSONAdminItem();
item.setAdminRole(AdminArrayObject.getString("AdminRole"));
item.setName(AdminArrayObject.getString("Name"));
this.AdminTeamList.add(item);
Log.e("Admin Role", AdminArrayObject.getString("AdminRole"));
Log.e("Name", AdminArrayObject.getString("Name"));
}
} catch (JSONException e) {
e.printStackTrace();
}
}
}
这是我的 JSONAdminItem 类文件:
JSONAdminItem.java
public class JSONAdminItem {
private String AdminRole;
private String Name;
public String getAdminRole(){
return AdminRole;
}
public void setAdminRole(String AdminRole) {
this.AdminRole = AdminRole;
}
public String getName(){
return Name;
}
public void setName(String Name) {
this.Name = Name;
}
}
这是我的 AndroidManifest.xml 文件,我在其中添加了相关权限,还添加了所见的 Activity :
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.divyeshbc.NHSF" >
<!-- Parse settings -->
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
<uses-permission android:name="android.permission.WAKE_LOCK" />
<uses-permission android:name="android.permission.VIBRATE" />
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
<uses-permission android:name="android.permission.GET_ACCOUNTS" />
<uses-permission android:name="com.google.android.c2dm.permission.RECEIVE" />
<permission
android:name="com.divyeshbc.NHSF.permission.C2D_MESSAGE"
android:protectionLevel="signature" />
<uses-permission android:name="com.divyeshbc.NHSF.permission.C2D_MESSAGE" />
<!-- -->
<application
android:name=".ParseApplication"
android:allowBackup="true"
android:icon="@mipmap/nhsf_app_logo_androidx144"
android:label="@string/app_name"
android:theme="@style/Theme.Custom" >
<activity
android:name=".SplashActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
<activity
android:name=".MainActivity"
android:label="@string/app_name">
<!--android:parentActivityName=".SplashActivity">
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.divyeshbc.NHSF.SplashActivity" />
-->
<intent-filter>
<action android:name="android.intent.action.MAINACTIVITY" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
<activity
android:name=".tabs.aboutUs.Introduction"
android:label="@string/Introduction"
android:parentActivityName=".MainActivity" >
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.divyeshbc.NHSF.MainActivity" />
<intent-filter>
<action android:name="android.intent.action.ACTION_VIEW" />
<category android:name="android.intent.category.DEFAULT" />
</intent-filter>
</activity>
<activity
android:name=".tabs.aboutUs.NationalCommittee"
android:label="@string/title_activity_natcom"
android:parentActivityName=".MainActivity" >
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.divyeshbc.NHSF.MainActivity" />
</activity>
<activity
android:name=".tabs.aboutUs.AdminTeam"
android:label="@string/title_activity_adminteam"
android:parentActivityName=".tabs.aboutUs.NationalCommittee" >
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.divyeshbc.NHSF.tabs.aboutUs.NationalCommittee" />
</activity>
<!-- Configuring Parse -->
<service android:name="com.parse.PushService" />
<receiver android:name="com.parse.ParseBroadcastReceiver" >
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED" />
<action android:name="android.intent.action.USER_PRESENT" />
</intent-filter>
</receiver>
<receiver
android:name="com.parse.ParsePushBroadcastReceiver"
android:exported="false" >
<intent-filter>
<action android:name="com.parse.push.intent.RECEIVE" />
<action android:name="com.parse.push.intent.DELETE" />
<action android:name="com.parse.push.intent.OPEN" />
</intent-filter>
</receiver>
<receiver
android:name="com.parse.GcmBroadcastReceiver"
android:permission="com.google.android.c2dm.permission.SEND" >
<intent-filter>
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
<action android:name="com.google.android.c2dm.intent.REGISTRATION" />
<category android:name="com.divyeshbc.NHSF" />
</intent-filter>
</receiver>
<!-- -->
<meta-data
android:name="com.divyeshbc.NHSF.notifcation_icon"
android:resource="@mipmap/nhsf_logo_push_android" />
</application>
</manifest>
我不明白为什么没有检测到 RecylerViewAdapterNationalCommiitee.java 中的 onClick。
这很奇怪,因为这个 Intent 有效:
<activity
android:name=".tabs.aboutUs.NationalCommittee"
android:label="@string/title_activity_natcom"
android:parentActivityName=".MainActivity" >
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.divyeshbc.NHSF.MainActivity" />
</activity>
而这不是:
<activity
android:name=".tabs.aboutUs.AdminTeam"
android:label="@string/title_activity_adminteam"
android:parentActivityName=".tabs.aboutUs.NationalCommittee" >
<meta-data
android:name="android.support.PARENT_ACTIVITY"
android:value="com.divyeshbc.NHSF.tabs.aboutUs.NationalCommittee" />
</activity>
任何指导将不胜感激。
谢谢!
最佳答案
您永远不会在列表项上设置任何点击监听器。在 onBindViewHolder
中的每个列表项上设置点击监听器将解决问题:
holder.itemView.setOnClickListener(...
关于java - Intent 的 RecyclerView 中未检测到 OnClick,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33557011/
我在另一个 RecyclerView(parentRecyclerView) 中实现了 RecyclerView(childRecyclerView),图片说明了所有的实现: 我想编写一个 espre
我正在构建一个应用程序,它使用ViewPager2在页面之间水平滚动,每个页面都有一个垂直滚动的内容RecyclerView,其中每个列表的第一个位置都有一行水平滚动小部件,例如附加到寻呼机指示器类型
我正在尝试实现一个水平的 recyclerview 并且 recyclerview 的每个项目都将是一个具有网格布局的垂直 recyclerview。我面临的问题是,当我尝试垂直滚动子 recycle
我使用显示条目列表的 RecyclerView。每个条目都托管另一个 RecyclerView,它是一个图像列表。 我现在想让这个嵌套的 RecyclerView 可点击,而不是它的项目,而是整个 V
我正在尝试将手机中的图像加载到我的回收 View 中。 到目前为止,我已经创建了一个 recyclerview.adapter 和一个 gridlayoutmanager,并将它们附加到我的 recy
我需要一个可扩展 View ,其中父/可扩展标题将具有文本和下拉箭头。每个此类标题的子项应该是在网格结构中具有多个项目的 View 。 (有点像带有 GridLayoutManager 的回收器 Vi
我正在使用显示不同类别列表的 RecyclerView。每行项目还包含 RecyclerView 以显示类别项目列表。父级 RecyclerView 由垂直 LinearLayoutManager 填
我正在更新一个旧的 Android 项目,现在我从 RecyclerView 中反复收到这条日志语句: W/RecyclerView:RecyclerView 不支持滚动到绝对位置。改为使用 scro
在我的 Adapter 中,我调用 LayoutManager.ChildAt(position) 来获取 itemview,但是我得到的 View 不是匹配的 itemview,当我调用 notif
我正在从 ListView 迁移到 RecyclerView,但是在 SQLite 中输入一些数据后,我的列表没有使用 notifyDataSetChanged() 更新;所以我总是要调用setAda
我正在用 Google Now Cards 的风格创建一组 5 张卡片。我首先关注的是总体布局。 我正在使用 CardView 和 RecyclerView ,我想要实现的是这样的: 这是我的 Car
在我的应用程序中,我有一个 RecyclerView,其中包含一个简单的项目 View ,每行包含一个 TextView 和一个 Spinner。 用户从操作栏中单击“保存”后,我需要遍历所有项目并获
我正在尝试检查 RecyclerView 中是否可以看到某些特定项目;但我无法实现。请帮助我确定我的项目是否在 RecyclerView 中完全可见。 mrecylerView.addOnScroll
我有一个提要片段,它的主要元素是帖子的 RecyclerView。 我正在使用 Lisa Wray 的 Groupie 库管理回收站 https://github.com/lisawray/group
我有这两个类似的行为回收器 View 适配器,它们之间的唯一区别是 onclick 方法和传递给它们的对象。所以,我正在考虑将类 B 设计为从回收器 View 适配器继承,这样我就可以更改构造函数来执
这很奇怪。我对这个问题感到沮丧。我将数据保存在 ArrayList 中。当我将数据放在 RecyclerView 上时。数据未显示在列表中。这是我的代码 listOrder.forEach { ord
编辑我通过使用 CoordinatorLayout 和 AppBarLayout 作为 header 和 TabLayout 的包装解决了这个问题。本来应该很明显,但是哦,好吧。 原始问题:我有一个设
我有一个回收 View 。我想从其适配器类更新回收器 View 。我尝试了 notiftDataSetChanged( ) 但它只适用于主类。下面是 recyclerview 适配器类的代码。 pac
我正在使用具有不同 viewholders 的 recyclerview(具有垂直 LinearLayout),其中一个有另一个 RecyclerView(带有水平 LL)。在第二个 recycler
我想创建一个与 Google Play Store 或 Netflix App 类似的布局,其中在单个 RecyclerView 中基本上有多个水平 RecyclerView。如果这不是他们做事的方式
我是一名优秀的程序员,十分优秀!