我是一个机器人新手试用我的第一个项目(API级别10)。我正在我的ListActivity中下载json数据,将其填充到本地sqlite数据库并使用自定义CursorAdapter显示它。我现在在布局中只有TextViews,但是会改变它,因此自定义CursorAdapter。一切似乎都工作,数据库被填充并显示数据但滚动列表时它会闪烁,我正在覆盖文本/不干净的刷新。任何帮助,将不胜感激。我尝试在我的ItemAdapter中使用“ViewHolder”,但它没有帮助,然后将其删除。我没有指定背景..
我的代码:
public class ItemList extends ListActivity {
private static ItemDBAdapter dao;
private static ProgressDialog dialog;
private static Cursor ItemCursor;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_Item_list);
getListView().setSmoothScrollbarEnabled(true);
dao = new ItemDBAdapter(this);
dao.open();
dialog = ProgressDialog.show(this, "Download", "Downloading");
load();
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_Item_list, menu);
return true;
}
@Override
protected void onDestroy() {
if (dialog != null && dialog.isShowing()) {
dialog.dismiss();
dialog = null;
}
super.onDestroy();
}
private class DownloadDataTask extends AsyncTask<String, Void, String> {
@Override
protected String doInBackground(String... urls) {
String success = "false";
String response = "";
for (String url : urls) {
DefaultHttpClient client = new DefaultHttpClient();
HttpGet httpGet = new HttpGet(url);
try {
HttpResponse execute = client.execute(httpGet);
InputStream content = execute.getEntity().getContent();
BufferedReader buffer = new BufferedReader(new InputStreamReader(content));
String s = "";
while ((s = buffer.readLine()) != null) {
response += s;
}
JSONArray Items = new JSONArray(response);
dao.saveAll(Items);
} catch (Exception e) {
e.printStackTrace();
}
}
success = "true";
return success;
}
@Override
protected void onPostExecute(String result) {
// TODO: check if internet failed, not all data loaded, etc...
dialog.dismiss();
fillData();
if (result == "true") {
}
}
}
public void load() {
DownloadDataTask task = new DownloadDataTask();
task.execute(new String[] { "http://247.85.45.12:3000/Item/index.json" });
}
public void fillData() {
ItemCursor = dao.getAll();
ItemAdapter adapter = new ItemAdapter(this, ItemCursor);
setListAdapter(adapter);
startManagingCursor(ItemCursor);
}
}
public class ItemAdapter extends CursorAdapter {
private final Context context;
private int NAME, ADDRESS, PHONE, URL;
private LayoutInflater inflater;
public ItemAdapter(Context context, Cursor c) {
super(context, c);
this.context = context;
NAME = c.getColumnIndex(ItemDBAdapter.KEY_NAME);
URL = c.getColumnIndex(ItemDBAdapter.KEY_URL);
ADDRESS = c.getColumnIndex(ItemDBAdapter.KEY_ADDRESS);
PHONE = c.getColumnIndex(ItemDBAdapter.KEY_PHONE);
inflater = LayoutInflater.from(context);
}
@Override
public void bindView(View view, Context context, Cursor cursor) {
if (view != null) {
TextView name = (TextView)view.findViewById(R.id.name);
TextView url = (TextView)view.findViewById(R.id.url);
TextView address = (TextView)view.findViewById(R.id.address);
TextView phone = (TextView)view.findViewById(R.id.phone);
name.setText(cursor.getString(NAME));
url.setText(cursor.getString(URL));
address.setText(cursor.getString(ADDRESS));
phone.setText(cursor.getString(PHONE));
}
}
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
View v = inflater.inflate(R.layout.Item_item, null);
return v;
}
}
活动布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ListView android:id="@+id/android:list"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
列出项目布局:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
<TextView
android:id="@+id/name"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/address"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/phone"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
<TextView
android:id="@+id/url"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</LinearLayout>
答案 0 :(得分:0)
问题解决了,我已将ListView宽度和线性布局宽度更改为“match_parent”
<ListView android:id="@+id/android:list"
android:layout_width="match_parent"
android:layout_height="wrap_content"/>
我注意到那些有不洁刷新和覆盖文字的区域是未使用的区域。这解决了这个问题。根本无法在虚拟设备上看到问题,但在高分辨率星系s3上非常明显
答案 1 :(得分:-1)
尝试致电
getListView.setCacheColorHint(...);
使用项目的背景颜色,如果没有这样的颜色则为0(它将禁用缓存)。如果你根本没有背景,甚至没有窗口背景,那也可能是问题。
希望它有所帮助。