Asynctaskloader在更改方向后未调用onfinedload



一些背景信息:我正在使用活动> parent fragment(持有ViewPager(>儿童片段。使用添加,删除按钮动态添加子片段。我正在使用MVP架构

实际问题:在Child Fragment中,我们有ListView通过主持人使用ASYNCTASKLOADER填充。

儿童碎片:

//Initialize Views
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
                         Bundle savedInstanceState) {
    root = inflater.inflate(R.layout.fragment_search_view_child, container, false);
.......
     mSearchViewPresenter= new SearchViewPresenter(
            getActivity(),
             new GoogleSuggestLoader(getContext()),
            getActivity().getLoaderManager(),
            this, id
    );
    SearchList list=new SearchList();
    //requestList from presenter
    searchListAdapter =new SearchViewListAdapter(getActivity(), list, this);
    listView.setAdapter(searchListAdapter);
......
    return root;
}

@Override
public void onResume(){
super.onResume();
    mSearchViewPresenter.start();
    searchBar.addTextChangedListener(textWatcher);

}

在主持人类中,我们有:

public SearchViewPresenter(@NonNull Context context, @NonNull GoogleSuggestLoader googleloader,@NonNull LoaderManager loaderManager,
                               @NonNull SearchViewContract.View tasksView, @NonNull String id) {
        // mLoader = checkNotNull(loader, "loader cannot be null!");
        mLoaderManager = checkNotNull(loaderManager, "loader manager cannot be null");
        // mTasksRepository = checkNotNull(tasksRepository, "tasksRepository cannot be null");
        mSearchView = checkNotNull(tasksView, "tasksView cannot be null!");
        mSearchView.setPresenter(this);
        searchList=new SearchList();
        this.googleLoader=googleloader;
        this.context=context;
        this.id=loaderID;
      //  this.id=Integer.parseInt(id);
    }
    @Override
    public void start() {

        Log.d("start>initloader","log");
        mLoaderManager.restartLoader(1, null, this);
    }
    //TODO implement these when you are ready to use loader to cache local browsing history

    @Override
    public android.content.Loader<List<String>> onCreateLoader(int i, Bundle bundle) {
        int loaderid=googleLoader.getId();
        Log.d("Loader: ", "created");
        googleLoader=new GoogleSuggestLoader(context);
        googleLoader.setUrl("");
        googleLoader.setUrl(mSearchView.provideTextQuery());
        return googleLoader;
    }
    @Override
    public void onLoadFinished(android.content.Loader<List<String>> loader, List<String> data) {
        Log.d("Loader: ", "loadFinished");
        searchList.clear();
        for (int i = 0; i < data.size(); ++i) {
            searchList.addListItem(data.get(i), null, LIST_TYPE_SEARCH, android.R.drawable.btn_plus);
           Log.d("data Entry: ",i+ " is: "+searchList.getText(i));
        }
        mSearchView.updateSearchList(searchList);
    }
    @Override
    public void onLoaderReset(android.content.Loader<List<String>> loader) {
    }

也在演示者中有此代码,该代码是由正在编辑的片段视图上的EditText框触发的。

  @Override
        public void notifyTextEntry() {
            //DETERMINE HOW TO GIVE LIST HERE
           // Dummy List
            Log.d("notifyTextEntry","log");
            if(googleLoader==null)googleLoader=new GoogleSuggestLoader(context);
                googleLoader.setUrl(mSearchView.provideTextQuery());
           // mLoaderManager.getLoader(id).abandon();

            mLoaderManager.getLoader(1).forceLoad();
            mLoaderManager.getLoader(1).onContentChanged();
            Log.d("length ", searchList.length().toString());
        //    googleLoader.onContentChanged();
        }

最后我们在这里有加载程序:

public class GoogleSuggestLoader extends AsyncTaskLoader<List<String>>{
    /** Query URL */
    private String mUrl;
    private static final String BASE_URL="https://suggestqueries.google.com/complete/search?client=firefox&oe=utf-8&q=";
    private List<String> suggestions =new ArrayList<>();

    public GoogleSuggestLoader(Context context) {
        super(context);
        this.mUrl=BASE_URL;
    }
    public void setUrl(String mUrl){
        this.mUrl=BASE_URL+mUrl;
    };
    @Override
    protected void onStartLoading() {forceLoad(); }
    @Override
    public List<String> loadInBackground() {
        if (mUrl == null) {
            return null;
        }
        try {
            suggestions = new ArrayList<>();
            Log.d("notifyinsideLoader","log");
            String result=GoogleSuggestParser.parseTemp(mUrl);
            if(result!=null) {
                JSONArray json = new JSONArray(result);
                if (json != null) {
                JSONArray inner=new JSONArray((json.getString(1)));
                    if(inner!=null){
                        for (int i = 0; i < inner.length(); ++i) {
                            //only show 3 results
                            if(i==3)break;
                            Log.d("notifyinsideLoader",inner.getString(i));
                            suggestions.add(inner.getString(i));
                        }
                    }
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        } catch (JSONException e) {
            e.printStackTrace();
        }
        return suggestions;
    }


}

所以问题:

该代码将数据罚款罚款到片段上的ListView。当方向更改时,加载程序未调用OnloadFined。我已经测试了加载程序,并且正在处理数据罚款。我已经尝试了forceload,并且在主持人中无济于事。如果您需要更多信息,或者我应该只使用rxjava之类的其他内容,请告诉我。但是我真的很想让这个工作。在您问之前,我已经看到类似的问题,例如:asynctaskloader:OnloadFined在方向更改后未调用,但是我使用相同的ID,因此不存在此问题。

答案在此页面上,AnnctaskLoader未调用OnloadFined 但是,没有提供有关如何搬到这一点的细节。因此,让我在这里为以后的其他人解释一下。

支持库是用于片段的。因此,负责回调的类必须从支持库中导入和实现正确的方法。与您使用MVP一样,您的演示者必须从支持LoaderManager延伸。即:导入android.support.v4.app.loadermanager;然后实现正确的回调。

喜欢

@Override
    public android.support.v4.content.Loader<List<String>> onCreateLoader(int i, Bundle bundle) {
...
return new loader
}

@Override
    public void onLoadFinished(android.support.v4.content.Loader<List<String>> loader, List<String> data) {
//do something here to your UI with data
}

其次:加载程序本身必须从支持 asynctaskloader 延伸。即:导入android.support.v4.content.asynctaskloader;