3

Facebookの基本的なことをアプリで完全に管理したいので、個人情報の要求、友達リスト、ウォールへの投稿を行います。このすべては、API 3.0 を使用して、フラグメントを使用せずに行う必要があります。

現在、これを行う唯一の例、つまりSessionLoginSampleActivityに行き詰まっています。現在の私のプログラムは、私のレイアウトに合わせた例にすぎません。投稿の最後に記載されています。残念ながら、その例は認証を超えるものではなく、Facebook と非同期通信を行い、ユーザー データなどを取得する方法を理解できません。

それを行う完全な例はどこかにありますか?

認証後、ユーザーの写真、名前、友達リストをフラグメントなしで非同期に取得するにはどうすればよいですか? どこに書いたらいいですか?新しいリスナーを作成する必要がありますか?

質問は奇妙で基本的なように見えるかもしれませんが、私は非常に強力に見えますが、私の目には非常に曖昧に見える Facebook API に本当に夢中になっています。

「フラグメントを使用してください!」と答えないでください。:)

どうもありがとうございました!

public class FbActivity extends Activity {
private Button buttonLoginLogout, b_friends, b_challenge;
private TextView t_instructions, t_username;
private ProfilePictureView profilePictureView;
private Session.StatusCallback statusCallback = new SessionStatusCallback();

public FbActivity() {
}

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.facebook_activity);
    findAll();

    Settings.addLoggingBehavior(LoggingBehavior.INCLUDE_ACCESS_TOKENS);

    Session session = Session.getActiveSession();
    if (session == null) {
        if (savedInstanceState != null) {
            session = Session.restoreSession(this, null, statusCallback, savedInstanceState);
        }
        if (session == null) {
            session = new Session(this);
        }
        Session.setActiveSession(session);
        if (session.getState().equals(SessionState.CREATED_TOKEN_LOADED)) {
            session.openForRead(new Session.OpenRequest(this).setCallback(statusCallback));
        }
    }

    updateView();
}
@Override
public void onStart() {
    super.onStart();
    Session.getActiveSession().addCallback(statusCallback);
}
@Override
public void onStop() {
    super.onStop();
    Session.getActiveSession().removeCallback(statusCallback);
}
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    Session.getActiveSession().onActivityResult(this, requestCode, resultCode, data);
}
@Override
protected void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    Session session = Session.getActiveSession();
    Session.saveSession(session, outState);
}

private void findAll() {
    buttonLoginLogout = (Button)findViewById(R.id.buttonLoginLogout);
    t_instructions = (TextView)findViewById(R.id.instructionsOrLink);
    b_friends = (Button)findViewById(R.id.buttonFindFriend);
    b_challenge = (Button)findViewById(R.id.buttonFindNewChallenge);
    profilePictureView = (ProfilePictureView)findViewById(R.id.profilePicture);
    t_username = (TextView)findViewById(R.id.textViewUserName);
}



private void setVisibility(boolean opened) {
    if (opened) {
        buttonLoginLogout.setText(R.string.logout);
        buttonLoginLogout.setOnClickListener(new OnClickListener() {
            public void onClick(View view) { onClickLogout(); }
        });
        t_instructions.setVisibility(TextView.INVISIBLE);
        b_friends.setVisibility(Button.VISIBLE);
        b_challenge.setVisibility(Button.VISIBLE);
        t_username.setVisibility(TextView.VISIBLE);
        profilePictureView.setVisibility(ProfilePictureView.VISIBLE);
    } else {
        buttonLoginLogout.setText(R.string.login);
        buttonLoginLogout.setOnClickListener(new OnClickListener() {
            public void onClick(View view) { onClickLogin(); }
        });
        t_instructions.setVisibility(TextView.VISIBLE);
        b_friends.setVisibility(Button.INVISIBLE);
        b_challenge.setVisibility(Button.INVISIBLE);
        t_username.setVisibility(TextView.VISIBLE);
        profilePictureView.setVisibility(ProfilePictureView.INVISIBLE);
    }

}
private void updateView() {
    Session session = Session.getActiveSession();
    setVisibility(session.isOpened());
}

private void onClickLogin() {
    Session session = Session.getActiveSession();
    if (!session.isOpened() && !session.isClosed()) {
        session.openForRead(new Session.OpenRequest(this).setCallback(statusCallback));
    } else {
        Session.openActiveSession(this, true, statusCallback);
    }
}
private void onClickLogout() {
    Session session = Session.getActiveSession();
    if (!session.isClosed()) {
        session.closeAndClearTokenInformation();
    }
}   
private class SessionStatusCallback implements Session.StatusCallback {
    @Override
    public void call(Session session, SessionState state, Exception exception) {
        updateView();
    }
}

}
4

3 に答える 3

2

最初にlogged_off.xmlというページがあり、そこにloginButtonだけがあり、目的はログインすることであり、正しくログインした後、ビューをlogged_in.xmlという別のページに変更するとします。

だからあなたは持っています:

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.logged_off);
Settings.addLoggingBehavior(LoggingBehavior.INCLUDE_ACCESS_TOKENS);

loginButton = (Button) findviedbyid(R.id.loginButton);
loginButton.setOnClickListener(new OnClickListener() {
        public void onClick(View view) { 
session.openForRead(new Session.OpenRequest(this).setCallback(statusCallback).setPermissions(PERMISSIONS));  
}
    });

//here we check if our session exists. if it does exists we directly go to our page logged_in.xml otherwise we stay in logged_off.xml waiting for the user to click on our loginButton

Session session = Session.getActiveSession();
if (session == null) {
    if (savedInstanceState != null) {
        session = Session.restoreSession(this, null, statusCallback, savedInstanceState);
    }
    if (session == null) {
        session = new Session(this);
    }
    Session.setActiveSession(session);
}else{
if(session.session.isOpened()){
setContentView(R.layout.logged_in);
}
}
}

この関数は、ログインを試みた後に呼び出されるため、ここでは、実際に正しくログインしたかどうかを確認し、正しくログインした場合は、ページをlogged_in.xmlに変更します。したがって、これを変更します。

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

これに:

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
Session.getActiveSession().onActivityResult(this, requestCode, resultCode, data);

if(session.session.isOpened()){
    setContentView(R.layout.logged_in);
}
}

もちろん、 setContentView(R.layout.logged_in); を変更できます。あなたが望むもので。

それが役に立ったことを願っています!

PS: これらの関数をすべて保持します。

@Override
public void onStart() {
super.onStart();
Session.getActiveSession().addCallback(statusCallback);
}

@Override
public void onStop() {
super.onStop();
Session.getActiveSession().removeCallback(statusCallback);
}

@Override
protected void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
Session session = Session.getActiveSession();
Session.saveSession(session, outState);
}

private class SessionStatusCallback implements Session.StatusCallback {
@Override
public void call(Session session, SessionState state, Exception exception) {
    //updateView();
}
}
于 2013-04-09T01:19:24.240 に答える
2

それ以上の bw 互換性を維持する必要があります。私たちが行ったことは、facebook API の v1.2.2 バージョンを github から取得し、代わりにそれを使用することでした。ドキュメントを見つけるのは困難ですが、サンプル アプリケーションは直接使用できます...そしてフラグメントはどこにも見えません。

git clone git://github.com/facebook/facebook-android-sdk.git
cd facebook-and*
git checkout v1.2.2

新しいバージョンのイメージをライブラリ プロジェクトに追加するなど、いくつかのことも追加する必要があるようですが、それは大したことではありません。

于 2013-02-12T18:49:42.490 に答える
0

Facebook 開発者のチュートリアルを参考にして、フラグメントに関連するすべてのものを削除することをお勧めします。たとえば、とメソッドをfragments manager保持する必要があるため、セッションの状態とその変更を知ることができます。UiLifecycleHelperonSessionStateChange

onSessionStateChange の例と、それを変更して新しいアクティビティを開始する方法を次に示します。フラグメントのないアプリを開発しています

private void onSessionStateChange(Session session, SessionState state, Exception exception) {

                if (state.isOpened()) { 
                    // If the session state is open:
                    // Show the SendRequest Activity
                    Intent sendRequest = new Intent(this, SendRequest.class);  // If session isOpened we launch the INTENT to Pick Friends
                    startActivity(sendRequest);
                }else if (state.isClosed()){
                    uiHelper.onResume();
                }
        } 
于 2013-07-05T00:32:57.950 に答える