Android片段:从数据库缓慢加载数据

时间:2016-03-08 05:48:44

标签: android database android-fragments

我有一个带有列表视图的fragmentB。列表视图中的数据来自本地数据库。当我点击fragmentA中的texview时,我正在用数据库中的数据打开fragmentB。但是在一小段时间内,我可以在片段B加载之前看到fragmentA。 FragmentB有asyncTask进行数据库查询。如何避免这一段次的延迟。

从FragmentA转到fragmentB的代码

borerangeselect.setOnClickListener(new OnClickListener() {
            BoreRangeFragment boreranges = new BoreRangeFragment();

            @Override
            public void onClick(View v) {

                rangeboregrade = boregradeselect.getText().toString();
                if (!rangeboregrade.equalsIgnoreCase("select")) {
                    FragmentManager fragmentManager = getFragmentManager();
                    FragmentTransaction ft = fragmentManager.beginTransaction();

                    ft.add(R.id.content_frame, boreranges);
                    FragmentChangeActivity.fragmentStack.lastElement().onPause();
                    ft.hide(FragmentChangeActivity.fragmentStack.lastElement());
                    FragmentChangeActivity.fragmentStack.push(boreranges);
                    ft.commit();

                }
            }
        });

FragmentB OnActvitycreated()

@Override
    public void onActivityCreated(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onActivityCreated(savedInstanceState);

            new MyBoreRangeTask().executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR,ToleranceFragment.rangeboregrade);
    }

2 个答案:

答案 0 :(得分:0)

如果您正在使用SQLite,那么最好使用LoaderManagers,它们在使用db时非常易于使用且效率很高。

public class SampleActivity extends Activity implements LoaderManager.LoaderCallbacks<Cursor> {

  public Loader<Cursor> onCreateLoader(int id, Bundle args) { ... }

  public void onLoadFinished(Loader<Cursor> loader, Cursor data) { ... }

  public void onLoaderReset(Loader<Cursor> loader) { ... }

  /* ... */
}

以下是Android文档的网址,您可以参考以获取更多信息, http://developer.android.com/reference/android/app/LoaderManager.html

希望这可以帮助您解决问题。

答案 1 :(得分:0)

您可以使用onPreExecute方法中的进度对话框,并将其隐藏在doInBackground()方法或查询结束的位置。 希望它有效。