Хабр Курсы для всех
РЕКЛАМА
Практикум, Хекслет, SkyPro, авторские курсы — собрали всех и попросили скидки. Осталось выбрать!
mRowIds.moveToPosition(position);
long rowId = mRowIds.getLong(0);
Cursor cursor = mDataSource.getRowById(rowId);
cursor.moveToFirst();package me.ilich.hellodocumentview;
import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.os.Bundle;
import android.util.Log;
import android.view.Menu;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ListView;
import android.widget.TextView;
public class QuickMainActivity extends Activity {
ListView mListView;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_list);
mListView = (ListView) findViewById(R.id.list);
final QuickAdapter a = new MyQuickAdapter(this, new MyDataSource());
mListView.setAdapter(a);
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
class MyQuickAdapter extends QuickAdapter {
public MyQuickAdapter(Context context, DataSource dataSource) {
super(context, dataSource);
}
@Override
public View getView(int arg0, View arg1, ViewGroup arg2) {
long t1 = System.currentTimeMillis();
View result = super.getView(arg0, arg1, arg2);
long t2 = System.currentTimeMillis();
long dt = t2-t1;
if(dt>10){
Log.i("Sokolov", arg0 + " " + dt);
}
return result;
}
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
View view = getLayoutInflater().inflate(
android.R.layout.simple_list_item_1, null);
ViewHolder vh = new ViewHolder();
vh.tv = (TextView) view.findViewById(android.R.id.text1);
view.setTag(vh);
return view;
}
@Override
public void bindView(View view, Context context, Cursor cursor) {
ViewHolder vh = (ViewHolder) view.getTag();
if(vh!=null){
vh.tv.setText(cursor.getString(cursor.getColumnIndex("text1")));
}
}
class ViewHolder {
TextView tv;
}
}
class MyDataSource implements QuickAdapter.DataSource {
@Override
public Cursor getRowIds() {
return ((HelloDocumentView) getApplication()).mDatabase.rawQuery(
"SELECT rowid FROM table1", new String[]{});
}
@Override
public Cursor getRowById(long rowId) {
return ((HelloDocumentView)getApplication()).mDatabase.rawQuery("SELECT * FROM table1 WHERE rowid = ?", new String[]{Long.toString(rowId)});
}
}
}
package me.ilich.hellodocumentview;
import android.app.Application;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
public class HelloDocumentView extends Application {
public SQLiteDatabase mDatabase;
@Override
public void onCreate() {
super.onCreate();
mDatabase = openOrCreateDatabase("/mnt/sdcard/db.sqlite", Context.MODE_PRIVATE, null);
}
}
Маленькая хитрость для отображения большого объёма данных в ListView