umeng(友盟)实现第三方登录和分享详解之分享

无分享面板的 new ShareAction(MainActivity.this) .setPlatform(SHARE_MEDIA.QQ)//传入平台 .withText(“hello”)//分享内容 .setCallback(umShareListener)//回调监听器 .share(); 都是实例化的new ShareAction ,这个操作在你点击分享按钮的监听事件中实现

无分享面板的

new ShareAction(MainActivity.this)

.setPlatform(SHARE_MEDIA.QQ)//传入平台

.withText(“hello”)//分享内容

.setCallback(umShareListener)//回调监听器

.share();

都是实例化的new ShareAction ,这个操作在你点击分享按钮的监听事件中实现。

withText(“”)是你分享的内容

setCallback是回调的监听

讲一下区别,无分享面板的,就直接.setPlatform(SHARE_MEDIA.QQ),直接传入相对应平台就可以调用。

有分享面板的,需要在setDisplayList中具体枚举所有的(按照顺序)分享平台。

2、具体实现分享内容

1)纯文本分享

new ShareAction(ShareActivity.this)

.withText(“hello”)

.share();

.withText(“hello”)里面填写你要分享的内容就好了

2)图片分享

private UMImage imageurl,imagelocal; 图片推荐资源图片和网络图片

imageurl = new UMImage(this,图片url);

imageurl.setThumb(new UMImage(this, R.drawable.thumb));

// imagelocal = new UMImage(this,R.drawable.logo,umImageMark);

imagelocal = new UMImage(this,R.drawable.logo);

imagelocal.setThumb(new UMImage(this, R.drawable.thumb));

new ShareAction(ShareDetailActivity.this).withMedia(imagelocal )

.setPlatform(share_media)

.setCallback(shareListener).share();

如果是本地图片就用withMedia(imagelocal ),网络图片withMedia(imageurl )

一般会设置缩略图

UMImage thumb = new UMImage(this, R.drawable.thumb);

imagelocal .setThumb(thumb);

ps:设置图片位置

UMImageMark umImageMark = new UMImageMark();

umImageMark.setGravity(Gravity.BOTTOM | Gravity.RIGHT);

umImageMark.setMarkBitmap(BitmapFactory.decodeResource(getResources(), R.drawable.umsocial_defaultwatermark));

``

当然图片资源还有

UMImage image = new UMImage(ShareActivity.this, “imageurl”);//网络图片

UMImage image = new UMImage(ShareActivity.this, file);//本地文件

UMImage image = new UMImage(ShareActivity.this, R.drawable.xxx);//资源文件

UMImage image = new UMImage(ShareActivity.this, bitmap);//bitmap文件

UMImage image = new UMImage(ShareActivity.this, byte[]);//字节流

new ShareAction(ShareDetailActivity.this).withText(Defaultcontent.text)

.withMedia(imagelocal)

.setPlatform(share_media)

.setCallback(shareListener).share();

4)图文加链接

UMWeb web = new UMWeb(Defaultcontent.url);

web.setTitle(“This is music title”);//标题

web.setThumb(thumb); //缩略图,可以本地图片,也可以网络图片

web.setDescription(“my description”);//描述

然后调用将这个参数设置到ShareAction中:

new ShareAction(ShareActivity.this)

.withMedia(web)

.share();

5)视频分享

视频只能使用网络视频:

UMVideo video = new UMVideo(videourl);

video.setTitle(“This is music title”);//视频的标题

video.setThumb(“http://www.umeng.com/images/pic/social/chart_1.png”);//视频的缩略图

video.setDescription(“my description”);//视频的描述

建立好之后可以进行分享:

new ShareAction(ShareActivity.this).withText(“hello”).withMedia(video).share();

6)音乐分享

音乐只能使用网络音乐:

UMusic music = new UMusic(musicurl);//音乐的播放链接

music.setTitle(“This is music title”);//音乐的标题

music.setThumb(“http://www.umeng.com/images/pic/social/chart_1.png”);//音乐的缩略图

music.setDescription(“my description”);//音乐的描述

music.setmTargetUrl(Defaultcontent.url);//音乐的跳转链接

建立好之后可以进行分享:

new ShareAction(ShareActivity.this)

.withMedia(music)

.share();

7)gif

目前只有微信好友分享支持Emoji表情,其他平台暂不支持

UMEmoji emoji = new UMEmoji(this,“http://img5.imgtn.bdimg.com/it/u=2749190246,3857616763&fm=21&gp=0.jpg”);

emoji.setThumb(new UMImage(this, R.drawable.thumb));

new ShareAction(ShareActivity.this)

.withMedia(emoji)

.share();

8)微信小程序

目前只有微信好友支持小程序分享,朋友圈,收藏及其他平台暂不支持:

UMMin umMin = new UMMin(Defaultcontent.url);

umMin.setThumb(imagelocal);

umMin.setTitle(Defaultcontent.title);

umMin.setDescription(Defaultcontent.text);

umMin.setPath(“pages/page10007/xxxxxx”);

umMin.setUserName(“xx_xxx”);

new ShareAction(ShareDetailActivity.this)

.withMedia(umMin)

.setPlatform(share_media)

.setCallback(shareListener)

.share();

emoji = new UMEmoji(this,”http://img5.imgtn.bdimg.com/it/u=2749190246,3857616763&fm=21&gp=0.jpg“);

emoji.setThumb(new UMImage(this, R.drawable.thumb));

9)分享文件

new ShareAction(ShareDetailActivity.this)

.withFile(file)

.withText(Defaultcontent.text)

.withSubject(Defaultcontent.title)

.setPlatform(share_media)

.setCallback(shareListener).share();

file = new File(this.getFilesDir()+“test.txt”);

if (!file.exists()){

try {

file.createNewFile();

} catch (IOException e) {

e.printStackTrace();

}

}

if (SocializeUtils.File2byte(file).length<=0){

String content = “U-share分享”;

byte[] contentInBytes = content.getBytes();

try {

FileOutputStream fop = new FileOutputStream(file);

fop.write(contentInBytes);

fop.flush();

fop.close();

} catch (FileNotFoundException e) {

e.printStackTrace();

} catch (IOException e) {

e.printStackTrace();

}

}

10)有面板的自定义面板

/增加自定义按钮的分享面板/

mShareAction = new ShareAction(ShareMenuActivity.this).setDisplayList(

SHARE_MEDIA.WEIXIN, SHARE_MEDIA.WEIXIN_CIRCLE, SHARE_MEDIA.WEIXIN_FAVORITE,

SHARE_MEDIA.SINA, SHARE_MEDIA.QQ, SHARE_MEDIA.QZONE,

SHARE_MEDIA.ALIPAY, SHARE_MEDIA.RENREN, SHARE_MEDIA.DOUBAN,

SHARE_MEDIA.SMS, SHARE_MEDIA.EMAIL, SHARE_MEDIA.YNOTE,

SHARE_MEDIA.EVERNOTE, SHARE_MEDIA.LAIWANG, SHARE_MEDIA.LAIWANG_DYNAMIC,

SHARE_MEDIA.LINKEDIN, SHARE_MEDIA.YIXIN, SHARE_MEDIA.YIXIN_CIRCLE,

SHARE_MEDIA.TENCENT, SHARE_MEDIA.FACEBOOK, SHARE_MEDIA.TWITTER,

SHARE_MEDIA.WHATSAPP, SHARE_MEDIA.GOOGLEPLUS, SHARE_MEDIA.LINE,

SHARE_MEDIA.INSTAGRAM, SHARE_MEDIA.KAKAO, SHARE_MEDIA.PINTEREST,

SHARE_MEDIA.POCKET, SHARE_MEDIA.TUMBLR, SHARE_MEDIA.FLICKR,

SHARE_MEDIA.FOURSQUARE, SHARE_MEDIA.MORE)

.addButton(“umeng_sharebutton_copy”, “umeng_sharebutton_copy”, “umeng_socialize_copy”, “umeng_socialize_copy”)

.addButton(“umeng_sharebutton_copyurl”, “umeng_sharebutton_copyurl”, “umeng_socialize_copyurl”, “umeng_socialize_copyurl”)

.setShareboardclickCallback(new ShareBoardlistener() {

@Override

public void onclick(SnsPlatform snsPlatform, SHARE_MEDIA share_media) {

if (snsPlatform.mShowWord.equals(“umeng_sharebutton_copy”)) {

最后

Android学习是一条漫长的道路,我们要学习的东西不仅仅只有表面的 技术,还要深入底层,弄明白下面的 原理,只有这样,我们才能够提高自己的竞争力,在当今这个竞争激烈的世界里立足。

人生不可能一帆风顺,有高峰自然有低谷,要相信,那些打不倒我们的,终将使我们更强大,要做自己的摆渡人。

资源持续更新中,欢迎大家一起学习和探讨。

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化学习资料的朋友,可以戳这里获取

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

知秋君
上一篇 2024-07-29 09:12
下一篇 2024-07-29 08:48

相关推荐