我正在使用基于ActionBarSherlock的活动和片段。要从SQLite数据库中读取行,我正在尝试使用Loader
而不是ContentProvider
,而我正试图让LoaderEx为我工作。
我遇到了一个顽固的问题:在我的片段onCreateLoader
回调中,ADT一直给我一个错误:
"Cannot convert from SQLiteCursorLoader to Loader<Cursor>"
我正在使用Android v4支持库。由于DEX错误,我从ActionBarSherlock和LoaderEx中删除了android-support-v4.jar
,并将其添加到我的基础项目中。然后我让ABS和LoaderEx都依赖于它。
ABS和LoaderEx都作为库项目添加。
我已经检查过我只使用v4导入。 LoaderExDemo也可以在模拟器中编译和工作。
这些是我片段的导入:
import com.actionbarsherlock.app.SherlockListFragment;
import android.database.Cursor;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.ListView;
import android.support.v4.widget.SimpleCursorAdapter;
import android.support.v4.app.LoaderManager;
import android.support.v4.app.LoaderManager.LoaderCallbacks;
import android.support.v4.content.CursorLoader;
import android.support.v4.content.Loader;
import com.commonsware.cwac.loaderex.SQLiteCursorLoader;
这是我的片段声明:
public class MeetingListFragment
extends SherlockListFragment
implements LoaderManager.LoaderCallbacks<Cursor> {
private JournalDatabaseHelper db = null;
private SimpleCursorAdapter adapter = null;
private SQLiteCursorLoader loader = null;
这是getLoader
回调方法:
public Loader<Cursor> onCreateLoader(int loaderId, Bundle args) {
loader = new SQLiteCursorLoader(getSherlockActivity().getApplicationContext(),
db,
"SELECT _ID, meeting_timestamp, meeting_desc FROM meeting " +
"ORDER BY meeting_timestamp DESC",
null);
return loader; // <<< this is the line of the ADT/Eclipse error
}
我和他一起来回走了好几个小时。关于SO的一些答案在该领域有点,但没有真正的解决方案。出了什么问题?
答案 0 :(得分:5)
你有:
import com.commonsware.cwac.loaderex.SQLiteCursorLoader;
这是错误的SQLiteCursorLoader
,因为它是Loader
框架的本机API Level 11+版本的版本。如the LoaderEx documentation中所述,如果您使用Android支持包中的com.commonsware.cwac.loaderex.acl.SQLiteCursorLoader
反向端口,则应使用Loader
。