java - 将非 Activity 类中的回调方法结果传递给android Activity 类?

标签 java android

我需要创建 twitter fabric 可重用组件。我的第一步是通过简单地调用类中的方法来允许使用 twitter 登录。

代码

import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.widget.Toast;

import com.twitter.sdk.android.Twitter;
import com.twitter.sdk.android.core.Callback;
import com.twitter.sdk.android.core.Result;
import com.twitter.sdk.android.core.TwitterAuthConfig;
import com.twitter.sdk.android.core.TwitterAuthToken;
import com.twitter.sdk.android.core.TwitterException;
import com.twitter.sdk.android.core.TwitterSession;
import com.twitter.sdk.android.core.identity.TwitterAuthClient;
import com.twitter.sdk.android.core.models.Tweet;
import com.twitter.sdk.android.core.services.StatusesService;

import io.fabric.sdk.android.Fabric;


public class TwitterAuth {

private String CONSUMER_KEY;
private String CONSUMER_SECRET;
private Context context;
private TwitterAuthClient client;
private StatusesService service;

public TwitterAuth(Context context, String CONSUMER_KEY, String CONSUMER_SECRET) {
    this.CONSUMER_KEY = CONSUMER_KEY;
    this.CONSUMER_SECRET = CONSUMER_SECRET;
    this.context = context;
    configureKey();
}

public void configureKey() {
    TwitterAuthConfig authConfig = new TwitterAuthConfig(CONSUMER_KEY, CONSUMER_SECRET);
    Fabric.with(context, new Twitter(authConfig));
}

public void doLogin() {
    client = new TwitterAuthClient();
    client.authorize((Activity) context, new Callback<TwitterSession>() {
        @Override
        public void success(Result<TwitterSession> twitterSessionResult) {
            final TwitterSession session = Twitter.getSessionManager().getActiveSession();
            TwitterAuthToken authToken = session.getAuthToken();
            String token = authToken.token;
            String secret = authToken.secret;
            String userName = session.getUserName();
            Toast.makeText(context, "TWITTER EASY LIB TEST :: Done Login With \n Username :" + userName + " \n Token :" + token + "\n Secret :" + secret, Toast.LENGTH_LONG).show();
            //Toast.makeText(MainActivity.this, "success", Toast.LENGTH_SHORT).show();
        }

        @Override
        public void failure(TwitterException e) {
            Toast.makeText(context, "TWITTER EASY LIB TEST :: failure", Toast.LENGTH_SHORT).show();
        }
    });
}


public void doLogout() {
    Twitter.getSessionManager().clearActiveSession();
}

public void publishTweet(String tweet) {
    service = Twitter.getInstance().getApiClient().getStatusesService();
    service.update(tweet, null, null, null, null, null, null, null, new Callback<Tweet>() {
        @Override
        public void success(Result<Tweet> tweetResult) {
            Toast.makeText(context, "Tweet Updated !",
                    Toast.LENGTH_SHORT).show();
        }

        @Override
        public void failure(TwitterException e) {
            Toast.makeText(context, "Error occured !",
                    Toast.LENGTH_SHORT).show();
        }
    });
}

public void onActivityResult(int requestCode, int resultCode, Intent data) {
    client.onActivityResult(requestCode, resultCode, data);
}

}

Activity

package codelynks.twitter.twitterintegration;


import android.content.Intent;
import android.os.Bundle;
import android.support.v7.app.ActionBarActivity;
import android.view.View;
import android.widget.Button;

import com.easytweet.TwitterAuth;

public class CheckLib extends ActionBarActivity {
private Button cus;
private TwitterAuth auth;
private String CONSUMER_KEY = "", CONSUMER_SECRET = "";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    auth = new TwitterAuth(CheckLib.this, CONSUMER_KEY, CONSUMER_SECRET);
    setContentView(R.layout.activity_main);
    cus = (Button) findViewById(R.id.cusbutton);
    cus.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            auth.doLogin();
        }
    });
}

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

@Override
protected void onResume() {
    super.onResume();
}

@Override
protected void onDestroy() {
    super.onDestroy();
}
 }

这里我将通过回调方法获取结果

   public void success(Result<TwitterSession> twitterSessionResult) {} 
                          **or**
           public void failure(TwitterException e) {}

我如何将此结果(成功/失败)传递给 Activity CheckLib 以执行进一步操作。?

任何帮助将不胜感激:)

最佳答案

您可以在您的 TwitterAuth.class 中设置成功或失败的监听器,然后在您的 Activity (CheckLib.class) 中设置此监听器以在成功或失败时通知您,像这样:

public class TwitterAuth {
private TwitterLoginListener listener;
public void setListener( TwitterLoginListener listener){
     this.listener = listener;    
}

Interfase TwitterLoginListener{
    public void success(Result<TwitterSession> twitterSessionResult);
    public void failure(TwitterException e);
} 
.
. 
.

在成功和失败的方法中你需要填写监听器:

在成功方法中(在 TwitterAuth.class 中):

if(listener != null){
    listener.success(twitterSessionResult);
}  

在失败方法中(在 TwitterAuth.class 中):

if(listener != null){
    listener.failure(e);
} 

然后在您的 Activity 中设置监听器:

.
.
.

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
auth = new TwitterAuth(CheckLib.this, CONSUMER_KEY, CONSUMER_SECRET);
auth.setListener(new TwitterLoginListener{

     @Override
     public void success(Result<TwitterSession> twitterSessionResult){
        //login success
     }

     @Override
     public void failure(TwitterException e){
        //login failed
     }
}); 
.
.
.

关于java - 将非 Activity 类中的回调方法结果传递给android Activity 类?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29667961/

相关文章:

java - 如何中途停止异步任务

java - Spring PropertySourcesPlaceholderConfigurer : local properties vs environment ones?

java - 锁定等待超时超过 JPA 插入

java - 从对话框到 Activity 的按钮位置

java - 来自数据库的微调器值给出错误

android - 如果没有 @Inject 构造函数或 dagger kotlin 中的 @Provides-annotated 方法,则无法提供

android - Genymotion安装报错 "the setup files are corrupted.Please obtain a new copy"

输入字符后 JavaFX 将焦点转移到 TextField

java - 如果我发现错误会发生什么?

javascript - ScriptEngineManager eval(..) 在求和时返回删节值