我有一个XML文件,其中包含两个线性布局,根据使用的设置,一次只能看到一个.两个视图都是动态生成的,并设置了一个on click Listener和onlongclickListener.
以下是XML布局:
<?xml version="1.0" enCoding="utf-8"?><relativeLayout xmlns:androID="http://schemas.androID.com/apk/res/androID" androID:layout_wIDth="match_parent" androID:layout_height="wrap_content" androID:orIEntation="vertical"> <linearLayout androID:ID="@+ID/resulttableContainer" androID:layout_wIDth="match_parent" androID:layout_height="match_parent" androID:orIEntation="vertical" androID:visibility="gone"> <ScrollVIEw androID:layout_wIDth="match_parent" androID:layout_height="wrap_content" androID:scrollbars="horizontal" androID:fillVIEwport="true"> <horizontalscrollview androID:layout_wIDth="match_parent" androID:layout_height="wrap_content" androID:fillVIEwport="true"> <tableLayout androID:ID="@+ID/resulttable" androID:stretchColumns="1" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:shrinkColumns="false"> </tableLayout> </horizontalscrollview> </ScrollVIEw> </linearLayout> <linearLayout androID:ID="@+ID/formattedResultContainer" androID:layout_wIDth="match_parent" androID:layout_height="match_parent" androID:orIEntation="vertical" androID:visibility="gone"> <ScrollVIEw androID:ID="@+ID/formattedScrollContainer" androID:layout_wIDth="match_parent" androID:layout_height="match_parent" androID:scrollbars="vertical"> <linearLayout androID:ID="@+ID/formattedResult" androID:layout_wIDth="match_parent" androID:layout_height="wrap_content" androID:orIEntation="vertical"/> </ScrollVIEw> </linearLayout></relativeLayout>
为简单起见,我将调用第一个线性布局容器视图1和第二个线性布局容器视图2.
默认情况下,两个视图的可见性设置都已消失,当屏幕首次加载时,视图1的可见性设置为可见,并使用以下代码动态生成视图:
@OverrIDe public voID processResult(final VIEw.OnClickListener editRowClickListener,final VIEw.OnLongClickListener columnLongClickListener) { try { this.getActivity().runOnUiThread(new Runnable() { @OverrIDe public voID run() { if (shouldExistingResultBeCleared()) { resultVIEw.removeAllVIEws(); } if (getSettings().getInt(defines.SharedPreferenceSettings.APPliCATION_theme,com.BoardIEsITSolutions.library.R.style.libApptheme) == com.BoardIEsITSolutions.library.R.style.libApptheme) { resultVIEw.setBackgroundcolor(color.WHITE); } else { resultVIEw.setBackgroundcolor(color.BLACK); } } }); this.showDialog(getJsONResult().length()); new Thread(new Runnable() { @OverrIDe public voID run() { try { for (int i = 0; i < getJsONResult().length(); i++) { HashMap<Integer,String> fIEldindexAndValue = new HashMap<Integer,String>(); final tableRow tr; if (!getSettings().getBoolean("IsDarktheme",false)) { tr = (tableRow) getFragment().getLayoutInflater(getFragment().getArguments()).inflate(R.layout.result_table_row_light_theme,resultVIEw,false); } else { tr = (tableRow) getFragment().getLayoutInflater(getFragment().getArguments()).inflate(R.layout.result_table_row_dark_theme,false); } if (i == 0) { tr.setBackgroundcolor(ContextCompat.getcolor(getActivity(),R.color.appPrimaryColour)); } else if (i % 2 == 0) { if (!getSettings().getBoolean("IsDarktheme",false)) { tr.setBackgroundcolor(ContextCompat.getcolor(getActivity(),R.color.resultRowlightthemeAlternateRow)); } else { tr.setBackgroundcolor(ContextCompat.getcolor(getActivity(),R.color.resultRowDarkthemeAlternateRow)); } } Imagebutton imagebutton = (Imagebutton) getFragment().getLayoutInflater(getFragment().getArguments()).inflate(R.layout.row_edit_image,tr,false); imagebutton.setonClickListener(editRowClickListener); tr.addVIEw(imagebutton); if (i == 0) { imagebutton.setVisibility(VIEw.INVISIBLE); } JsONArray array = getJsONResult().getJsONArray(i); String currentFIEld = null; for (int j = 0; j < array.length(); j++) { final TextVIEw textVIEw; textVIEw = (TextVIEw) getFragment().getLayoutInflater(getFragment().getArguments()).inflate(R.layout.result_textvIEw,false); textVIEw.setText(array.getString(j)); if (!getSettings().getBoolean(defines.SharedPreferenceSettings.MulTIliNE_RESulT,true)) { textVIEw.setSingleline(true); } if (i == 0) { textVIEw.setTypeface(null,Typeface.BolD); //Get the fIElds into a index and fIEld hash map addindexAndFIEld(j,array.getString(j)); } else { textVIEw.setonLongClickListener(columnLongClickListener); fIEldindexAndValue.put(j,array.getString(j)); } getActivity().runOnUiThread(new Runnable() { @OverrIDe public voID run() { tr.addVIEw(textVIEw); } }); } imagebutton.setTag(fIEldindexAndValue); getActivity().runOnUiThread(new Runnable() { @OverrIDe public voID run() { resultVIEw.addVIEw(tr); } }); updateProgressDialog(); //handler.sendMessage(handler.obtainMessage()); } closeDialog(); //((ResultProcessor)resultProcessor).closeDialog(); } catch (JsONException ex) { } } }).start(); } catch (Exception ex) { } }
这完全没问题.用户按下选项以切换到视图2,因此视图1被清除,可见性设置为消失,视图2被设置为可见.然后动态生成此视图,并相应地将单击侦听器设置为视图. (我没有包含此视图的代码,因为我认为它不相关,并且此视图始终无例外地工作).
如果用户然后切换回视图1,则清除视图2,并且可见性设置为消失,视图1恢复可见,并且使用与上面所示相同的方法动态地重新创建视图并分配on click侦听器.
视图自我看起来很好,但是没有用户交互可能,滚动视图不再垂直或水平滚动,并且点击处理程序都不起作用.
由于视图1工作一次,我不明白为什么它不会重新生成,但视图2总是有效,无论如何.
解决方法 我已经设法解决了我遇到的问题,感谢大家的帮助,我尝试了所建议但不幸的是没有太大的影响.我目前所拥有的是一个片段,它必须是线性布局容器,当视图被切换时,一个容器被隐藏并显示容器,然后重新加载相关的视图内容.
我改为将每个视图更改为不同的片段并使用自己的XML布局文件,然后在切换视图时,它使用片段事务将一个片段视图替换为另一个,然后使用相同的代码正如我上面动态填充相关的视图内容.
总结以上是内存溢出为你收集整理的android – 清除并重新创建视图时,Scrollview和OnClick处理程序无法正常工作全部内容,希望文章能够帮你解决android – 清除并重新创建视图时,Scrollview和OnClick处理程序无法正常工作所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)