自定义Facebook登录按钮 - Android

Neo*_*oVe 47 android facebook facebook-sdk-4.0

我正在遵循这个教程,但到目前为止我无法使它工作,虽然这是从一年前左右...

我正在使用androidStudo 1.2.2和FacebookSDK 4.

我想使用自定义按钮简单登录facebook,如下图所示:

例

现在,在本教程的示例中,我遇到了Session变量问题,它说它无法解决它getActivity()

有没有人在FacebookSDK4.0上试过这个?

这是正确的方法还是有更新的东西?

提前致谢!

Har*_*rja 154

第1步: 首先添加FrameLayout并使facebook按钮可见性="消失"并添加您的自定义按钮.别忘了放入xmlns:facebook="http://schemas.android.com/apk/res-auto"你的主要布局.

<FrameLayout
        android:id="@+id/FrameLayout1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >

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

        <Button
            android:id="@+id/fb"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:background="#416BC1"
            android:onClick="onClick"
            android:text="FaceBook"
            android:textColor="#ffffff"
            android:textStyle="bold" />
    </FrameLayout>
Run Code Online (Sandbox Code Playgroud)

第2步:FacebookSdkonCreate变形布局之前 初始化.

FacebookSdk.sdkInitialize(this.getApplicationContext());

第3步:将其添加到您的java文件中.

callbackManager = CallbackManager.Factory.create();

fb = (Button) findViewById(R.id.fb);
loginButton = (LoginButton) findViewById(R.id.login_button);

List < String > permissionNeeds = Arrays.asList("user_photos", "email",
    "user_birthday", "public_profile", "AccessToken");
loginButton.registerCallback(callbackManager,
new FacebookCallback < LoginResult > () {@Override
    public void onSuccess(LoginResult loginResult) {

        System.out.println("onSuccess");

        String accessToken = loginResult.getAccessToken()
            .getToken();
        Log.i("accessToken", accessToken);

        GraphRequest request = GraphRequest.newMeRequest(
        loginResult.getAccessToken(),
        new GraphRequest.GraphJSONObjectCallback() {@Override
            public void onCompleted(JSONObject object,
            GraphResponse response) {

                Log.i("LoginActivity",
                response.toString());
                try {
                    id = object.getString("id");
                    try {
                        URL profile_pic = new URL(
                            "http://graph.facebook.com/" + id + "/picture?type=large");
                        Log.i("profile_pic",
                        profile_pic + "");

                    } catch (MalformedURLException e) {
                        e.printStackTrace();
                    }
                    name = object.getString("name");
                    email = object.getString("email");
                    gender = object.getString("gender");
                    birthday = object.getString("birthday");
                } catch (JSONException e) {
                    e.printStackTrace();
                }
            }
        });
        Bundle parameters = new Bundle();
        parameters.putString("fields",
            "id,name,email,gender, birthday");
        request.setParameters(parameters);
        request.executeAsync();
    }

    @Override
    public void onCancel() {
        System.out.println("onCancel");
    }

    @Override
    public void onError(FacebookException exception) {
        System.out.println("onError");
        Log.v("LoginActivity", exception.getCause().toString());
    }
});
Run Code Online (Sandbox Code Playgroud)

第4步: 不要忘记添加以下代码.

@Override
protected void onActivityResult(int requestCode, int responseCode,
Intent data) {
    super.onActivityResult(requestCode, responseCode, data);
    callbackManager.onActivityResult(requestCode, responseCode, data);
}
Run Code Online (Sandbox Code Playgroud)

步骤5: 设置自定义按钮单击以按下FacebookLogin按钮.

public void onClick(View v) {
    if (v == fb) {
        loginButton.performClick();
    }
 }
Run Code Online (Sandbox Code Playgroud)

步骤6: 对于以编程方式注销,请使用此选项.

.LoginManager.getInstance()退出();

第7步:您可以找到用户登录或未登录的用户.

profile = Profile.getCurrentProfile().getCurrentProfile();
if (profile != null) {
    // user has logged in
} else {
    // user has not logged in
}
Run Code Online (Sandbox Code Playgroud)

  • 太棒了!我正在实施它,我只是在这一行上有一个错误:'loginButton.registerCallback(callbackManager,' 'Cannot resolve method' :( 有什么遗漏吗? (2认同)
  • 我要为错误打开一个新问题,非常感谢。 (2认同)
  • 它很好..可以举例说明如何为此制作自定义注销按钮。 (2认同)
  • 非常感谢,这篇文章很有帮助...完美解释 (2认同)
  • `loginButton.performClick();` 这就是答案,谢谢伙计:) (2认同)

She*_*bic 82

所选答案的IMO部分是一种解决办法,而不是正确的解决方案.所以需要改变以使其正确的是以下内容:

  1. 从XML中删除"com.facebook.login.widget.LoginButton"

    <com.facebook.login.widget.LoginButton
            android:id="@+id/login_button"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:visibility="gone" />
    
    Run Code Online (Sandbox Code Playgroud)
  2. 删除Java代码中对"LoginButton"的所有引用

  3. 使用Facebook的"LoginManager"类,其目的如下:

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // Some code
        callbackManager = CallbackManager.Factory.create();
        LoginManager.getInstance().registerCallback(
            callbackManager,
            new FacebookCallback < LoginResult > () {
                @Override
                public void onSuccess(LoginResult loginResult) {
                    // Handle success
                }
    
                @Override
                public void onCancel() {
                }
    
                @Override
                public void onError(FacebookException exception) {
                } 
           }
       );
    }
    
    public void onClick(View v) {
       if (v == fb) {
           LoginManager.getInstance().logInWithReadPermissions(
               this,
               Arrays.asList("user_photos", "email", "user_birthday", "public_profile")
           );
       }
    }
    
    // this part was missing thanks to wesely
    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);
        callbackManager.onActivityResult(requestCode, resultCode, data);
    }
    
    Run Code Online (Sandbox Code Playgroud)

  • 它应该是ACCEPTED的答案,因为它提供了一种清晰合法的操作登录按钮的方法. (7认同)

小智 14

这很简单.在布局文件中添加一个按钮,如

<Button
    android:layout_width="200dp"
    android:layout_height="wrap_content"
    android:text="Login with facebook"
    android:textColor="#ffff"
    android:layout_gravity="center"
    android:textStyle="bold"
    android:onClick="fbLogin"
    android:background="@color/colorPrimary"/>
Run Code Online (Sandbox Code Playgroud)

而在onClick上的LoginManager的registercallback()方法请问这个方法会自动执行.

喜欢:

  public void fbLogin(View view)
{
    // Before Edit:
    // LoginManager.getInstance().logInWithReadPermissions(this, Arrays.asList("user_photos", "email", "public_profile", "user_posts" , "AccessToken"));

    LoginManager.getInstance().logInWithReadPermissions(this, Arrays.asList("user_photos", "email", "public_profile", "user_posts"));
    LoginManager.getInstance().logInWithPublishPermissions(this, Arrays.asList("publish_actions"));
    LoginManager.getInstance().registerCallback(callbackManager,
            new FacebookCallback<LoginResult>()
            {
                @Override
                public void onSuccess(LoginResult loginResult)
                {
                    // App code
                }

                @Override
                public void onCancel()
                {
                    // App code
                }

                @Override
                public void onError(FacebookException exception)
                {
                    // App code
                }
            });
}
Run Code Online (Sandbox Code Playgroud)

玩得开心


Wes*_*ely 10

(没有足够的声誉来添加评论......)

我试过@ Shehabix的答案,在我添加之前无法接收回调

@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    callbackManager.onActivityResult(requestCode, resultCode, data);
}
Run Code Online (Sandbox Code Playgroud)

然后它工作正常.

  • 今晚晚些时候我会用这个部分更新我的答案,谢谢 (2认同)

Bis*_*mad 7

简单的答案是添加facebookButton.performClick()内部cutomBtn.setOnClickListener

    <!-- connect with Facebook -->
    <RelativeLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">

        <com.facebook.login.widget.LoginButton
            android:id="@+id/fb_connect"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:textSize="@dimen/login_fb_font_size"
            android:visibility="invisible" />

        <LinearLayout
            android:id="@+id/mfb_connect"
            style="@style/facebook_button">

            <ImageView
                style="@style/login_connect_icon"
                android:src="@drawable/ic_facebook" />

            <TextView
                style="@style/login_connect_text"
                android:text="@string/login_connect_facebook" />
        </LinearLayout>
    </RelativeLayout>
Run Code Online (Sandbox Code Playgroud)

...

private LoginButton fb_connect;
private LinearLayout mfb_connect;
Run Code Online (Sandbox Code Playgroud)

...

    // the button from facebook sdk
    fb_connect = (LoginButton) findViewById(R.id.fb_connect);
    // handle the click from my custom button to perfrom action click on facebook sdk button
    mfb_connect = (LinearLayout) findViewById(R.id.mfb_connect);
    mfb_connect.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            fb_connect.performClick();
        }
    });
Run Code Online (Sandbox Code Playgroud)

这将实现这一目标:

在此输入图像描述

  • 真有帮助:) (2认同)