2013-03-19 6 views
15

Я создал интеграцию Facebook, используя шаги из документации 3.0. Он отлично работает, когда я развертываю приложение на своем телефоне с помощью Eclispe; однако, когда я экспортирую приложение, чтобы загрузить его в хранилище, а боковая загрузка apk, он выходит из строя со следующей ошибкой. SDK там и загружен, когда я его экспортирую. Любая подсказка о том, где я ошибаюсь?Ошибка раздувания класса com.facebook.widget.LoginButton

03-18 21:01:02.089: E/AndroidRuntime(14834): FATAL EXCEPTION: main 
03-18 21:01:02.089: E/AndroidRuntime(14834): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.telvista.facebooksupport/com.telvista.facebooksupport.SplashActivity}: android.view.InflateException: Binary XML file line #51: Error inflating class com.facebook.widget.LoginButton 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2088) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2113) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.ActivityThread.access$700(ActivityThread.java:139) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1224) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.os.Handler.dispatchMessage(Handler.java:99) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.os.Looper.loop(Looper.java:137) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.ActivityThread.main(ActivityThread.java:4918) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at java.lang.reflect.Method.invokeNative(Native Method) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at java.lang.reflect.Method.invoke(Method.java:511) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1004) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:771) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at dalvik.system.NativeStart.main(Native Method) 
03-18 21:01:02.089: E/AndroidRuntime(14834): Caused by: android.view.InflateException: Binary XML file line #51: Error inflating class com.facebook.widget.LoginButton 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.view.LayoutInflater.createView(LayoutInflater.java:613) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.view.LayoutInflater.createViewFromTag(LayoutInflater.java:687) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.view.LayoutInflater.rInflate(LayoutInflater.java:746) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.view.LayoutInflater.rInflate(LayoutInflater.java:749) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.view.LayoutInflater.inflate(LayoutInflater.java:489) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.view.LayoutInflater.inflate(LayoutInflater.java:396) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.view.LayoutInflater.inflate(LayoutInflater.java:352) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at com.android.internal.policy.impl.PhoneWindow.setContentView(PhoneWindow.java:306) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.Activity.setContentView(Activity.java:1901) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at com.telvista.facebooksupport.SplashActivity.onCreate(SplashActivity.java:29) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.Activity.performCreate(Activity.java:5048) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1094) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2052) 
03-18 21:01:02.089: E/AndroidRuntime(14834): ... 11 more 
03-18 21:01:02.089: E/AndroidRuntime(14834): Caused by: java.lang.reflect.InvocationTargetException 
03-18 21:01:02.089: E/AndroidRuntime(14834): at java.lang.reflect.Constructor.constructNative(Native Method) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at java.lang.reflect.Constructor.newInstance(Constructor.java:417) 
03-18 21:01:02.089: E/AndroidRuntime(14834): at android.view.LayoutInflater.createView(LayoutInflater.java:587) 
03-18 21:01:02.089: E/AndroidRuntime(14834): ... 23 more 
03-18 21:01:02.089: E/AndroidRuntime(14834): Caused by: java.lang.NoClassDefFoundError: com.facebook.android.R$color 
03-18 21:01:02.089: E/AndroidRuntime(14834): at com.facebook.widget.LoginButton.<init>(LoginButton.java:204) 
03-18 21:01:02.089: E/AndroidRuntime(14834): ... 26 more 

Вот манифеста:

<?xml version="1.0" encoding="utf-8"?> 
<manifest xmlns:android="http://schemas.android.com/apk/res/android" 
    package="com.t.facebooksupport" 
    android:versionCode="21" 
    android:versionName="2.1" > 

    <uses-sdk 
    android:minSdkVersion="11" 
    android:targetSdkVersion="17" /> 
    <uses-permission android:name="android.permission.INTERNET"/> 
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /> 
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /> 

    <application 
    android:allowBackup="false" 
    android:icon="@drawable/t_logo" 
    android:label="@string/app_name"> 

    <activity 
     android:theme="@android:style/Theme.NoTitleBar" 
     android:name="com.t.facebooksupport.SplashActivity" 
     android:icon="@drawable/t_logo" 
     android:label="@string/app_name" > 
     <intent-filter> 
     <action android:name="android.intent.action.MAIN" /> 

     <category android:name="android.intent.category.LAUNCHER" /> 
     </intent-filter> 
    </activity> 
    <activity 
     android:name="com.t.facebooksupport.MainActivity"> 
    </activity> 
    <activity 
     android:name="com.t.facebooksupport.ViewPost"> 
    </activity> 
    <meta-data android:name="com.facebook.sdk.ApplicationId" android:value="@string/app_id"/> 
    <activity android:label="@string/app_name" android:name="com.facebook.LoginActivity"></activity> 

    </application> 

</manifest> 

Всплеск страница с кнопкой входа:

package com.t.facebooksupport; 

import java.util.Arrays; 
import java.util.Map; 

import com.facebook.Request; 
import com.facebook.Response; 
import com.facebook.Session; 
import com.facebook.SessionState; 
import com.facebook.UiLifecycleHelper; 
import com.facebook.model.GraphUser; 
import com.facebook.widget.LoginButton; 
import com.t.facebooksupport.helper.PostConstants; 

import android.app.Activity; 
import android.content.Intent; 
import android.content.SharedPreferences; 
import android.os.Bundle; 
import android.util.Log; 

public class SplashActivity extends Activity { 

    private UiLifecycleHelper uiHelper; 
    private boolean isResumed = false; 

    @Override 
    protected void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.splash); 

     uiHelper = new UiLifecycleHelper(this, callback); 
     Session session = Session.getActiveSession(); 

     if (session != null && session.isOpened()) { 
      startActivity(new Intent(SplashActivity.this, MainActivity.class)); 
     } 
     LoginButton authButton = (LoginButton) findViewById(R.id.login_button); 
     authButton.setReadPermissions(Arrays.asList("email")); 

    } 

    private void onSessionStateChange(Session session, SessionState state, Exception exception) { 
     if (isResumed) { 
      if (state.isOpened()) { 
       Request.executeMeRequestAsync(session, new Request.GraphUserCallback() { 

        @Override 
        public void onCompleted(GraphUser user, Response response) { 
         if (user != null) { 
          // Display the parsed user info 
          SharedPreferences settings = getSharedPreferences(PostConstants.PREFS_NAME, Activity.MODE_PRIVATE); 
          SharedPreferences.Editor editor = settings.edit(); 
          editor.putString("fb_id", user.getId()); 
          editor.putString("fullname", user.getFirstName() + " " + user.getLastName()); 
          editor.putString("firstname", user.getFirstName()); 
          editor.putString("lastname", user.getLastName()); 
          editor.putString("image_loc", "https://graph.facebook.com/" + user.getId() + "/picture?type=large"); 
          editor.putString("user_id", user.asMap().get("email").toString()); 
          editor.putString("email", user.asMap().get("email").toString()); 
          editor.putString("page", "1"); 
          editor.putString("count", "30"); 
          editor.putString("token", ""); 
          editor.commit(); 

          startActivity(new Intent(SplashActivity.this, MainActivity.class)); 
         } 
        } 
       }); 
      } else if (state.isClosed()) { 
      } 
     } 
    } 

    @Override 
    public void onResume() { 
     super.onResume(); 
     uiHelper.onResume(); 
     isResumed = true; 
    } 

    @Override 
    public void onPause() { 
     super.onPause(); 
     uiHelper.onPause(); 
     isResumed = false; 
    } 

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

    @Override 
    public void onDestroy() { 
     super.onDestroy(); 
     uiHelper.onDestroy(); 
    } 

    @Override 
    protected void onSaveInstanceState(Bundle outState) { 
     super.onSaveInstanceState(outState); 
     uiHelper.onSaveInstanceState(outState); 
    } 

    private Session.StatusCallback callback = new Session.StatusCallback() { 
     @Override 
     public void call(Session session, SessionState state, Exception exception) { 
      onSessionStateChange(session, state, exception); 
     } 
    }; 

} 

EDIT: ---------------- -------------------------------

Вот что я пробовал:

  1. Пробовал очистить мой проект и FacebookSDK примерно в 50 раз.
  2. Удалено FacebookSDK и прочитано 3 раза.

Я пробовал все, что я могу найти в Интернете, и не могу понять, в чем проблема.

+0

попытку загрузить новую молнию в SDK – Darussian

+0

я попробовал, что пару раз. –

+0

Я тоже получаю эту ошибку, но с активностью HelloFacebookSample! –

ответ

1

Единственный способ, которым я решил исправить это, - включить весь SDK в свой проект. Теперь это работает. Не предпочтительное решение, но оно работает.

+0

Это единственный способ сделать это ... Без всего SDK он не имеет понятия, какой цвет относится к – Darussian

+0

Как это сделать? Поместите facebookdk.jar в папку lib, но я все равно получаю ту же ошибку –

+0

Я определяю ошибку, потому что маршрут к классу является неправильным. Чтобы получить решение, я переписал путь к моему классу (тогда adt стал глупым, и мне пришлось перезапустить) и сделано. –

0

Одним из решений является добавление в проект вашего проекта SDK для проекта project.properties.

Как:

android.library.reference.1=../libfacebook/facebook-android-sdk-3.0.1/facebook 
1

Я имел ту же ошибку, даже когда я попытался запустить его в эмуляторе.

Моя проблема была более связана с тем, что я добавил Sdk Facebook в путь сборки вместо добавления проекта на вкладке «Свойства». Я получил ответ от another stackoverflow answer

4

У меня была такая же ошибка, я просто очистил свои проекты (facebook sdk и текущий проект), и это было разрешено.

0

У меня также была такая же ошибка, и только с помощью поддержки android-support-v4.jar с поддержкой android-v13.jar решена проблема.

0

на всякий случай .. Если кому-то все еще нужно, очистите только проект facebook, а затем добавьте его в качестве библиотеки в свой проект. Это решило мою проблему

3

После добавления Facebook в качестве модуля вы должны добавить их к зависимостям Gradle, добавив следующую строку в зависимости блока:

compile project(':facebook') 

Я надеюсь, что это может помочь.

11

Если вы используете Facebook SDK 4.x, то обратите внимание, что имя пакета изменилось. Сейчас com.facebook.login.widget.LoginButton

1

Просто инициализируйте FacebookSdk.sdkИнтициализировать (getApplicationContext()); в вашем классе Application. Поскольку класс Application инициализируется еще до инициализации ваших действий.

сделать так же, как это:

общественного класса ApplicationController расширяет приложение {

@Override 
public void onCreate() { 
    super.onCreate(); 
    FacebookSdk.sdkInitialize(getApplicationContext()); 
} 

}

53

FacebookSdk.sdkInitialize(getApplicationContext());

это перед setContentView

setContentView(R.layout.activity_home); 
+0

Отлично. Спасибо. – Ferrrmolina

+0

Идеальное решение – JAF

+0

Это идеальный ответ для инициализации sdk перед setcontentView. – Vishal

5

Я получал эту ошибку, потому что я установил представление содержимого перед sdkInitialize. В руководстве по началу работы есть комментарий, относящийся к этому.

https://developers.facebook.com/docs/android/getting-started#androidstudio

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    FacebookSdk.sdkInitialize(getApplicationContext()); 
    // Initialize the SDK before executing any other operations, 
    // especially, if you're using Facebook UI elements. 
} 

Так что мой код теперь выглядит следующим образом:

@Override 
public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    FacebookSdk.sdkInitialize(getApplicationContext()); 
    setContentView(R.layout.activity_main); 
} 
0

Я попытался Programatically создать экземпляр LoginButton программно как

LoginButton loginButton = new LoginButton(this); 

и добавил это к LinearLayout

fbLoginButton = (LinearLayout) findViewById(R.id.fb_login_view); 
    fbLoginButton.addView(loginButton); 

А вот проблеск моего макета XML

<LinearLayout 
      android:layout_width="wrap_content" 
      android:layout_height="40dip" 
      android:id="@+id/fb_login_view" 
      android:layout_centerInParent="true" 
      android:layout_gravity="center_horizontal" 
      android:text="connect_with_facebook"/> 

Это конечно после редактирования предложенной @Lalit Kumar's answer Позвольте мне знать, если я что-нибудь не хватает.

0

Если вы добавите библиотеку facebook в приложение в Properties-> Android, вы должны удалить facebook.jar в вашем пути facebookdk/bin/facebook.jar. Это вызывает ошибку при соединении в eclipse. Затем вы очищаете свой фейсбук sdk и свое приложение. Я надеюсь, что все будет хорошо.

4

вы должны инициализировать facebook SDK, прежде чем setContentView, поэтому добавьте следующую строку прямо над setContentView

FacebookSdk.sdkInitialize(getApplicationContext()); 
+0

Я забыл это. Помог мне! :-) –

+0

помог мне так +1 – TapanHP

Смежные вопросы