封裝微信微博QQ分享lib快速使用
阿新 • • 發佈:2019-02-05
上次封裝了分享圖片資源的處理趁著有空 把分享功能進行了整合封裝
ShareLib
整合微信微博QQ分享功能
1.接入工程
在主工程的build.gradle 中新增maven倉庫地址
maven { url "https://dl.bintray.com/thelasterstar/maven/" }// 主要針對微博分享sdk
並新增sharelib依賴
2.初始化分享sdk(配置分享sdk key值
// 初始化分享sdk各個平臺的註冊key值
ShareManager.initWxShareSdk("wxappid");
ShareManager.initSinaSdk("新浪AppId" ,"重定向地址","scrop");
ShareManager.initQqSdk("qqAppId","分享成功後返回按鈕的名稱");
3.構造分享平臺及資料資料
// 構建分享平臺數據
SharePlamFormData data1 = new SharePlamFormData()
.withQqMessageBuilder(new SharePlamFormData.QQMessageBuilder().buidWebMessage("http://www.baidu.com","http://f8.topitme.com/8/25/80/1125177570eea80258o.jpg","標題","內容" ))
.withWxChatMessageBuilder(new SharePlamFormData.WxChatMessageBuilder().buildedrImageMessage("http://f8.topitme.com/8/25/80/1125177570eea80258o.jpg",null))
.withWxMomentMessageBuilder(new SharePlamFormData.WxMomentMessageBuilder().buidWebMessage("http://www.baidu.com","http://f8.topitme.com/8/25/80/1125177570eea80258o.jpg" ,"標題","內容"))
.withSinaMessageBuilder(new SharePlamFormData.SinaMessageBuilder().builderImageWithTextMessage("標題","內容","http://www.baidu.com","http://f8.topitme.com/8/25/80/1125177570eea80258o.jpg"));
QQMessageBuilder 構造分享到QQ的資料
WxChatMessageBuilder 構造分享到微信好友的分享資料
WxMomentMessageBuilder 構造分享到朋友圈的分享資料
SinaMessageBuilder 構造分享到新浪微博的分享資料
可以根據需求構造需要的分享平臺,如
.withQqMessageBuilder(newSharePlamFormData.QQMessageBuilder().buidWebMessage("http://www.baidu.com","http://f8.topitme.com/8/25/80/1125177570eea80258o.jpg","標題","內容"))
.withWxChatMessageBuilder(new SharePlamFormData.WxChatMessageBuilder().buildedrImageMessage("http://f8.topitme.com/8/25/80/1125177570eea80258o.jpg",null))
.withWxMomentMessageBuilder(new SharePlamFormData.WxMomentMessageBuilder().buidWebMessage("http://www.baidu.com","http://f8.topitme.com/8/25/80/1125177570eea80258o.jpg","標題","內容"))
此種情況只會新增 QQ 微信好友 微信朋友圈 三個分享按鈕.
4.發起分享
4.1 直接部分不調起分享控制元件
new ShareManager(this)
.withPlamFormData(data1.getPlamFormDatas())
.share();
```
此種分享只會分享平臺集合資料的第一項資料。
4.2 調起分享控制元件進行分享
new ShareManager(this)
.withPlamFormData(data1.getPlamFormDatas())
.open();
5.自定義
分享lib支援自定義分享控制元件的佈局 但平臺按鈕ID需固定
QQ:btn_share_qq 微信好友:btn_share_wechat 微信朋友圈:btn_share_wechat_moments 微博分享:btn_share_weibo
View customView = View.inflate(MainActivity.this,R.layout.view_custom_dialog,null);
final ShareManager shareManager = new ShareManager(MainActivity.this)
.withCustomDialogView(customView) // 自定義view
.withDialogDimAmount(0)
.withPlamFormData(data1.getPlamFormDatas())
.withPlamformClickListener(new ShareDialog.OnPlamFormClickListener() { // 點選平臺按鈕動作回撥 可以用於打點等
@Override
public void onPlamFormClick(View view, int plamForm) {
Toast.makeText(MainActivity.this, "plamForm:" + plamForm, Toast.LENGTH_LONG).show();
}
});
自定義圖片變換操作
// 額外圖片的獲取
private Observable<Bitmap> dowloadExtraObservable = Observable.create(emitter -> {
Bitmap bitmap = Glide.with(getApplicationContext())
.asBitmap()
.load("https://timgsa.baidu.com/timg?image&quality=80&size=b9999_10000&sec=1515476758278&di=1a65b298738b7467faff309b7df72fb3&imgtype=0&src=http%3A%2F%2Fscimg.jb51.net%2Fallimg%2F161207%2F102-16120H243090-L.jpg")
.submit(Target.SIZE_ORIGINAL, Target.SIZE_ORIGINAL)
.get();
Log.e(TAG, "onNext");
emitter.onNext(bitmap);
emitter.onComplete();
});
// 當額外圖片準備好後的後續操作 此功能可用於對分享的圖片新增水印或者二維碼等操作
shareManager.withExtralOperator(dowloadExtraObservable ,new BiFunction<Bitmap, Bitmap, Bitmap>() {
@Override
public Bitmap apply(Bitmap posterBitmap, Bitmap bitmap2) throws Exception {
Bitmap finalBitmap = Bitmap.createBitmap(posterBitmap.getWidth(), posterBitmap.getHeight(), Bitmap.Config.ARGB_8888);
Canvas canvas = new Canvas(finalBitmap);
canvas.drawBitmap(posterBitmap, 0, 0, null);
canvas.drawBitmap(bitmap2, 0, 0, null);
Log.e(TAG, "setBitmapOpreatorFuncation");
return finalBitmap; //返回最終的資料
}
})
```
//更新分享平臺數據
當分享過程中某一平臺的資料有變化時可以更新單個平臺的資料。
shareManager.updataPlamForm(new SharePlamFormData.SinaMessageBuilder()
.builderImageWithTextMessage("標題1","內容1","http://www.baidu.com","http://f8.topitme.com/8/25/80/1125177570eea80258o.jpg")
.build());
“`
自定義下載
lib預設採用的是glide進行圖片的下載
public class GlideImageDownload implements IShareImageDownLoad {
@Override
public Bitmap dowwnload(Context context, String url) throws Exception {
RequestOptions options = new RequestOptions().diskCacheStrategy(DiskCacheStrategy.ALL);
return Glide.with(context)
.asBitmap()
.load(url)
.apply(options)
.submit()
.get();
}
}
···
如
···
shareManager.withDownload(new IShareImageDownLoad() {
@Override
public Bitmap dowwnload(Context context, String url) throws Exception {
return null;
}
})
···