- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图在单击特定按钮时显示或隐藏我的 RecyclerView 项目,但由于某种原因没有任何反应。我什至尝试使用 adapter.notifyDataSetChanged();
。需要修复什么以便在单击必要按钮(全部展开 或全部折叠)时此 RecyclerView 中的所有项目都变得可见或消失?
public class MyFragment extends android.support.v4.app.Fragment {
private static final String TAG = MyActivity.class.getSimpleName();
public Boolean isSupposedToBeCollapsed;
private static final int ITEM_TYPE = 100;
private static final int HEADER_TYPE = 101;
private static final int HEADER_TYPE_2 = 102;
private static final int INTRO_TYPE = 103;
public MyFragment() {}
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
return inflater.inflate(R.layout.fragment_rv, container, false);
}
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
View v = getView();
assert v != null;
recyclerView = v.findViewById(R.id.my_recyclerview);
recyclerView.setLayoutManager(new LinearLayoutManager(getActivity(), LinearLayoutManager.VERTICAL, false));
// SpannableStrings
int[] attrS = {R.attr.spannablestringtextColor};
TypedArray ta = getActivity().getTheme().obtainStyledAttributes(attrS);
int colorSS = ta.getColor(0, Color.BLACK); //Color.BLACK - default value (colour will change automatically depending on chosen theme)
Log.d(TAG, "clickMethod 1) " + Integer.toHexString(colorSS));
ta.recycle();
// SpannableString (start)
SpannableStringBuilder ssb1 = new SpannableStringBuilder();
SpannableString str1a = new SpannableString(getString(R.string.placeholder1_placeholder2_placeholder3,
" ", getString(R.string.title_1a), " "));
str1a.setSpan(new BackgroundColorSpan(Color.BLACK), 0, str1a.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
str1a.setSpan(new ForegroundColorSpan(ContextCompat.getColor(getContext(), R.color.yellow)), 0, str1a.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
ssb1.append(str1a);
SpannableString str1b = new SpannableString(" " + getString(R.string.title_1b));
str1b.setSpan(new ForegroundColorSpan(colorSS), 0, str1b.length(), 0);
ssb1.append(str1b);
// SpannableString (end)
// SpannableString (start)
SpannableStringBuilder ssb2 = new SpannableStringBuilder();
SpannableString str2a = new SpannableString(getString(R.string.title_2a));
str2a.setSpan(new BackgroundColorSpan(Color.BLACK), 0, str2a.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
str2a.setSpan(new ForegroundColorSpan(ContextCompat.getColor(getContext(), R.color.yellow)), 0, str2a.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE);
ssb2.append(str2a);
SpannableString str2b = new SpannableString(", " + getString(R.string.title_2b));
str2b.setSpan(new ForegroundColorSpan(colorSS), 0, str2b.length(), 0);
ssb2.append(str2b);
// SpannableString (end)
// init data
dataTitle = new ArrayList<>();
dataTitle.add(ssb1);
dataTitle.add(ssb2);
dataTitle.add(getString(R.string.title_c));
dataTitle.add(getString(R.string.title_d));
dataSubtitle = new ArrayList<>();
dataSubtitle.add(getString(R.string.subtitle_a));
dataSubtitle.add(getString(R.string.subtitle_b));
dataSubtitle.add(getString(R.string.subtitle_c));
dataSubtitle.add(getString(R.string.subtitle_d));
dataDescription = new ArrayList<>();
dataDescription.add(getString(R.string.description_a));
dataDescription.add(getString(R.string.description_b));
dataDescription.add(getString(R.string.description_c));
dataDescription.add(getString(R.string.description_d));
adapter = createAdapter();
recyclerView.setAdapter(adapter);
super.onActivityCreated(savedInstanceState);
}
RecyclerView recyclerView;
ArrayList<CharSequence> dataTitle;
ArrayList<String> dataSubtitle;
ArrayList<String> dataDescription;
RecyclerView.Adapter<MyFragment.ViewHolder> adapter;
// creates the adapter
private RecyclerView.Adapter<MyFragment.ViewHolder> createAdapter() {
return new RecyclerView.Adapter<TabFragmentWATTerminus.ViewHolder>() {
public Boolean expandedAll;
public Boolean collapsedAll;
@NonNull
@Override
public MyFragment.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int type) {
switch (type) {
case HEADER_TYPE:
return new MyFragment.ViewHolder(inflateHelper(R.layout.recyclerview_header, parent));
case HEADER_TYPE_2:
return new MyFragment.ViewHolder(inflateHelper(R.layout.recyclerview_header, parent));
case ITEM_TYPE:
return new MyFragment.ViewHolder(inflateHelper(R.layout.recyclerview_item_tv_itemtype, parent));
case INTRO_TYPE:
return new MyFragment.ViewHolder(inflateHelper(R.layout.recyclerview_item_tv_intro, parent));
default:
return new TabFragmentWATTerminus.ViewHolder(inflateHelper(R.layout.recyclerview_item_tv_itemtype, parent));
}
}
@Override
public void onBindViewHolder(@NonNull final MyFragment.ViewHolder viewHolder, int position) {
final Typeface iconFont = FontManager.getTypeface(getContext(), FontManager.FONTAWESOME);
final RelativeLayout rlInformation = viewHolder.itemView.findViewById(R.id.rl_information);
switch (getItemViewType(position)) {
case HEADER_TYPE:
Button expandButton = viewHolder.itemView.findViewById(R.id.button);
expandButton.setText(R.string.expand_all);
expandButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(expandedAll){
expandedAll = true;
expandRL(rlInformation, txtArrowTV);
adapter.notifyDataSetChanged();
} else if(collapsedAll){
collapsedAll = true;
collapseRL(rlInformation, txtArrowTV);
adapter.notifyDataSetChanged();
}
}
});
break;
case HEADER_TYPE_2:
Button collapseButton = viewHolder.itemView.findViewById(R.id.button);
collapseButton.setText(R.string.collapse_all);
collapseButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(rlInformation.getVisibility() == View.VISIBLE){ collapseRL(rlInformation, txtArrowTV);
adapter.notifyDataSetChanged();
}
});
break;
case INTRO_TYPE:
TextView tvIntroA = viewHolder.itemView.findViewById(R.id.tv_placeholder;
tvIntroA.setVisibility(View.GONE);
break;
case ITEM_TYPE:
// get the current item
CharSequence itemA = dataTitle.get(position - 3);
String itemB = dataSubtitle.get(position - 3);
String itemC = dataDescription.get(position - 3);
//
final TextView txtTitle = viewHolder.itemView.findViewById(R.id.tv_title);
txtTitle.setText(itemA);
final TextView txtSubtitle = viewHolder.itemView.findViewById(R.id.tv_subtitle);
txtSubtitle.setText(itemB);
final TextView txtDescription = viewHolder.itemView.findViewById(R.id.tv_description);
txtDescription.setText(itemC);
final TextView txtArrowTV = viewHolder.itemView.findViewById(R.id.tv_expandcollapsearrow);
txtArrowTV.setText(R.string.fa_icon_chevron_down);
txtArrowTV.setTypeface(iconFont);
// final RelativeLayout rlInformation = viewHolder.itemView.findViewById(R.id.rl_information);
rlInformation.setVisibility(View.GONE);
//
CardView cardView = viewHolder.itemView.findViewById(R.id.cardview_item);
LinearLayout mLinearLayoutTV = viewHolder.itemView.findViewById(R.id.cardview_titlerow);
//
cardView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(rlInformation.getVisibility() == View.GONE){
expandRL(rlInformation, txtArrowTV);
} else {
collapseRL(rlInformation, txtArrowTV);
}
}
});
mLinearLayoutTV.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(rlInformation.getVisibility() == View.GONE){
expandRL(rlInformation, txtArrowTV);
} else {
collapseRL(rlInformation, txtArrowTV);
}
}
});
txtArrowTV.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(rlInformation.getVisibility() == View.GONE){
expandRL(rlInformation, txtArrowTV);
} else {
collapseRL(rlInformation, txtArrowTV);
}
}
});
break;
}
}
@Override
public int getItemCount() {
return dataTitle.size() + 3;
}
@Override
public int getItemViewType(int position) {
switch (position) {
case 0:
return HEADER_TYPE;
case 1:
return HEADER_TYPE_2;
case 2:
return INTRO_TYPE;
default: return ITEM_TYPE;
}
}
};
}
private View inflateHelper(int resId, ViewGroup parent) {
return LayoutInflater.from(getActivity()).inflate(resId, parent, false);
}
// inner class for viewholder to use,
class ViewHolder extends RecyclerView.ViewHolder {
ViewHolder(@NonNull View itemView) {
super(itemView);
}
}
public void expandRL(final RelativeLayout rlInformation, final TextView txtArrowTV) {
rlInformation.setVisibility(View.VISIBLE);
txtArrowTV.setText(R.string.fa_icon_chevron_up);
}
public void collapseRL(final RelativeLayout rlInformation, final TextView txtArrowTV) {
rlInformation.setVisibility(View.GONE);
txtArrowTV.setText(R.string.fa_icon_chevron_down);
}
}
最佳答案
编辑答案中的代码有点困难,因为大括号不是成对的。无论如何,您应该在适配器类中定义两个 boolean
字段(例如 expandedAll
和 collapsedAll
)。在 collapseButton
和 expandButton
的点击监听器中,为 expandedAll
和 collapsedAll
设置正确的值,然后调用 notifyDataSetChanged( )
。之后在 onBindViewHolder
中,当 View 类型为 ITEM_TYPE
时,检查 expandedAll
和 collapsedAll
的值:
在MyFragment中:
private RecyclerView.Adapter<MyFragment.ViewHolder> createAdapter() {
return new MyAdapter(dataTitle, dataSubtitle, dataDescription);
}
MyAdapter.java:
public class MyAdapter extends RecyclerView.Adapter<MyFragment.ViewHolder> {
public static final int ITEM_TYPE = 100;
public static final int HEADER_TYPE = 101;
public static final int HEADER_TYPE_2 = 102;
public static final int INTRO_TYPE = 103;
private ArrayList<CharSequence> dataTitle;
private ArrayList<String> dataSubtitle;
private ArrayList<String> dataDescription;
private Boolean expandedAll;
private Boolean collapsedAll;
public MyAdapter(ArrayList<CharSequence> dataTitle, ArrayList<String> dataSubtitle, ArrayList<String> dataDescription) {
this.dataTitle = dataTitle;
this.dataSubtitle = dataSubtitle;
this.dataDescription = dataDescription;
}
@NonNull
@Override
public MyFragment.ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int type) {
switch (type) {
case HEADER_TYPE:
return new MyFragment.ViewHolder(inflateHelper(parent.getContext(), R.layout.recyclerview_header, parent));
case HEADER_TYPE_2:
return new MyFragment.ViewHolder(inflateHelper(parent.getContext(), R.layout.recyclerview_header, parent));
case ITEM_TYPE:
return new MyFragment.ViewHolder(inflateHelper(parent.getContext(), R.layout.recyclerview_item_tv_itemtype, parent));
case INTRO_TYPE:
return new MyFragment.ViewHolder(inflateHelper(parent.getContext(), R.layout.recyclerview_item_tv_intro, parent));
default:
return new TabFragmentWATTerminus.ViewHolder(inflateHelper(parent.getContext(), R.layout.recyclerview_item_tv_itemtype, parent));
}
}
@Override
public void onBindViewHolder(@NonNull MyFragment.ViewHolder viewHolder, int position) {
final Typeface iconFont = FontManager.getTypeface(getContext(), FontManager.FONTAWESOME);
final RelativeLayout rlInformation = viewHolder.itemView.findViewById(R.id.rl_information);
switch (getItemViewType(position)) {
case HEADER_TYPE:
Button expandButton = viewHolder.itemView.findViewById(R.id.button);
expandButton.setText(R.string.expand_all);
expandButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
expandedAll = true;
collapsedAll = false;
notifyDataSetChanged();
}
});
break;
case HEADER_TYPE_2:
Button collapseButton = viewHolder.itemView.findViewById(R.id.button);
collapseButton.setText(R.string.collapse_all);
collapseButton.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
expandedAll = false;
collapsedAll = true;
notifyDataSetChanged();
}
});
break;
case INTRO_TYPE:
TextView tvIntroA = viewHolder.itemView.findViewById(R.id.tv_placeholder;
tvIntroA.setVisibility(View.GONE);
break;
case ITEM_TYPE:
// get the current item
CharSequence itemA = dataTitle.get(position - 3);
String itemB = dataSubtitle.get(position - 3);
String itemC = dataDescription.get(position - 3);
//
final TextView txtTitle = viewHolder.itemView.findViewById(R.id.tv_title);
txtTitle.setText(itemA);
final TextView txtSubtitle = viewHolder.itemView.findViewById(R.id.tv_subtitle);
txtSubtitle.setText(itemB);
final TextView txtDescription = viewHolder.itemView.findViewById(R.id.tv_description);
txtDescription.setText(itemC);
final TextView txtArrowTV = viewHolder.itemView.findViewById(R.id.tv_expandcollapsearrow);
txtArrowTV.setText(R.string.fa_icon_chevron_down);
txtArrowTV.setTypeface(iconFont);
// final RelativeLayout rlInformation = viewHolder.itemView.findViewById(R.id.rl_information);
rlInformation.setVisibility(View.GONE);
//
CardView cardView = viewHolder.itemView.findViewById(R.id.cardview_item);
LinearLayout mLinearLayoutTV = viewHolder.itemView.findViewById(R.id.cardview_titlerow);
//
cardView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (rlInformation.getVisibility() == View.GONE) {
expandRL(rlInformation, txtArrowTV);
} else {
collapseRL(rlInformation, txtArrowTV);
}
}
});
mLinearLayoutTV.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (rlInformation.getVisibility() == View.GONE) {
expandRL(rlInformation, txtArrowTV);
} else {
collapseRL(rlInformation, txtArrowTV);
}
}
});
txtArrowTV.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (rlInformation.getVisibility() == View.GONE) {
expandRL(rlInformation, txtArrowTV);
} else {
collapseRL(rlInformation, txtArrowTV);
}
}
});
if (expandedAll) {
expandRL(rlInformation, txtArrowTV);
} else if (collapsedAll) {
collapseRL(rlInformation, txtArrowTV);
}
break;
}
}
@Override
public int getItemCount() {
return dataTitle.size() + 3;
}
@Override
public int getItemViewType(int position) {
switch (position) {
case 0:
return HEADER_TYPE;
case 1:
return HEADER_TYPE_2;
case 2:
return INTRO_TYPE;
default:
return ITEM_TYPE;
}
}
private View inflateHelper(Context context, int resId, ViewGroup parent) {
return LayoutInflater.from(context).inflate(resId, parent, false);
}
}
上述解决方案解决了展开和折叠所有问题,但另一个问题仍然存在。您应该为显示项目折叠或展开的每个项目维护一个 boolean
。我在名为 PrimeAdapter 的开源库中处理了 RecyclerView
项的扩展. (它有 android java 示例应用程序)如果你愿意,我建议你使用它。它使您的代码变得如此简单。
关于java - RecyclerView 项目不会同时改变可见性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52597450/
我在 Mac OsX 10.11 上使用 Xcode 7.0.1 (7A1001) 我使用 carthage 0.9.2 通过以下购物车文件下载reactivecocoa github“Reactiv
我正在将一个对象从属性“模型”(我从 Laravel 中的 Blade 属性模型中获得)分配给数据属性模型。后来数据属性模型发生变化,因为它绑定(bind)到表单输入字段。但 Prop “模型”也发生
当我更新数组内对象的属性然后作为组件的 Prop 传递时,在 svelte 中触发 react 性的正确方法是什么? let items = [{ id: 1, name: 'first'
我是 DRY principle 的坚定拥护者: Every piece of knowledge must have a single, unambiguous, authoritative rep
我正在实现一个需要以下功能的线程: 及时响应终止请求 推送消息 在等待消息时保持对 SendMessage 请求的响应 我对消息泵的初始实现使用了 GetMessage,如下所示: while not
在我的应用程序中,用户获得了一份已到达她的文档列表,并且可以对每个文档执行操作。 文件是分批提交的,当这种情况发生时,列表会增加。这一切都很好,这是预期的行为,但最好有一个按钮“暂停实时数据”,它会忽
我有一个属性为 的数据对象 displaySubtotal 我可以通过以下方式更新该属性的值: data.displaySubtotal = numPad.valueAsAString(); 我的方法
我需要一个垂直 slider 输入。由于内置的 sliderInput 函数无法做到这一点,因此我选择自己实现。根据this thread可以 (I) 使用 CSS 旋转 sliderInput
我正在从自定义用户权限管理系统迁移到 Alanning:roles v2.0 .我有一个非常基本的结构: 基本用户 用户组,每个用户组都有特定的设置。我将它们存储在一个“组”集合中。 管理群组的用户的
Shiny 中的响应式(Reactive)表达式将更改传播到需要去的地方。我们可以使用 isolate 来抑制一些这种行为。 ,但是我们可以抑制基于我们自己的逻辑表达式传播的更改吗? 我给出的例子是一
是否有(或可能有) react 性 Parsec (或任何其他纯函数式解析器)在 Haskell 中? 简而言之,我想逐个字符地为解析器提供数据,并获得与我提供的足够多的结果一样多的结果。 或者更简单
HTML(JADE) p#result Lorem ipsum is javascript j s lo 1 2 4 this meteor thismeteor. meteor input.sear
我有一个被导入函数更改的对象。 https://svelte.dev/repl/e934087af1dc4a25a1ee52cf3fd3bbea?version=3.12.1 我想知道如何使我的更改反
我有一个YUV 420半平面格式的图像,其中字节以这种方式存储: [Y1 Y2 ... [U1 V1.... Yk Yk+1...] Uk' Uk'+1] 其中Y平面的大小是UV平面的两倍,并
如何使用 ReactiveCocoa 订阅从 NSMutableDictionary 添加和删除的对象?另外,我想在它发生变化时广播通知。我的猜测是可以使用 RACMulticastConnectio
我正在构建一个带有多个选项卡的应用程序,其中一些选项卡涉及过多的计算,而另一些选项卡的计算速度很快。一个允许用户在 react 性或手动更新之间进行选择的复选框,与“刷新”按钮结合使用,将是理想的选择
我知道您可以在获取集合时使用 reactive: false 关闭 react 性。如何在内容可编辑区域内的集合字段中实现相同的效果?示例: Template.documentPage.events(
我想在 z3 中表示一个哈希函数,比如 SHA(x)。在做了一些研究之后,似乎 z3 不能很好地支持注入(inject)性,所以我不能有像这样的约束(虽然我意识到这并不是严格意义上的碰撞,但作为一种启
我正在解决一个问题,我想在仪表板中将数据显示为图表(通过 perak:c3 )和表格(通过 aslagle:reactive-table )。我的问题是数据是从 MongoDB 中的集合中提取的,它的
我的 ViewModel 中有这个函数,它返回一个信号,但内部 block 不起作用,我尝试添加断点,但它没有中断。这是我的代码。 func executeLoginAPI() -> RACSigna
我是一名优秀的程序员,十分优秀!