- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
问题
我创建了自定义 ListView,其中包含自定义 View ,以及每个列表项的一些 TextView 。一切都按我的预期工作,直到设备方向改变,ListView 消失。我知道当方向改变 Activity 重新发生时会发生问题。但是,我已经在应用程序中将必要的文件保存为 JSON 字符串格式,当 Activity 重新创建时,我发现数据已加载并成功运行,直到代码结束没有强制关闭但是,listview 没有显示?
注意
我确信我的保存数据是可用的,因为这个文件用于防止从互联网上获取数据(如果可用的话),我已经测试过了,它可以工作!
我的自定义 ListView 有 ListView 类提供数组列表和适配器类,但我不能在这里提供,因为它太长了。
主类
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.schedule);
aq = new AQuery(this);
lvSchedule = (ListView) findViewById(R.id.listView_schedule);
scheduleLvItems = new ArrayList<Schedule_ListView>();
dm = new DataManager(this);
//check available in app data
String scheduleJSON = dm.readFile("scheduleJSON");
if (scheduleJSON != "empty"){
System.out.println(scheduleJSON);
renderData(scheduleJSON);
}
else{
String url = "http://requestURL/getSchedule_v2.php?+" +
"loginId="+yourID+
"&password="+yourPassword+
"&year=2013&semester=2";
aq.ajax(url,String.class, this,"cb1");
}
}
public void cb1(String url, String html, AjaxStatus status){
System.out.println(html);
renderData(html);
}
public void renderData(String jsonString){
try {
List<List<String>> monData = new ArrayList<List<String>>();
List<List<String>> tueData = new ArrayList<List<String>>();
List<List<String>> wedData = new ArrayList<List<String>>();
List<List<String>> thuData = new ArrayList<List<String>>();
List<List<String>> friData = new ArrayList<List<String>>();
List<List<String>> satData = new ArrayList<List<String>>();
List<List<String>> sunData = new ArrayList<List<String>>();
/*Note [Knowledge]
*JSON Symbol {,} = JSONObject
*JSON symbol [,] = JSONArray
*/
//Change JSONString to JSONArray
JSONArray jsonArray_data = new JSONArray(jsonString);
//Set jsonArray_data in global variable for further use
// ((Global_Variable)getApplicationContext()).setJsonSubject(jsonArray_data);
//Save Persistence Json Array in app data for fetch with out internet
dm.writeFile("scheduleJSON",jsonArray_data.toString());
for(int i = 0; i < jsonArray_data.length(); i++){
//Change object to String and stored each JSON item in Variable
JSONObject dataRecord = jsonArray_data.getJSONObject(i);
String yearSemester = dataRecord.getString("YEAR / SEM");
String courseID = dataRecord.getString("COURSE ID");
String courseName = dataRecord.getString("COURSE NAME");
String courseSection = dataRecord.getString("SECTION");
JSONArray courseInfo = dataRecord.getJSONArray("COURSE INFO");
String finalDate = dataRecord.getString("FINAL DATE");
String finalRoom = dataRecord.getString("FINAL ROOM");
String finalTime = dataRecord.getString("FINAL TIME");
String midtermDate = dataRecord.getString("MIDTERM DATE");
String midtermRoom = dataRecord.getString("MIDTERM ROOM");
String midtermTime = dataRecord.getString("MIDTERM TIME");
int subjectColor = getResources().getColor(SUBJECT_COLOR[i]);
for(int ii = 0; ii < courseInfo.length(); ii++){
//Change object to String and stored each JSON item in Variable
JSONObject infoRecord = courseInfo.getJSONObject(ii);
String day = infoRecord.getString("DAY").replace(".","").trim();
String tStart = infoRecord.getString("TIME").replace(" - ","").trim().substring(0,5);
String tStop = infoRecord.getString("TIME").replace(" - ","").trim().substring(5);
String roomStudy = infoRecord.getString("ROOM STUDY");
String instructor = infoRecord.getString("INSTRUCTOR");
List<String> dataRow = new ArrayList<String>();
if (day.contains("Mon")) {
dataRow.add(courseName); //course name
dataRow.add(tStart); //period start
dataRow.add(tStop); //period end
dataRow.add(String.valueOf(subjectColor)); //subject color
dataRow.add(String.valueOf(i)); //subject position in json
monData.add(dataRow);
} else if (day.contains("Tue")) {
dataRow.add(courseName); //course name
dataRow.add(tStart); //period start
dataRow.add(tStop); //period end
dataRow.add(String.valueOf(subjectColor)); //subject color
dataRow.add(String.valueOf(i)); //subject position in json
tueData.add(dataRow);
} else if (day.contains("Wed")) {
dataRow.add(courseName); //course name
dataRow.add(tStart); //period start
dataRow.add(tStop); //period end
dataRow.add(String.valueOf(subjectColor)); //subject color
dataRow.add(String.valueOf(i)); //subject position in json
wedData.add(dataRow);
} else if (day.contains("Thu")) {
dataRow.add(courseName); //course name
dataRow.add(tStart); //period start
dataRow.add(tStop); //period end
dataRow.add(String.valueOf(subjectColor)); //subject color
dataRow.add(String.valueOf(i)); //subject position in json
thuData.add(dataRow);
} else if (day.contains("Fri")) {
dataRow.add(courseName); //course name
dataRow.add(tStart); //period start
dataRow.add(tStop); //period end
dataRow.add(String.valueOf(subjectColor)); //subject color
dataRow.add(String.valueOf(i)); //subject position in json
friData.add(dataRow);
} else if (day.contains("Sat")) {
dataRow.add(courseName); //course name
dataRow.add(tStart); //period start
dataRow.add(tStop); //period end
dataRow.add(String.valueOf(subjectColor)); //subject color
dataRow.add(String.valueOf(i)); //subject position in json
satData.add(dataRow);
} else if (day.contains("Sun")){
dataRow.add(courseName); //course name
dataRow.add(tStart); //period start
dataRow.add(tStop); //period end
dataRow.add(String.valueOf(subjectColor)); //subject color
dataRow.add(String.valueOf(i)); //subject position in json
sunData.add(dataRow);
}
}
}
if(monData.size() != 0){
scheduleLvItems.add(new Schedule_ListView(
R.drawable.monday_mdpi,
monData,
getResources().getInteger(R.integer.COLLAPSED_HEIGHT_1)
));
}
if(tueData.size() != 0){
scheduleLvItems.add(new Schedule_ListView(
R.drawable.tuesday_mdpi,
tueData,
getResources().getInteger(R.integer.COLLAPSED_HEIGHT_1)
));
}
if(wedData.size() != 0){
scheduleLvItems.add(new Schedule_ListView(
R.drawable.wendesday_mdpi,
wedData,
getResources().getInteger(R.integer.COLLAPSED_HEIGHT_1)
));
}
if(thuData.size() != 0){
scheduleLvItems.add(new Schedule_ListView(
R.drawable.thursday_mdpi,
thuData,
getResources().getInteger(R.integer.COLLAPSED_HEIGHT_1)
));
}
if(friData.size() != 0){
scheduleLvItems.add(new Schedule_ListView(
R.drawable.friday_mdpi,
friData,
getResources().getInteger(R.integer.COLLAPSED_HEIGHT_1)
));
}
if(satData.size() != 0){
scheduleLvItems.add(new Schedule_ListView(
R.drawable.saturday_mdpi,
satData,
getResources().getInteger(R.integer.COLLAPSED_HEIGHT_1)
));
}
if(sunData.size() != 0) {
scheduleLvItems.add(new Schedule_ListView(
R.drawable.sunday_mdpi,
sunData,
getResources().getInteger(R.integer.COLLAPSED_HEIGHT_1)
));
}
//add padding top - bottom for listview
LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
LinearLayout header = (LinearLayout) inflater.inflate(R.layout.listview_header, null);
lvSchedule.addFooterView(header, null, false);
lvSchedule.addHeaderView(header, null, false);
//setup listView Adapter
scheduleAdapter = new Schedule_Adapter(Schedule.this, R.layout.schedule_listview, scheduleLvItems);
//setup adapter to listView
lvSchedule.setAdapter(scheduleAdapter);
//setup OnClickListener
lvSchedule.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
int postion = i - lvSchedule.getHeaderViewsCount();
toggle(view, postion);
}
});
}catch (Exception e){
System.out.println(e);
}
}
最佳答案
发生这种情况是因为您在 onCreate 中将数据分发到 ListView
并且每当您更改方向时, Activity 将重新启动并且不会调用 onCreate。因此,它不会被分发。要解决此问题,只需将此行和相关行移动到 onResume
renderData(scheduleJSON); //take more important lines with it to onResume
应该是这样的:
protected void onResume()
{
super.onResume();
renderData(scheduleJSON); //take more important lines with it to onResume
}
第二种解决方案:
您可以通过将其添加到 Activity 标签中的 list 中来防止方向发生变化时 Activity 重新启动
<activity android:name="YourActivity"
android:screenOrientation="portrait"
android:configChanges="keyboardHidden|orientation"> //this line
关于安卓 : Custom ListView Disappear After Orientation Change,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24102815/
编辑:为了澄清,我想问的是:在什么情况下您会更喜欢一种语法而不是另一种语法? 有什么区别: .trigger('change') 和 .change() 两者都按预期工作。在任何情况下语法都会有所不同
这个问题在这里已经有了答案: Difference between .on('click') vs .click() (12 个答案) 关闭 6 年前。 有什么区别: $('选择器').change
我用的是Select2-4.0.0 和 $gameSelect.select2().on("change",function(e){....} 工作正常。 但是当我将它链接起来时('change')就
有一天在#haskell 上,有人提到了当字符串改变时字符串的类型应该如何改变的概念。这让我想起了我项目中的一些代码。它一直困扰着我,我说不清为什么。我现在推测,原因是我没有实现这个概念。这是下面的代
我使用了 .on("change") 事件函数,因为我的整个代码中有一部分是动态变化的。 .trigger("change") 在 .change() 中工作正常,但在 .on("change") 中
下面是一个非常简单的表单下拉列表设置。但是,on-change 事件拒绝触发...除非它更改为 ng-change。 这让我卡住了大约一个小时,因为我们在网站的其他地方使用了相同的设置(即模型属性/列
我有两个v-model 案例一: 这很好用 案例二: 即使改变 u1 也会触发 onDateChange(); 最佳答案 :change 绑定(bind)属性,如 v-bind:change=
我找到了 .and方法对于链接许多期望非常有用。 expect { click_button 'Update Boilerplate' @boilerplate_original.reload
出于合规性原因,我需要捕获所有数据库更改。我知道 Change Feed 存储此信息(并且我正在等待完全保真度来捕获删除)。目前,我一直在通过 Function 触发器读取 Change Feed 并
我添加了一个data-ng-change='getSubjectsClasswise(classBean.class_id);'上课标签,但主题未在主题 处加载标签。 一切看起来都很好,没有遇到问题
我有一组复选框,当您单击其中一个时,它们应该全部被选中。 当用户单击一个复选框时,它会检查以该类名称开头的所有其他复选框。我想要的是用户单击一个复选框,并且每次单击仅触发一次 $(".atpSelec
我在 Stack Overflow 上阅读了很多有关此问题的内容,并应用了所有建议的解决方案(getShell pack、布局、getparent 布局等...),但没有一个起作用。 我有一个带有文本
我想更改我的索引。我的数据框如下: partA = pd.DataFrame({'u1': 2, 'u2': 3, 'u3':4, 'u4':29, 'u5':4, 'u6':1, 'u7':323,
我有一个像这样的下拉菜单: Grade Year 旁边还有另一个下拉菜单: 3 4
这个问题已经有人问过,但我只停留在最基本的层面上。除了选择标记和尝试通过 jquery 捕获更改事件外,我没有向我的 html 添加任何内容。这是我的代码: $('#target').bin
我只是 Django 的新手几天。现在,当自定义表单中其他字段的值发生变化时,我需要同时更改一个字段中的值和表示形式。此时更改 MyModel 是受限。 我的应用程序/models.py: class
我正在使用 ListView 控件来显示一些数据行。有一个后台任务接收列表内容的外部更新。新收到的数据可能包含更少、更多或相同数量的项目,而且项目本身可能已更改。 ListView.ItemsSour
我在 android studio 中使用 git 插件。我的问题是当我提交更改列表(公开提交)时,但我在更改列表中的评论是错误的/丢失的,我想更改它。 问题: 有没有办法通过 AndroidStud
MyCustomObject * object=new MyCustomObject(); 假设我的许多类都使用了对象指针,但突然间我想在不更改地址的情况下更改指针的内容。 我认为 object =
我正在使用新的 KeyValue Observing。当变量发生变化时,我接到了我的观察者的电话,但 change struct 附带 newValue和 oldValue都为 nil ,所以它永远不
我是一名优秀的程序员,十分优秀!