看到同事和朋友都有在写博客,也来练练手。。。
环境:cocos code ide 1.2 , Android 新浪weiboSDK 3.0.1 ,cocos2dx 3.3F,eclipse
一、认证授权(PS:不就是登录吗?),手机有无安装微博客户端都可用
1,申请APP_KEY,注册 应用程序包名和签名,和导入eclipse,及AndroidManifest.xml里要修改的权限(文档里讲得很详细。。)
2,eclipse下 打开 AppActivity.java,把weibo demo里的constants.java 和AccessTokenKeeper.java复制到org.cocos2dx.lua目录下,并自行修改包,key等。。
3,在类AppActivity里创建 变量
private static AuthInfo mAuthInfo;
private static Oauth2AccessToken mAccessToken;
private static SsoHandler mSsoHandler;
public static AuthListener auth;
public static boolean isEnter; //是否登陆,
4,在
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
里添加
// 创建授权认证信息
mAuthInfo = new AuthInfo(this, Constants.APP_KEY, Constants.REDIRECT_URL, Constants.SCOPE);
mSsoHandler = new SsoHandler(AppActivity.this, mAuthInfo);
isEnter = false;
auth = new AuthListener();
5,回到类AppActivity里添加
class AuthListener implements WeiboAuthListener {
@Override
public void onComplete(Bundle values) {
// 从 Bundle 中解析 Token
mAccessToken = Oauth2AccessToken.parseAccessToken(values);
System.out.println("mAccessToken:" + mAccessToken);
if (mAccessToken.isSessionValid()) {
// 显示 Token
// 保存 Token 到 SharedPreferences
isEnter = true;
AccessTokenKeeper.writeAccessToken(AppActivity.this, mAccessToken);
//Toast.makeText(app, R.string.weibosdk_demo_toast_auth_success, Toast.LENGTH_SHORT).show();
System.out.println("mAccessToken: " + mAccessToken);
} else {
// 以下几种情况,您会收到 Code:
// 1. 当您未在平台上注册的应用程序的包名与签名时;
// 2. 当您注册的应用程序包名与签名不正确时;
// 3. 当您在平台上注册的包名和签名与您当前测试的应用的包名和签名不匹配时。
String code = values.getString("code");
//String message = getString(R.string.weibosdk_demo_toast_auth_failed);
if (!TextUtils.isEmpty(code)) {
//message = message + "\nObtained the code: " + code;
}
System.out.println("code:" + code);
//Toast.makeText(WeiboMain.this, message, Toast.LENGTH_LONG).show();
}
}
@Override
public void onCancel() {
}
@Override
public void onWeiboException(WeiboException e) {
Toast.makeText(AppActivity.this,
"Auth exception : " + e.getMessage(), Toast.LENGTH_LONG).show();
}
}
@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
super.onActivityResult(requestCode, resultCode, data);
// SSO 授权回调
// 重要:发起 SSO 登陆的 Activity 必须重写 onActivityResult
if (mSsoHandler != null) {
mSsoHandler.authorizeCallBack(requestCode, resultCode, data);
System.out.println("mAccessToken:" + mAccessToken);
}
}
//跳转到登陆界面
public static boolean enterWeibo(){
new Thread(new Runnable() {
public void run() {
if (isEnter == false )
{
mSsoHandler.authorize(auth);
}
}
}).start();
return isEnter;
}
6,cocos2dx代码里调用public static boolean enterWeibo() 函数看返回值为TRUE就是成功登陆了
PS : 都用的静态数据 ,是为了方便方便cocos2dx的调用