一、概述
ShareLoginSdk是一個封裝了QQ、微信、微博登錄和分享功能的庫,分享支持純文字、
純圖片、網頁(圖文)三種格式,可分享到微博、QQ好友、QQ空間、微信好友、朋友圈、微信收藏。
- 分享、登錄時會自動檢查是否安裝并給出提示;
- 由于QQ分享不支持分享純文本給好友,這一部分采用直接調用QQ的方式實現。
二、版本
已上傳jCenter,最新版本0.0.2,直接在gradle中添加依賴即可。
compile 'com.hengda.zwf:ShareLogin:0.0.2'
三、使用
封裝此庫的目的是為了在開發第三方登錄和分享功能時,盡可能的少一些拷貝和配置。詳細使用參見Demo。
項目地址:https://git.oschina.net/tailyou/HD_Frame_ShareLogin。
3.1 配置
配置非常簡單,不需要拷貝jar文件,不需要修改AndroidManifest.xml.
添加對ShareLogin的依賴即可。
compile 'com.hengda.zwf:ShareLogin:0.0.2'
修改項目的build.gradle,增加 maven { url "https://dl.bintray.com/thelasterstar/maven/" }
buildscript {
repositories {
jcenter()
maven { url "https://dl.bintray.com/thelasterstar/maven/" }
}
dependencies {
classpath 'com.android.tools.build:gradle:2.3.0'
classpath 'com.novoda:bintray-release:0.3.4'
// NOTE: Do not place your application dependencies here; they belong
// in the individual module build.gradle files
}
}
allprojects {
repositories {
jcenter()
maven { url "https://dl.bintray.com/thelasterstar/maven/" }
}
tasks.withType(Javadoc) {
options.addStringOption('Xdoclint:none', '-quiet')
options.addStringOption('encoding', 'UTF-8')
}
}
如果用到QQ平臺,需要在app的defaultConfig中配置tencentAuthId,如下所示
defaultConfig {
applicationId "com.umeng.soexample"
minSdkVersion 15
targetSdkVersion 22
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
manifestPlaceholders = [tencentAuthId: "tencent100424468"]
}
3.2 使用
3.2.1 初始化ShareLoginClient
,配置相應平臺的AppId,AppSecret等。
/**
* 初始化 ShareLoginClient
*
* @author 祝文飛(Tailyou)
* @time 2017/6/6 13:40
*/
private void initShareLoginClient() {
ShareLoginConfig slc = new ShareLoginConfig.Builder()
.debug(true)
.appName(getString(R.string.app_name))
.qq(Constants.QQ_APP_ID, Constants.QQ_SCOPE)
.weiXin(Constants.WECHAT_APP_ID, Constants.WECHAT_APP_SECRET)
.weiBo(Constants.SINA_APP_KEY, Constants.SINA_REDIRECT_URL, Constants.SINA_SCOPE)
.build();
ShareLoginClient.init(slc);
}
3.2.2 登錄,傳入登錄平臺和回調
微博
ShareLoginClient.login(mActivity, LoginPlatform.WEIBO, new LoginListener(mActivity, LoginPlatform.WEIBO));
微信
ShareLoginClient.login(mActivity, LoginPlatform.WEIXIN, new LoginListener(mActivity, LoginPlatform.WEIXIN));
ShareLoginClient.login(mActivity, LoginPlatform.QQ, new LoginListener(mActivity, LoginPlatform.QQ));
3.2.3 分享,根據分享類型創建分享內容。
1)純文本
mShareContent = new ShareContentText("我感覺這是個神奇的問題,昨天項目還一切OK");
2)純圖片
mShareContent = new ShareContentPicture(mLargeBmpPath);
3)圖文(網頁)
mShareContent = new ShareContentPage("這是標題,好像不夠長","我感覺這是個神奇的問題,昨天項目還一切OK",
"https://segmentfault.com/q/1010000009688458", mLargeBmpPath, mThumbBmpBytes);
3.2.4 分享,傳入分享平臺、分享內容、回調
以微博為例,其他分享平臺類似。
ShareLoginClient.share(mActivity, SharePlatform.WEIBO_TIME_LINE, mShareContent, new ShareListener(mActivity));