2015-09-23 30 views
-1

所以我在我的Android應用上遇到異常,我不知道從哪裏來。是的,我的代碼現在是一個完整的混亂,現在試圖解決它。setContentView異常(R.layout.activity_main);

不知何故,我的setcontentview指向某處null,但我真的不知道在哪裏和爲什麼。

MainActivity.java

package com.example.nan.spymap; 

import android.app.ActionBar; 
import android.app.Activity; 
import android.content.Intent; 
import android.os.Bundle; 
import android.support.v4.app.FragmentActivity; 
import android.util.Log; 
import android.view.Menu; 
import android.view.MenuItem; 
import android.view.View; 
import android.widget.Button; 
import android.widget.TextView; 

import com.facebook.CallbackManager; 
import com.facebook.FacebookCallback; 
import com.facebook.FacebookException; 
import com.facebook.FacebookSdk; 
import com.facebook.Profile; 
import com.facebook.login.LoginManager; 
import com.facebook.login.LoginResult; 
import com.facebook.login.widget.LoginButton; 
import com.parse.LogInCallback; 
import com.parse.Parse; 
import com.parse.ParseFacebookUtils; 
import com.parse.ParseUser; 
import com.parse.SaveCallback; 
import com.parse.SignUpCallback; 

import java.text.ParseException; 

public class MainActivity extends FragmentActivity { 

    private CallbackManager callbackManager; 

    private TextView info; 
    private LoginButton loginButton; 
    Button mActionButton; 


    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     Parse.initialize(this, "KEY", "KEY"); 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 


     //final ParseUser user = new ParseUser(); 
     //user.setUsername("my name"); 
     //user.setPassword("my pass"); 
     //user.setEmail("[email protected]"); 

// other fields can be set just like with ParseObject 
     // user.put("phone", "650-555-0000"); 
/** 
* 

     user.signUpInBackground(new SignUpCallback() { 
      @Override 
      public void done(com.parse.ParseException e) { 
       if (e == null) { 
        // Hooray! Let them use the app now. 
       } else { 
        // Sign up didn't succeed. Look at the ParseException 
        // to figure out what went wrong 
       } 
      } 
     }); 
*/ 


     ParseFacebookUtils.initialize(this); 
     FacebookSdk.sdkInitialize(getApplicationContext()); 
     callbackManager = CallbackManager.Factory.create(); 


     info = (TextView)findViewById(R.id.info); 
     loginButton = (LoginButton)findViewById(R.id.login_button); 

     loginButton.registerCallback(callbackManager, new FacebookCallback<LoginResult>() { 

      @Override 
      public void onSuccess(LoginResult loginResult) { 
       startActivity(new Intent(MainActivity.this, MapActivity.class)); 
       Profile profile = Profile.getCurrentProfile(); 
       Log.d("facebook id",profile.getId()); 
       Log.d("facebook name", profile.getFirstName()); 

      } 

      @Override 
      public void onCancel() { 
       info.setText("Login attempt cancelled."); 
      } 

      @Override 
      public void onError(FacebookException e) { 
       info.setText("Login attempt failed."); 
      } 

     }); 

     mActionButton = (Button) findViewById(R.id.Sbutton); 
     mActionButton.setOnClickListener(new View.OnClickListener() { 
      public void onClick(View view) { 
       startActivity(new Intent(MainActivity.this, SignupActivity.class)); 

      } 
     }); 
     View decorView = getWindow().getDecorView(); 
// Hide the status bar. 
     int uiOptions = View.SYSTEM_UI_FLAG_FULLSCREEN; 
     decorView.setSystemUiVisibility(uiOptions); 
// Remember that you should never show the action bar if the 
// status bar is hidden, so hide that too if necessary. 

     ActionBar actionBar = getActionBar(); 
     actionBar.hide(); 

    } 

    @Override 
    protected void onActivityResult(int requestCode, int resultCode, Intent data) { 
     callbackManager.onActivityResult(requestCode, resultCode, data); 
     super.onActivityResult(requestCode, resultCode, data); 
     ParseFacebookUtils.onActivityResult(requestCode, resultCode, data); 
    } 

} 

我的主要活動XML

<?xml version="1.0" encoding="utf-8"?> 
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="match_parent" android:layout_height="match_parent" 
    android:padding="16dp" 
    android:id="@+id/spymap" 
    android:background="#79dbff"> 

    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:id="@+id/info" 
     android:layout_alignParentLeft="true" 
     android:layout_alignParentTop="true" 
     android:textSize="18sp" 
     /> 

    <com.facebook.login.widget.LoginButton 
     android:id="@+id/login_button" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_centerInParent="true" 
     /> 

    <Button 
     style="?android:attr/buttonStyleSmall" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:text="Sign Up" 
     android:id="@+id/Sbutton" 
     android:layout_marginTop="40dp" 
     android:layout_below="@+id/login_button" 
     android:layout_centerHorizontal="true" /> 
    > 

    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:textAppearance="?android:attr/textAppearanceLarge" 
     android:text="Get stalked" 
     android:id="@+id/textView" 
     android:layout_above="@+id/login_button" 
     android:layout_centerHorizontal="true" 
     android:layout_marginBottom="68dp" /> 

    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:textAppearance="?android:attr/textAppearanceSmall" 
     android:text="Don't worry, totally not gonna steal your data" 
     android:id="@+id/textView2" 
     android:layout_alignParentBottom="true" 
     android:layout_centerHorizontal="true" 
     android:layout_marginBottom="47dp" /> 

</RelativeLayout> 

和錯誤;

09-23 12:18:11.289 13106-13106/? E/AndroidRuntime﹕ FATAL EXCEPTION: main 
    Process: com.example.nan.spymap, PID: 13106 
    java.lang.RuntimeException: Unable to start activity ComponentInfo{com.example.nan.spymap/com.example.nan.spymap.MainActivity}: android.view.InflateException: Binary XML file line #17: Error inflating class com.facebook.login.widget.LoginButton 
      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2325) 
      at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387) 
      at android.app.ActivityThread.access$800(ActivityThread.java:151) 
      at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303) 
      at android.os.Handler.dispatchMessage(Handler.java:102) 
      at android.os.Looper.loop(Looper.java:135) 
      at android.app.ActivityThread.main(ActivityThread.java:5254) 
      at java.lang.reflect.Method.invoke(Native Method) 
      at java.lang.reflect.Method.invoke(Method.java:372) 
      at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
      at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 
    Caused by: android.view.InflateException: Binary XML file line #17: Error inflating class com.facebook.login.widget.LoginButton 
      at android.view.LayoutInflater.createView(LayoutInflater.java:633) 
      at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:743) 
      at android.view.LayoutInflater.rInflate(LayoutInflater.java:806) 
      at android.view.LayoutInflater.inflate(LayoutInflater.java:504) 
      at android.view.LayoutInflater.inflate(LayoutInflater.java:414) 
      at android.view.LayoutInflater.inflate(LayoutInflater.java:365) 
      at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:378) 
      at android.app.Activity.setContentView(Activity.java:2145) 
      at com.example.nan.spymap.MainActivity.onCreate(MainActivity.java:45) 
      at android.app.Activity.performCreate(Activity.java:5990) 
      at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106) 
      at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278) 
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387) 
            at android.app.ActivityThread.access$800(ActivityThread.java:151) 
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303) 
            at android.os.Handler.dispatchMessage(Handler.java:102) 
            at android.os.Looper.loop(Looper.java:135) 
            at android.app.ActivityThread.main(ActivityThread.java:5254) 
            at java.lang.reflect.Method.invoke(Native Method) 
            at java.lang.reflect.Method.invoke(Method.java:372) 
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 
    Caused by: java.lang.reflect.InvocationTargetException 
      at java.lang.reflect.Constructor.newInstance(Native Method) 
      at java.lang.reflect.Constructor.newInstance(Constructor.java:288) 
      at android.view.LayoutInflater.createView(LayoutInflater.java:607) 
            at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:743) 
            at android.view.LayoutInflater.rInflate(LayoutInflater.java:806) 
            at android.view.LayoutInflater.inflate(LayoutInflater.java:504) 
            at android.view.LayoutInflater.inflate(LayoutInflater.java:414) 
            at android.view.LayoutInflater.inflate(LayoutInflater.java:365) 
            at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:378) 
            at android.app.Activity.setContentView(Activity.java:2145) 
            at com.example.nan.spymap.MainActivity.onCreate(MainActivity.java:45) 
            at android.app.Activity.performCreate(Activity.java:5990) 
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106) 
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278) 
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387) 
            at android.app.ActivityThread.access$800(ActivityThread.java:151) 
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303) 
            at android.os.Handler.dispatchMessage(Handler.java:102) 
            at android.os.Looper.loop(Looper.java:135) 
            at android.app.ActivityThread.main(ActivityThread.java:5254) 
            at java.lang.reflect.Method.invoke(Native Method) 
            at java.lang.reflect.Method.invoke(Method.java:372) 
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 
    Caused by: The SDK has not been initialized, make sure to call FacebookSdk.sdkInitialize() first. 
      at com.facebook.internal.Validate.sdkInitialized(Validate.java:136) 
      at com.facebook.AccessTokenTracker.<init>(AccessTokenTracker.java:55) 
      at com.facebook.login.widget.LoginButton$2.<init>(LoginButton.java:561) 
      at com.facebook.login.widget.LoginButton.configureButton(LoginButton.java:561) 
      at com.facebook.FacebookButtonBase.<init>(FacebookButtonBase.java:66) 
      at com.facebook.login.widget.LoginButton.<init>(LoginButton.java:200) 
            at java.lang.reflect.Constructor.newInstance(Native Method) 
            at java.lang.reflect.Constructor.newInstance(Constructor.java:288) 
            at android.view.LayoutInflater.createView(LayoutInflater.java:607) 
            at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:743) 
            at android.view.LayoutInflater.rInflate(LayoutInflater.java:806) 
            at android.view.LayoutInflater.inflate(LayoutInflater.java:504) 
            at android.view.LayoutInflater.inflate(LayoutInflater.java:414) 
            at android.view.LayoutInflater.inflate(LayoutInflater.java:365) 
            at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:378) 
            at android.app.Activity.setContentView(Activity.java:2145) 
            at com.example.nan.spymap.MainActivity.onCreate(MainActivity.java:45) 
            at android.app.Activity.performCreate(Activity.java:5990) 
            at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1106) 
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2278) 
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2387) 
            at android.app.ActivityThread.access$800(ActivityThread.java:151) 
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1303) 
            at android.os.Handler.dispatchMessage(Handler.java:102) 
            at android.os.Looper.loop(Looper.java:135) 
            at android.app.ActivityThread.main(ActivityThread.java:5254) 
            at java.lang.reflect.Method.invoke(Native Method) 
            at java.lang.reflect.Method.invoke(Method.java:372) 
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:903) 
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:698) 
+0

在錯誤顯然是提到: 「的SDK尚未初始化,請務必先調用FacebookSdk.sdkInitialize()」,所以前設置該視圖做到這一點 –

+0

@NicklasN:嘗試FacebookSdk.sdkInitialize(this);而不是FacebookSdk。sdkInitialize(getApplicationContext()); – AndiGeeky

+0

嘿,我不知道它,但你可以寫** Parse.initialize(這,「EsOSbCtBvwx6S2ZojAP3JWh7TcNiy5czMguNMYmh」,「nLUoS1u1408ZYUt6YZFeiPvZz0iI0WPncjvnmh0h」); **剛剛超級();方法。 –

回答

-3

你的printStackTrace明確指出Error inflating class com.facebook.login.widget.LoginButton

您使用自定義窗口小部件com.facebook.login.widget.LoginButton經過它的文檔,並檢查您的充氣

檢查this問題

+0

@AndiGeeky我不認爲stackoverflow是個人調試器。在這裏,人們不會解決可以通過一點搜索時間找到的問題。 – user3616287

+0

請點擊這裏 - > http://stackoverflow.com/help/how-to-answer .. !! – AndiGeeky

+0

我一直在尋找解決方案整個早上,我只是非常新的android和java,它不是很容易理解所有的答案,當它不直接適用於您的應用程序..:/ – NicklasN

1

認沽以下行:

FacebookSdk.sdkInitialize(getApplicationContext()); 

此的setContentView()之前

0

我編輯的OnCreate此;

@Override 
    protected void onCreate(Bundle savedInstanceState) { 

     FacebookSdk.sdkInitialize(this); 
     Parse.initialize(this, "KEY", "KEY"); 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.activity_main); 

     ParseFacebookUtils.initialize(this); 

而且現在的工作..

0

堆棧跟蹤是相當清楚的:

Caused by: The SDK has not been initialized, make sure to call FacebookSdk.sdkInitialize() first. 

需要調用

FacebookSdk.sdkInitialize(getApplicationContext()); 

setContentView(R.layout.activity_main); 
0

您的堆棧跟蹤狀態

The SDK has not been initialized, make sure to call FacebookSdk.sdkInitialize() first. 

FacebookSdk參見文檔:

這個函數初始化的Facebook SDK,Facebook的SDK函數的行爲是不確定的,如果這個功能沒有被調用。它應該儘可能早地被調用。

所以只要將相關的初始化了

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    Parse.initialize(this, "KEY", "KEY"); 
    ParseFacebookUtils.initialize(this); 
    FacebookSdk.sdkInitialize(getApplicationContext()); 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    [...] 
} 
相關問題