1. 程式人生 > >封裝微信微博QQ分享lib快速使用

封裝微信微博QQ分享lib快速使用

上次封裝了分享圖片資源的處理趁著有空 把分享功能進行了整合封裝

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;
     }
   })

···