ShareSDKUtils,封装的分享工具类

小咪咪 2022-06-10 04:48 314阅读 0赞

介绍

ShareSDKUtils是基于ShareSDK提供的API进行封装的工具类,方便于我们开发时分享的调用,支持使用默认的GUI,也支持自定义界面,点击事件中调用分享到某一个ShareSDK支持的第三方平台,使用ShareSDKUtils需要依赖ShareSDK提供的开发包。

使用的方式为:如ShareSDKUtils.getInstance(Context context).useDefaultGUI(需要传入的那些参数);

Mob相关文档介绍,提供参考

分享到指定平台

不同平台分享内容的详细说明

接下来介绍ShareSDKUtils封装的方法:







 

/**

* @description: 分享的工具类
*/

public class ShareSDKUtils {

private static Handler mHandler = new Handler();

private static ShareSDKUtils mInstance;

private static Object mLock = new Object();

private static Context mContext;

public static ShareSDKUtils getInstance(Context context){

if (mInstance == null){

synchronized (mLock){

if (mInstance == null){

mInstance = new ShareSDKUtils();

mContext = context;
}
}
}
return mInstance;
}

使用默认的GUI分享

App中分享按钮点击事件中,调用此方法可以弹出ShareSDK自带的默认分享的弹框,包括你选择的那些第三方平台,最后一个参数是平台分享后操作的回调,有分享成功、分享失败、取消分享三个操作的回调,如果不需要监听分享动作的回调,可以传null,默认对应的操作会弹出吐司”分享成功”,”分享失败”,”分享已取消”的提示。

  1. /** * 使用默认的分享GUI * * @param title 标题 * @param content 内容 * @param imgUrl 图片的Url * @param siteUrl 网站的Url * @param shareListener 分享的回调 */
  2. private static void useDefaultGUI(String title, String content, String imgUrl, String siteUrl, PlatformActionListener shareListener) {
  3. ShareSDK.initSDK(mContext);
  4. OnekeyShare oks = new OnekeyShare();
  5. //关闭sso授权
  6. //oks.disableSSOWhenAuthorize();
  7. // title标题,印象笔记、邮箱、信息、微信、人人网和QQ空间使用
  8. oks.setTitle(title);
  9. // titleUrl是标题的网络链接,仅在人人网和QQ空间使用
  10. oks.setTitleUrl(siteUrl);
  11. //分享网络图片,新浪微博分享网络图片需要通过审核后申请高级写入接口,否则请注释掉测试新浪微博
  12. oks.setImageUrl(imgUrl);
  13. // url仅在微信(包括好友和朋友圈)中使用
  14. oks.setUrl(siteUrl);
  15. // site是分享此内容的网站名称,仅在QQ空间使用
  16. oks.setSite("");
  17. // siteUrl是分享此内容的网站地址,仅在QQ空间使用
  18. oks.setSiteUrl(siteUrl);
  19. // text是分享文本,所有平台都需要这个字段
  20. oks.setText(content + "\n链接: " + siteUrl);
  21. //设置回调
  22. oks.setCallback(shareListener);
  23. // 启动分享GUI
  24. oks.show(mContext);
  25. }

自定义GUI的分享

如果不使用ShareSDK自带的GUI,自定义分享的布局,则在对应的点击事件中,调用分享到某个平台的方法,下面介绍封装好的单独分享到微信、朋友圈、QQ好友、QQ空间、新浪微博的方法。

分享到微信好友或朋友圈

  1. /** * 分享到微信好友或朋友圈,图片可以是ur或者是本地的,默认本地图片优先 * * @param wechatType 微信好友或朋友圈 Wechat.NAME 微信好友 WechatMoments.NAME 朋友圈 * @param shareType 分享的类型 Platform.SHARE_WEBPAGE 网页 Platform.SHARE_IMAGE 图片 * @param title 标题 * @param content 内容 * @param siteUrl 网站的url * @param imgUrl 网络图片的url * @param bm bitmap * @param imgPath 本地图片的绝对路径 * @param shareListener 分享的回调 */
  2. private static void shareToWechat(String wechatType, int shareType, String title, String content, String siteUrl, String imgUrl, Bitmap bm, String imgPath, PlatformActionListener shareListener) {
  3. ShareSDK.initSDK(mContext);
  4. Wechat.ShareParams shareParams = new Wechat.ShareParams();
  5. shareParams.setShareType(shareType);
  6. shareParams.setTitle(title);//设置标题
  7. shareParams.setText(content);//设置内容
  8. shareParams.setUrl(siteUrl);//设置网站
  9. if (!TextUtils.isEmpty(imgUrl)) {
  10. //如果有网络图片,则设置图片的url
  11. shareParams.setImageUrl(imgUrl);
  12. }
  13. if (bm != null) {
  14. //如果是bitmap类型,则设置bm
  15. shareParams.setImageData(bm);
  16. }
  17. if (!TextUtils.isEmpty(imgPath)) {
  18. //如果是本地图片路径,则设置图片路径
  19. shareParams.setImagePath(imgPath);
  20. }
  21. Platform platform = ShareSDK.getPlatform(wechatType);
  22. platform.share(shareParams);//分享
  23. if (shareListener != null) {
  24. platform.setPlatformActionListener(shareListener);//设置回调
  25. } else {
  26. //如果为空,设置默认回调回调
  27. platform.setPlatformActionListener(defaultShareListner);
  28. }
  29. }

其中,第一个参数是分享到微信的类型:

  • 如果是分享给微信好友,则是传 Wechat.NAME;
  • 如果是分享到朋友圈,则是传 WechatMoments.NAME;

如果分享的是图片,可以传入网络图片的链接、bitmap对象、本地图片的绝对路径,三者只需传入一个,其他两个设置为null即可,如果三个都设置了,则只会显示其中一个,按照以下优先级(从高到底),只把优先级最高的那个显示:

  1. bitmap
  2. imgPath
  3. imgUrl

当最后一个参数传入的分享动作回调为null时,会使用默认的回调:

  1. /** * 默认的分享回调 */
  2. public static PlatformActionListener defaultShareListner = new PlatformActionListener() {
  3. @Override
  4. public void onComplete(Platform platform, int i, HashMap<String, Object> hashMap) {
  5. mHandler.post(new Runnable() {
  6. @Override
  7. public void run() {
  8. Toast.makeText(mContext, "分享成功", Toast.LENGTH_SHORT).show();
  9. }
  10. });
  11. }
  12. @Override
  13. public void onError(Platform platform, int i, Throwable throwable) {
  14. mHandler.post(new Runnable() {
  15. @Override
  16. public void run() {
  17. Toast.makeText(mContext, "分享失败", Toast.LENGTH_SHORT).show();
  18. }
  19. });
  20. }
  21. @Override
  22. public void onCancel(Platform platform, int i) {
  23. mHandler.post(new Runnable() {
  24. @Override
  25. public void run() {
  26. Toast.makeText(mContext, "分享已取消", Toast.LENGTH_SHORT).show();
  27. }
  28. });
  29. }
  30. };

这里和使用默认的GUI方法不同,如果为platform.setPlatformActionListener()传入的回调为null,会报空指针异常,所以这里创建一个默认的回调,也是弹出对应的吐司提示而已。

分享到QQ,QQ空间

  1. /** * 分享到QQ,QQ空间 * * @param title 标题 * @param content 内容 * @param siteUrl 网站的url * @param imgUrl 网络图片的url * @param bm bitmap * @param imgPath 本地图片的绝对路径 * @param shareListener 分享的回调 */
  2. private static void shareToQQ(String title, String content, String siteUrl, String imgUrl, Bitmap bm, String imgPath, PlatformActionListener shareListener) {
  3. ShareSDK.initSDK(mContext);
  4. QQ.ShareParams shareParams = new QQ.ShareParams();
  5. shareParams.setShareType(Platform.SHARE_WEBPAGE);
  6. shareParams.setTitle(title);//标题
  7. shareParams.setText(content);//内容
  8. shareParams.setTitleUrl(siteUrl);//网址
  9. if (!TextUtils.isEmpty(imgUrl)) {
  10. //如果有网络图片,则设置图片的url
  11. shareParams.setImageUrl(imgUrl);
  12. }
  13. if (bm != null) {
  14. //如果是bitmap类型,则设置bm
  15. shareParams.setImageData(bm);
  16. }
  17. if (!TextUtils.isEmpty(imgPath)) {
  18. //如果是本地图片路径,则设置图片路径
  19. shareParams.setImagePath(imgPath);
  20. }
  21. Platform platform = ShareSDK.getPlatform(QQ.NAME);
  22. platform.share(shareParams);//分享
  23. if (shareListener != null) {
  24. platform.setPlatformActionListener(shareListener);//设置回调
  25. } else {
  26. //如果为空,设置默认回调回调
  27. platform.setPlatformActionListener(defaultShareListner);
  28. }
  29. }

分享到新浪微博

  1. /** * 分享到新浪微博 * * @param content 内容 * @param siteUrl 网站的url * @param imgUrl 网络图片的url * @param bm bitmap * @param imgPath 本地图片的绝对路径 * @param shareListener 分享的回调 */
  2. private static void shareToSina(String content, String siteUrl, String imgUrl, Bitmap bm, String imgPath, PlatformActionListener shareListener) {
  3. ShareSDK.initSDK(mContext);
  4. SinaWeibo.ShareParams shareParams = new SinaWeibo.ShareParams();
  5. shareParams.setContentType(Platform.SHARE_WEBPAGE);
  6. shareParams.setText(content + "\n" + siteUrl);//设置内容
  7. if (!TextUtils.isEmpty(imgUrl)) {
  8. //如果有网络图片,则设置图片的url
  9. shareParams.setImageUrl(imgUrl);
  10. }
  11. if (bm != null) {
  12. //如果是bitmap类型,则设置bm
  13. shareParams.setImageData(bm);
  14. }
  15. if (!TextUtils.isEmpty(imgPath)) {
  16. //如果是本地图片路径,则设置图片路径
  17. shareParams.setImagePath(imgPath);
  18. }
  19. Platform platform = ShareSDK.getPlatform(SinaWeibo.NAME);
  20. platform.share(shareParams);//分享
  21. if (shareListener != null) {
  22. platform.setPlatformActionListener(shareListener);//设置回调
  23. } else {
  24. //如果为空,设置默认回调回调
  25. platform.setPlatformActionListener(defaultShareListner);
  26. }
  27. }

发表评论

表情:
评论列表 (有 0 条评论,314人围观)

还没有评论,来说两句吧...

相关阅读

    相关 自己JDBC

    > 对JDBC进行一些简单的封装,可以方便在项目中调用,同时也减少了重复代码量,降低代码的冗余度,提高代码的可读性和美观。 package JdbcUtil