Facebook按钮片段无法打开和终止应用程序

时间:2017-02-27 06:09:51

标签: android android-studio android-fragments facebook-javascript-sdk

我用facebook按钮创建了一个片段。它工作了一段时间,现在当我尝试使用导航应用程序抽屉打开片段时,它正在崩溃应用程序。

下面是堆栈跟踪:

  

E / AndroidRuntime:致命异常:主要                     过程:com.myclass.myapp,PID:3526                     java.lang。 NullPointerException :尝试调用虚方法'void com.facebook.AccessTokenTracker。 startTracking ()'   在null对象引用上                             在com.myclass.myapp.FacebookLogin.onCreate( FacebookLogin .java:82)                             在android.support.v4.app.Fragment.performCreate(Fragment.java:2177)                             在android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1244)                             在android.support.v4.app.FragmentTransition.addToFirstInLastOut(FragmentTransition.java:1080)                             在android.support.v4.app.FragmentTransition.calculateFragments(FragmentTransition.java:971)                             在android.support.v4.app.FragmentTransition.startTransitions(FragmentTransition.java:95)                             在android.support.v4.app.FragmentManagerImpl.executeOpsTogether(FragmentManager.java:2143)                             在android.support.v4.app.FragmentManagerImpl.optimizeAndExecuteOps(FragmentManager.java:2098)                             在android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:2008)                             在android.support.v4.app.FragmentManagerImpl $ 1.run(FragmentManager.java:710)                             在android.os.Handler.handleCallback(Handler.java:751)                             在android.os.Handler.dispatchMessage(Handler.java:95)                             在android.os.Looper.loop(Looper.java:154)                             在android.app.ActivityThread.main(ActivityThread.java:6077)                             at java.lang.reflect.Method.invoke(Native Method)                             在com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run(ZygoteInit.java:865)                             在com.android.internal.os.ZygoteInit.main(ZygoteInit.java:755)       申请已终止。

片段类代码:

    public class FacebookLogin extends Fragment {

    //initialize WebView
    private TextView mTextDetails;
    private CallbackManager mCallbackManager;
    private AccessTokenTracker mTokenTracker;
    private ProfileTracker mProfileTracker;

    private FacebookCallback<LoginResult> mCallback=new FacebookCallback<LoginResult>() {
        @Override
        public void onSuccess(LoginResult loginResult) {

            AccessToken accessToken = loginResult.getAccessToken();
            Profile profile = Profile.getCurrentProfile();
            displayWelcomeMessage(profile);
        }

        @Override
        public void onCancel() {

        }

        @Override
        public void onError(FacebookException error) {

        }
    };

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        FacebookSdk.sdkInitialize(getActivity().getApplicationContext());
        mCallbackManager=CallbackManager.Factory.create();
        AccessTokenTracker tracker=new AccessTokenTracker() {
            @Override
            protected void onCurrentAccessTokenChanged(AccessToken oldAccessToken, AccessToken currentAccessToken) {

            }
        };

        ProfileTracker profileTracker=new ProfileTracker() {
            @Override
            protected void onCurrentProfileChanged(Profile oldProfile, Profile currentProfile) {
                displayWelcomeMessage(currentProfile);
            }
        };

        mTokenTracker.startTracking();
        mProfileTracker.startTracking();
  }

    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        return inflater.inflate(R.layout.facebook_login, container, false);
   }

   private void displayWelcomeMessage(Profile profile){
        if (profile != null){
            mTextDetails.setText(profile.getName());
        }

    }



    @Override
    public void onViewCreated(View view, @Nullable Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);
        LoginButton loginButton = (LoginButton) view.findViewById(R.id.login_button);
        loginButton.setReadPermissions("user_friends");
        loginButton.setFragment(this);
        loginButton.registerCallback(mCallbackManager,mCallback);

        mTextDetails = (TextView)view.findViewById(R.id.text_details);
    }

    @Override
    public void onResume() {
        super.onResume();
        Profile profile=Profile.getCurrentProfile();
        displayWelcomeMessage(profile);
    }

    @Override
    public void onStop(){
        super.onStop();
        mTokenTracker.stopTracking();
        mProfileTracker.stopTracking();
    }

    @Override
    public void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        mCallbackManager.onActivityResult(requestCode,resultCode, data);
    }
}

1 个答案:

答案 0 :(得分:0)

您没有在onCreate()

中初始化mTokenTracker
 mTokenTracker = new AccessTokenTracker() {
        @Override
        protected void onCurrentAccessTokenChanged(AccessToken oldToken, AccessToken newToken) {
            updateWithToken(newToken);
        }
    };
    mTokenTracker.startTracking();

您的mProfileTracker未初始化

mProfileTracker = new ProfileTracker() {
                                    @Override
                                    protected void onCurrentProfileChanged(com.facebook.Profile profile_old, com.facebook.Profile profile_new) {
                                        // profile2 is the new profile
                                        profile = profile_new;
                                        mProfileTracker.stopTracking();
                                    }
                                };
                                mProfileTracker.startTracking();