- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我坚持了一个逻辑,无法达到预期的结果。我有一个回收器 View ,它有另一个水平的子回收器 View 。单击该项目后,我可以展开折叠 View 。我希望当我单击一个元素时,只有当前位置应该展开,所有其他位置都崩溃了。我尝试了很多逻辑,但没有人适合我。
我的回收站 View 适配器代码是:
public class NewAdpater extends RecyclerView.Adapter<NewAdpater.ViewHolder> implements Response.ErrorListener {
Context context;
boolean flag=true;
private List<FetchDocument> docDatalist;
int customerSerial;
private int expandedPosition = -1;
private int vinappserial;
ImageFetchResponse response;
ArrayList<Bitmap> bitmaps;
SendHoldertdata sendHoldertdata;
UtilityOfActivity utilityOfActivity;
List<ImageFetchResponseDocumentList> list = new ArrayList<>();
public NewAdpater(List<FetchDocument> docDatalist, Context context, String vinappserial, SendHoldertdata sendHoldertdata) {
this.docDatalist = docDatalist;
this.context = context;
this.sendHoldertdata = sendHoldertdata;
utilityOfActivity = new UtilityOfActivity((Activity) context);
this.vinappserial = Integer.valueOf(vinappserial);
UserDetail userDetail = new Gson().fromJson(PrefrenceFile.getInstance().getString(Constant.PREF_KEY_USER_DATA), UserDetail.class);
customerSerial = userDetail.getLoginResponse().getCustInfo().getCustSerialNo();
}
@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View v = LayoutInflater.from(parent.getContext()).
inflate(R.layout.doc_send_item_list, parent, false);
ViewHolder viewHolder = new ViewHolder(v);
return viewHolder;
}
@Override
public void onBindViewHolder(final ViewHolder holder, final int position) {
holder.recyclerViewImages.setVisibility(View.GONE);
holder.doc_type.setText(docDatalist.get(position).getDocTypeDesc());
// expandedPosition=holder.getAdapterPosition();
holder.myDocumentListCollapse.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
boolean shouldExpand = holder.recyclerViewImages.getVisibility() == View.GONE;
if (shouldExpand) {
holder.recyclerViewImages.setVisibility(View.VISIBLE);
holder.iconexpandCollapse.setImageResource(R.mipmap.expand_4);
imagerequestserver(docDatalist.get(position), vinappserial, holder);
// DocumentImageFetchResponseListner setData= new DocumentImageFetchResponseListner(holder);
} else {
holder.recyclerViewImages.setVisibility(View.GONE);
holder.iconexpandCollapse.setImageResource(R.mipmap.expand);
}
}
});
}
@Override
public int getItemCount() {
return docDatalist.size();
}
public interface SendHoldertdata {
void setdata(ArrayList<Bitmap> bitmapArrayList, int count);
}
class ViewHolder extends RecyclerView.ViewHolder {
TextView doc_type;
LinearLayout myDocumentListCollapse;
RelativeLayout layoutAddDoc;
ImageView iconexpandCollapse;
RecyclerView recyclerViewImages;
public ViewHolder(View itemView) {
super(itemView);
doc_type = itemView.findViewById(R.id.doc_type);
myDocumentListCollapse = itemView.findViewById(R.id.myDocumentListCollapse);
layoutAddDoc = itemView.findViewById(R.id.layoutAddDoc);
iconexpandCollapse = itemView.findViewById(R.id.iconexpandCollapse);
recyclerViewImages = itemView.findViewById(R.id.recyclerViewImages);
recyclerViewImages.setVisibility(View.GONE);
}
}
public void imagerequestserver(FetchDocument fetchDocument, int vinappserial, ViewHolder holder) {
ImageFetchRequest imageFetchRequest = new ImageFetchRequest();
imageFetchRequest.setCustSerial(customerSerial);
imageFetchRequest.setDocGroup(fetchDocument.getDocTypeCode());
imageFetchRequest.setVehSerial(String.valueOf(vinappserial));
imageFetchRequest.setDocSerial("0");
String url = Constant.API_MAIN + Constant.API_DOCUMENT_IMAGEFETCH;
AbstractVolleyRequest jsonObjectrequest = new
AbstractVolleyRequest(url, this, new DocumentImageFetchResponseListner(fetchDocument, vinappserial, holder), imageFetchRequest, Request.Method.POST);
jsonObjectrequest.setTag("DocumentImageFetchRequest");
Log.v("DocumentFetchRequest", "DocumentImageFetchRequest" + jsonObjectrequest);
VolleyRequestQue.getmInstance(context.getApplicationContext()).addToRequestQueue(jsonObjectrequest);
}
@Override
public void onErrorResponse(VolleyError error) {
if (context != null) {
utilityOfActivity.progresDissmiss();
}
utilityOfActivity.toast(context.getString(R.string.connectivity_server_error));
}
public class DocumentImageFetchResponseListner extends MyListner<ImageFetchResponse> implements MailDocumentListAdapter.ISelectedImageMail {
FetchDocument fetchDocument;
String vinappserial;
public ViewHolder holder;
public DocumentImageFetchResponseListner(FetchDocument fetchDocument, int vinappserial, ViewHolder holder) {
super(ImageFetchResponse.class);
this.vinappserial = String.valueOf(vinappserial);
this.fetchDocument = fetchDocument;
this.holder = holder;
utilityOfActivity.progressDialogShow(context.getString(R.string.please_wait));
}
@Override
public void onResponse(MyResponse instaResponse) {
utilityOfActivity.progresDissmiss();
if (instaResponse != null) {
if (instaResponse instanceof ImageFetchResponse) {
response = (ImageFetchResponse) instaResponse;
if (response.getResult().getResultStatus().contains("SUCCESS")) {
list = response.getDocumentList();
// list.addAll(newList);
Log.d("", "");
if (list.size() > 0) {
setData();
}
} else {
utilityOfActivity.toast(context.getString(R.string.connectivity_server_error));
}
}
}
}
private void setData() {
MailDocumentListAdapter recyclerViewNewAdpater = new MailDocumentListAdapter(context, list, this);
holder.recyclerViewImages.setLayoutManager(new GridLayoutManager(context, 3));
recyclerViewNewAdpater.notifyDataSetChanged();
holder.recyclerViewImages.setAdapter(recyclerViewNewAdpater);
}
@Override
public void sendBitMap(ArrayList<Bitmap> itemSelectedArrayList,int count) {
bitmaps = itemSelectedArrayList;
sendHoldertdata.setdata(bitmaps,count);
}
}
}
这是我设置适配器的 DialogFragment:
public class DialogMailDocument extends DialogFragment implements NewAdpater.SendHoldertdata {
TextView txtCount;
int count=0;
ImageView documentCross;
RecyclerView recyclerViewDocument;
UtilityOfActivity utilityOfActivity;
AppCompatActivity appCompatActivity;
NewAdpater mainAdapter;
private int expandedPosition = -1;
Context mContext;
ArrayList<Bitmap> sendImageBitmap = new ArrayList<>();
List<ImageFetchResponseDocumentList> imageFetchResponseDocumentLists;
List<FetchDocument> fetchDocuments;
String vinappSerail;
MailDocumentListAdapter.ISelectedImageMail selectedImageMail;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setStyle(DialogFragment.STYLE_NORMAL, R.style.fullscreen_dialog);
}
private void init(View view) {
txtCount = view.findViewById(R.id.txtCount);
// selectAll = view.findViewById(R.id.selectAll);
recyclerViewDocument = view.findViewById(R.id.recyclerViewDocument);
TextView tvSendDoc = view.findViewById(R.id.tvSendDoc);
documentCross = view.findViewById(R.id.documentCross);
documentCross.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
getDialog().dismiss();
}
});
tvSendDoc.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (sendImageBitmap != null) {
email(getActivity(), "xyz@gmail.com", "hello", sendImageBitmap);
} else {
Toast.makeText(getActivity(), "Nothing is selected", Toast.LENGTH_SHORT).show();
}
}
});
setDocumentRecyclerView();
}
public DialogMailDocument newInstance(MailDocumentListAdapter.ISelectedImageMail iSelectedImageMail) {
DialogMailDocument fragment = new DialogMailDocument();
this.selectedImageMail = iSelectedImageMail;
return fragment;
}
@Override
public void onAttach(Activity activity) {
super.onAttach(activity);
utilityOfActivity = new UtilityOfActivity(activity);
appCompatActivity = (AppCompatActivity) activity;
}
@Override
public void onAttach(Context context) {
super.onAttach(context);
mContext = context;
}
@Override
public void onStart() {
super.onStart();
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.dialog_mail_document, container, false);
Bundle bundle = getArguments();
if (bundle != null) {
imageFetchResponseDocumentLists = bundle.getParcelableArrayList("documentList");
fetchDocuments = bundle.getParcelableArrayList("documentListHead");
vinappSerail = bundle.getString("vinappSerail");
}
init(view);
return view;
}
private void setDocumentRecyclerView() {
mainAdapter = new NewAdpater(fetchDocuments, getActivity(), vinappSerail, this,expandedPosition);
RecyclerView.LayoutManager mLayoutManager = new LinearLayoutManager(getActivity());
recyclerViewDocument.setLayoutManager(mLayoutManager);
recyclerViewDocument.setAdapter(mainAdapter);
//
// GridLayoutManager manager =
// new GridLayoutManager(getActivity(), 3);
// recyclerViewDocument.setLayoutManager(manager);
// mainAdapter.setLayoutManager(manager);
// adapter.shouldShowHeadersForEmptySections(hideEmpty);
// adapter.shouldShowFooters(showFooters);
recyclerViewDocument.setAdapter(mainAdapter);
mainAdapter.notifyDataSetChanged();
}
public Uri getImageUri(Context inContext, Bitmap inImage) {
ByteArrayOutputStream bytes = new ByteArrayOutputStream();
inImage.compress(Bitmap.CompressFormat.JPEG, 100, bytes);
String path = MediaStore.Images.Media.insertImage(inContext.getContentResolver(), inImage, "Title", null);
return Uri.parse(path);
}
public void email(Context context, String emailTo, String emailText, ArrayList<Bitmap> filePaths) {
//need to "send multiple" to get more than one attachment
final Intent emailIntent = new Intent(Intent.ACTION_SEND_MULTIPLE);
emailIntent.setType("image/*");
emailIntent.putExtra(Intent.EXTRA_EMAIL,
new String[]{emailTo});
emailIntent.putExtra(Intent.EXTRA_TEXT, emailText);
//has to be an ArrayList
ArrayList<Uri> uris = new ArrayList<Uri>();
//convert from paths to Android friendly Parcelable Uri's
for (Bitmap file : filePaths) {
Uri u = getImageUri(getActivity(), file);
uris.add(u);
}
emailIntent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, uris);
context.startActivity(Intent.createChooser(emailIntent, "Send mail..."));
}
@Override
public void setdata(ArrayList<Bitmap> bitmapArrayList,int count) {
sendImageBitmap = bitmapArrayList;
this.count=count;
txtCount.setText(String.valueOf(count)+" selected");
}
@Override
public void setExpandedPosition(int expandedPosition) {
DialogMailDocument.this.expandedPosition = expandedPosition;
mainAdapter.notifyDataSetChanged();
}
}
最佳答案
在模型类中取一个 bool 值“isShow”,并将其默认设置为 false,用于您的 recyclerview 的所有项目。
然后....
if (list.get(position).isShow()) {
// show item....
} else {
// hide item....
}
在 onBindViewHolder 方法中重复一个 for 循环的最简单方法如下所示。
for (int i = 0; i < list.size(); i++) {
if (i == position) {
if (list.get(position).isShow()) {
list.get(position).setShow(false);
} else {
list.get(position).setShow(true);
}
} else {
list.get(i).setShow(false);
}
notifyDataSetChanged();
}
向我询问更多问题。
谢谢。
关于android - 当点击 recyclerView 中的另一个位置时,setVisibility 如何消失所有其他位置?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48056955/
我使用 vanilla JS 通过 AJAX 向数据库发送请求。数据写入数据库没有问题。在刷新页面之前,我看不到被放入数据库中的内容。当我删除内容时也会发生同样的情况,我必须刷新才能看到内容消失了。
抱歉,这篇文章很长,我试图提供所有信息并解释我已经尝试过的内容。 问题: 我将经典的 Phoenix View 放入实时 View 中。虽然一切看起来都很好,但 echart 一完成绘制就消失了。好像
搜索了一下,没有找到我要找的东西。我有两个按钮,单击一次即可拉出两个不同的选择框,第二次单击它们就会消失。但是,我希望选择框 1 在单击按钮 2 时消失,反之亦然:选择框 2 将在单击按钮 1 时消失
我正在尝试使用自动布局使用“浮动”标题构建滚动视图。更确切地说,我正在尝试建立包含几列的日历视图。这些列中的每个列都应具有自己的标题,该标题应浮动在顶部,而该列可以垂直滚动到其下方。 如果一切正常,则
我正在尝试模仿星星背景。 星星是在加载时创建并随机散布在整个网站上的。到目前为止我已经调整了一些代码。 var star="•"; var numStars=100; for(var x=1;x•";
我查遍了整个网络,但找不到解决方案。我对 jQuery 也很陌生。 我的案例: 我有一个导航栏,其中的每个链接都会激活/触发一个megamenu(每个链接都有自己的megamenu)。 我需要什么:
我有一个可扩展的 ListView ,当我点击一行时,它会触发 onChildClick 或 onGroupClick,具体取决于我点击的是子项还是组。 如果我在 xml 布局文件中添加可点击的内容(
在我的程序中,我有一个 NSMutableData 变量,用于收集来自 http://www.nhara.org/scored_races-2013.htm 的信息。 .大约第三次从网站获取信息后,当
我一直在完美地使用 Genymotion,但是从最近几天开始我的 Genymotion 并打开它的 GPS 开始,我的 Genymotion 突然消失了。但是我的 eclipse 显示 Genymot
这个问题不太可能帮助任何 future 的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visit
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and t
所以我的 Item::return_all() 有问题,因为我在 main.cpp 中调用它。早些时候我在 read_file() 和 for (auto data : example_item) 中
所有 UITableCells 在 UITableView 中滚动和触摸时消失。一切都以编程方式完成,我使用标准的 UITableViewCell 类。 我在某处读到包含我的单元格数据的数组可能被清空
我对 Swift 还很陌生。我的问题是我的 UICollectionView 正在消失。在 Xcode 中,它显示一切就绪,但当我在模拟器或设备上启动时,它消失了,只剩下导航栏和标签栏。 有谁知道是什
这是 this one的续题。较早的问题是在复选框上。但是后来我根据要求把check box改成了radio buttons。 现在我需要显示子单选按钮并在母单选按钮处于事件状态时更改背景颜色。一旦它
我用 JS 写了一个简单的脚本。当我将它放入 html 文档(在 body 标签的底部)时,它工作正常。当我尝试将它放入外部文档并链接它时,脚本运行但 canvas 元素消失(刚刚检查:当我将脚本放在
我正在尝试创建一个带有固定元素的滚动页面,当用户向下滚动页面时,该元素“始终”可见。例如,带有道路背景的汽车图像。因此,当用户向下滚动页面时,汽车看起来就像在路上行驶。虽然汽车出现在道路的顶部,但它必
这个问题在这里已经有了答案: How can I change CSS display none or block property using jQuery? (15 个答案) 关闭 4 年前。
我在市场上有一个支持小部件的应用程序。我对应用程序进行了一些重大更改,重新设计了很多内部结构,替换/重命名 Activity 等。其他更改包括从不同的共享首选项键获取小部件配置数据,尽管我已经编写了转
我有一个 fragment alertsfragment.java,它有一个 GridView 布局,当我打开它时,它工作正常,但是当我在其他选项卡之间滑动时,它就消失了。为了解释更多,我有一个 Ac
我是一名优秀的程序员,十分优秀!