Ошибка LoaderManager и java.lang.NullPointerException

Я учусь фрагментации в Android, я пишу эту простую программу: В этом приложении я хочу создать представление списка, и я не буду создавать фоновый поток, этот поток записать в файл журнала

Это основная деятельность

public class MainActivity extends FragmentActivity {
    public static final String TAG = "Test_Loader"; 
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Log.i(TAG, "Start  !!!!!!!!!!!!!!");    
        if (getSupportFragmentManager().findFragmentById(android.R.id.content) == null) {
            getSupportFragmentManager().beginTransaction().replace(android.R.id.content, new listFragment()).commit();

        }
    }
}

Это мой ListFragment:

public class listFragment extends ListFragment implements LoaderCallbacks<Void> {

    public static final String TAG = "Test_Loader";
    private ProgressBar mProgressView;
    private LinearLayout mFormView;
    private int valTest = 0;

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.activity_main, null);
        Log.i(TAG, "start listFragment");
        return view;
    }

    @Override
    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);


        ArrayList<Map<String, String>> list = buildData();
        String[] from = { "name", "purpose" };
        int[] to = { R.id.recordTitolo, R.id.recordDescrizione };
        SimpleAdapter adapter = new SimpleAdapter(getActivity(), list,
                R.layout.record, from, to);
        setListAdapter(adapter);

        /** IL LOADERMANAGER */
        getLoaderManager().initLoader(0, null, this);

    }


    private ArrayList<Map<String, String>> buildData() {
        ArrayList<Map<String, String>> list = new ArrayList<Map<String, String>>();
        list.add(putData("android", "mobile"));
        list.add(putData("winphone7 ", "windows"));
        list.add(putData("iPhone", "iPhone"));
        return list;
        // TODO Auto-generated method stub

    }


    private HashMap<String, String> putData(String name, String purpose) {
        HashMap<String, String> item = new HashMap<String, String>();
        item.put("name", name);
        item.put("purpose", purpose);
        return item;
    }


    @Override
    public Loader<Void> onCreateLoader(int id, Bundle args) {
        Log.i(TAG, "onCreateLoader(): id=" + id);
        AsyncTaskLoader<Void> loader = new AsyncTaskLoader<Void>(getActivity()) {
            @Override
            public Void loadInBackground() {

                try {

                Log.i(TAG, "loadInBackground(): doing some work....");
                    for (int i = 0; i < 4; ++i) {
                    Log.i(TAG, "backgroud: number " + i);
                    }
                    valTest = 100;
                    Thread.sleep(5000);                                     
                } catch (InterruptedException e) {
                    Log.d(TAG, "ERROR" + e);
                }

                Log.i(TAG, "Stop backgroud");
                return null;
            }
        };
        Log.i(TAG, "return");
        loader.forceLoad();
        return loader;
    }

    // metodo per implementare dopo caricato questo metido viene richiamato
    @Override
    public void onLoadFinished(Loader<Void> arg0, Void arg1) {
        toggleLoading(false);
        buildForm();
        // TODO Auto-generated method stub

    }
    private void buildForm() {

        // TODO Auto-generated method stub
        Log.i(TAG, "Valuet: " + valTest);
    }

    private void toggleLoading(boolean b) {
        // TODO Auto-generated method stub
        mProgressView.setVisibility(b ? View.VISIBLE : View.GONE); 
        mFormView.setGravity(b ? Gravity.CENTER : Gravity.TOP); 
    }

    @Override
    public void onLoaderReset(Loader<Void> arg0) {
        // TODO Auto-generated method stub
        Log.i(TAG, "start onLoaderReset()");
    }

}

здесь вы можете увидеть activity_main.xml

activity_main.xml

Теперь я думаю, что проблема присутствует в getLoaderManager но я не понимаю, как это исправить.

редактировать

Когда я запускаю свое приложение, я вижу это в logcat:

08-08 15:13:09.347: E/AndroidRuntime(341): FATAL EXCEPTION: main
08-08 15:13:09.347: E/AndroidRuntime(341): java.lang.NullPointerException
08-08 15:13:09.347: E/AndroidRuntime(341):  at com.example.test3.listFragment.toggleLoading(listFragment.java:128)
08-08 15:13:09.347: E/AndroidRuntime(341):  at com.example.test3.listFragment.onLoadFinished(listFragment.java:114)
08-08 15:13:09.347: E/AndroidRuntime(341):  at com.example.test3.listFragment.onLoadFinished(listFragment.java:1)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.support.v4.app.LoaderManagerImpl$LoaderInfo.callOnLoadFinished(LoaderManager.java:425)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.support.v4.app.LoaderManagerImpl$LoaderInfo.onLoadComplete(LoaderManager.java:393)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.support.v4.content.Loader.deliverResult(Loader.java:103)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.support.v4.content.AsyncTaskLoader.dispatchOnLoadComplete(AsyncTaskLoader.java:221)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.support.v4.content.AsyncTaskLoader$LoadTask.onPostExecute(AsyncTaskLoader.java:61)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.support.v4.content.ModernAsyncTask.finish(ModernAsyncTask.java:461)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.support.v4.content.ModernAsyncTask.access$500(ModernAsyncTask.java:47)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.support.v4.content.ModernAsyncTask$InternalHandler.handleMessage(ModernAsyncTask.java:474)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.os.Handler.dispatchMessage(Handler.java:99)
08-08 15:13:09.347: E/AndroidRuntime(341):  at android.os.Looper.loop(Looper.java:123)

Я думаю, что проблема в этом коде

private void toggleLoading(boolean b) {
    // TODO Auto-generated method stub
    mProgressView.setVisibility(b ? View.VISIBLE : View.GONE); 
    mFormView.setGravity(b ? Gravity.CENTER : Gravity.TOP);
}

когда я удаляю этот код, все работает хорошо, но я не знаю, потому что у меня такая ситуация.

1 ответ

Решение

Вы получаете эту проблему, потому что похоже, что вы не инициализируете mProgressView а также mFormView поля. Если они определены в макете, вам нужно что-то вроде этого:

public View onCreateView(LayoutInflater inflater, ViewGroup container,
        Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.activity_main, null);

    mProgressView = (ProgressBar)view.findViewById(R.id.progress_view_id);
    mFormView = (LinearLayout)view.findViewById(R.id.form_view_id);

    Log.i(TAG, "start listFragment");
    return view;
}
Другие вопросы по тегам