Android社会化分享的实现方法

众所周知,互联网是一个资源共享的地方,在网络上,我们可以分享我们所有认为好的资源。而随着互联网信息爆发式的增长,我们习惯了一键分享功能,比如:微博分享、微信分享、QQ空间分享、人人网分享等等。由此可见分享是很重要的一个客户体验功能,那在移动端,我们怎样实现分享功能呢?

Android系统的社会分享功能来看,实现手段主要有两种:一种是通过系统自带的来启动分享功能;第二种是通过第三方的SDK插件进行分享;具体实现方式如下。

一、Android系统启动分享功能

系统启动分享功能很简单,实现也很容易,下面通过一个demo为大家展示一下:

1、还是先看一个布局文件,布局文件很简单,仅仅一个button按钮来触发分享功能即可:

<RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android"

xmlns:tools="http://schemas.android.com/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

tools:context=".MainActivity">

<Button

android:id="@+id/btn_share"

android:text="@string/hello_world"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:padding="10dp"/>

</RelativeLayout>

2、直接看实现的代码:

public classMainActivity extends ActionBarActivity {

private Buttonbtn_share;

@Override

protected voidonCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

btn_share = (Button)findViewById(R.id.btn_share);

btn_share.setOnClickListener(newView.OnClickListener() {

@Override

public void onClick(View v) {

shareBySystem();

}

});

}

/**

* 通过系统的组件进行分享

*/

private voidshareBySystem(){

Intent intent = newIntent(Intent.ACTION_SEND);

intent.setType("image/*");

intent.putExtra(Intent.EXTRA_SUBJECT,"Share");

//设置分享的内容

intent.putExtra(Intent.EXTRA_TEXT, "Ihave successfully)");

intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);

startActivity(Intent.createChooser(intent,getTitle()));

}

仅仅通过系统的Intent组件来指定我们分享的内容即可,效果图如下:

从图片中,可以看出分享功能已经实现,但是问题来了,这种方式实现的分享功能却没有大家常用的QQ、新浪微博、豆瓣等!这就是这种分享功能实现的局限性,虽然实现简单,但是不一定能达到我们的特殊需求。为解决这个问题,我们就需要用到,第三方的SDK插件了。

二、第三方组件ShareSDK的使用

要分享东西到腾讯、新浪这些主流社交平台时,没有他们提供的SDK支持是不可能实现的,那么问题又来了,如果要分享到十几种平台岂不是需要十几种SDK插件?其实我们可以直接用ShareSDK的解决,下面就一起来看看他的具体实现步骤吧。

1、在 mob官网注册一个开发者账号,然后填写相关的认证信息即可。

2、下载官方提供的SDK。

3、进入ShareSDK解压目录,打开“Share SDK for Android”目录,可以找到“QuickIntegrater.jar”,这个就是快速集成ShareSDK的工具,我们双击该工具,选择我们要分享的平台,填写好事例名称和包名,点击【确定】,然后系统自动给我们生成一个我们需要的demo,如下图:

4、我们赋值文件夹下的对应文件,拷贝到我们工程目录即可。

5、至此,所有需要的文件都已经拷贝到我们工程中,我们接下来就是修改Manifest文件的配置。

(1)添加权限

<uses-permissionandroid:name="android.permission.GET_TASKS" />

<uses-permissionandroid:name="android.permission.INTERNET" />

<uses-permissionandroid:name="android.permission.ACCESS_WIFI_STATE" />

<uses-permissionandroid:name="android.permission.ACCESS_NETWORK_STATE" />

<uses-permissionandroid:name="android.permission.CHANGE_WIFI_STATE" />

<uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE" />

<uses-permissionandroid:name="android.permission.READ_PHONE_STATE" />

<uses-permissionandroid:name="android.permission.MANAGE_ACCOUNTS"/>

<uses-permissionandroid:name="android.permission.GET_ACCOUNTS"/>

<!-- 蓝牙分享所需的权限 -->

<uses-permissionandroid:name="android.permission.BLUETOOTH" />

<uses-permissionandroid:name="android.permission.BLUETOOTH_ADMIN" />

(2)配置我们分享的主流平台的Activity文件,例如:

<!-- QQ客户端回调 -->

<activity

android:name="cn.sharesdk.tencent.qq.ResultReceiver"

android:launchMode="singleTask"

android:noHistory="true">

<!--

如果集成QQ分享,或者使用QQ客户端来进行QQ空间的分享,须要在此处添加一个对ACTION_VIEW

事件的过滤器,其中的scheme是“tencent”前缀再开发者应用的加上appId。如果此过滤器不设置,

则分享结束以后不能得到正确的回调

-->

<intent-filter android:priority="1000">

<dataandroid:scheme="tencent100371282" />

<actionandroid:name="android.intent.action.VIEW" />

<categoryandroid:name="android.intent.category.DEFAULT" />

<categoryandroid:name="android.intent.category.BROWSABLE" />

</intent-filter>

</activity>

<!-- 微信分享回调 -->

<activity

android:name=".wxapi.WXEntryActivity"

android:theme="@android:style/Theme.Translucent.NoTitleBar"

android:configChanges="keyboardHidden|orientation|screenSize"

android:exported="true" />

<!-- 易信分享回调 -->

<activity

android:name=".yxapi.YXEntryActivity"

android:theme="@android:style/Theme.Translucent.NoTitleBar"

android:configChanges="keyboardHidden|orientation|screenSize"

android:excludeFromRecents="true"

android:exported="true"

android:launchMode="singleTop"/>

<!-- 支付宝分享回调 -->

<activity

android:name=".apshare.ShareEntryActivity"

android:theme="@android:style/Theme.Translucent.NoTitleBar"

android:configChanges="keyboardHidden|orientation|screenSize"

android:exported="true"/>

<!-- 调用新浪原生SDK,需要注册的activity-->

<activity

android:name="com.sina.weibo.sdk.component.WeiboSdkBrowser"

android:configChanges="keyboardHidden|orientation"

android:windowSoftInputMode="adjustResize"

android:exported="false" >

</activity>

<!-- 调用新浪原生SDK,需要注册的回调activity-->

<activity

android:name="cn.sharesdk.sina.weibo.SinaActivity"

android:theme="@android:style/Theme.Translucent.NoTitleBar">

<intent-filter>

<actionandroid:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY"/>

<categoryandroid:name="android.intent.category.DEFAULT" />

</intent-filter>

</activity>

6、使用第三方的SDK,他们都会要求我们提供应用的App_key进行识别,所以ShareSDK也不例外,在做第4步时,我们需要将assets文件夹下的一个xml文件进行拷贝,这个文件里面包含了我们分享的各个平台的App_key信息,例如:

7、至此,所有配置基本完成,我们只需要在代码中调用分享功能即可。

private voidshowShare() {

ShareSDK.initSDK(this);

OnekeyShare oks = new OnekeyShare();

//关闭sso授权

oks.disableSSOWhenAuthorize();

// 分享时Notification的图标和文字  2.5.9以后的版本不调用此方法

//oks.setNotification(R.drawable.ic_launcher,getString(R.string.app_name));

// title标题,印象笔记、邮箱、信息、微信、人人网和QQ空间使用

oks.setTitle(getString(R.string.share));

// titleUrl是标题的网络链接,仅在人人网和QQ空间使用

oks.setTitleUrl("http://sharesdk.cn");

// text是分享文本,所有平台都需要这个字段

oks.setText("我是分享文本");

// imagePath是图片的本地路径,Linked-In以外的平台都支持此参数

oks.setImagePath("/sdcard/test.jpg");//确保SDcard下面存在此张图片

// url仅在微信(包括好友和朋友圈)中使用

oks.setUrl("http://sharesdk.cn");

// comment是我对这条分享的评论,仅在人人网和QQ空间使用

oks.setComment("我是测试评论文本");

// site是分享此内容的网站名称,仅在QQ空间使用

oks.setSite(getString(R.string.app_name));

// siteUrl是分享此内容的网站地址,仅在QQ空间使用

oks.setSiteUrl("http://sharesdk.cn");

// 启动分享GUI

oks.show(this);

}

然后我们在Button的onClick事件中进行响应即可。

btn_share.setOnClickListener(newOnClickListener() {

@Override

public void onClick(View v) {

showShare();

}

});

至此,使用ShareSDK的快速集成已经完成了。但值得注意的是,ShareSDK仅仅是一个将个平台的分享集成的一个工具,我们还是要去各个社交平台去注册账户,然后注册应用信息,才能获取对应的App_key进行使用。效果如下:

以上就是Android社会化分享最基本功能的简单介绍,当然Android分享还有很多高级的功能,在以后的分享中小编将为大家一一介绍。同时,也希望通过本文的分享,对Android初学者这块功能的学习、使用有所帮助。

时间: 2025-01-09 12:01:19

Android社会化分享的实现方法的相关文章

Android应用开发-小巫CSDN博客客户端之集成友盟社会化分享组件

Android应用开发-小巫CSDN博客客户端之集成友盟社会化分享组件 上一篇博客给大家介绍了如何分析网页并且使用jsoup这个库对html代码进行解析,本篇博客继续给大家介绍如何集成友盟社会化组件,如何使用SDK提供的API轻松实现多平台的社会化分享,官网的文档和Demo看起来很头疼的有木有,小巫在集成这个社会化的组件也有点烦躁,所以也需要各位耐心看下面的博文把友盟社会化组件集成到你的应用中去.为什么要选择友盟呢,这里也是答应了小喵的,要帮忙集成他们的服务,所以也顺带帮他们写一篇这样的博文,千

Android第三期 - sharesdk社会化分享组件

网站分享比较简单的一句js就可以了,但是手机就没有这么简单了,要有点小复杂,刚学Android两个月了,也再用第三方的Android开发组件,现在介绍给大家sharesdk.直接上代码!! 第一步:下载ShareSDK 官网 http://share.sharesdk.cn/Download 第二步:集成ShareSDK 进入ShareSDK解压目录,打开"Share SDK for Android"目录,可以找到"QuickIntegrater.jar",这个就是

android 实现分享功能两种方法

当我想做一个智能的记事本的时候,我就在尝试自己写一组分享功能.后来才知道,原来每个社交软件中都有自己的分享接口. 这就大大减少了我们的代码量了. 第一种方法:特点--简单 package com.example.share; import android.app.Activity; import android.content.Intent; import android.os.Bundle; import android.view.Menu; import android.view.MenuI

Android集成友盟社会化分享功能

1.  产品概述 友盟社会化组件,可以让移动应用快速具备社会化分享.登录.评论.喜欢等功能,并提供实时.全面的社会化数据统计分析服务. 指南将会手把手教你使用社会化组件SDK,用5分钟为APP增加新浪微博.腾讯微博.人人网分享功能. 注意:本文示例代码均针对最新版SDK,如果你所用SDK的类名或方法名与此文不符合,请使用你所用SDK的随包文档.或者下载使用最新版SDK. 2.  获取友盟Appkey 如果你之前已经在友盟注册了应用,并获取到了Appkey,可以继续使用它. 如果你尚未在友盟注册开

在Android Studio中使用shareSDK进行社会化分享(图文教程)

[前言] 如今的app当中,几乎都包含了社会化分享的功能,来两张图see 一 see: 好在这种分享功能已经有第三方平台帮我们做好了,我们直接调用其SDK即可.市面上做社会化分享平台的比较好平台的有:mob等. 今天我们就用mob的平台做分享吧,官网地址是:http://www.mob.com/ 怎么样?光看这个网站的首页就碉堡了吧?好了不废话,进入正题. 开发环境: IDE版本:Android Studio 1.2 物理机版本:Win7旗舰版(64位) 一.获取SDK并解压: 打开网站首页后,

为Unity开发的android手机游戏添加一个社会化分享功能

先看一下我最近自己做的一个游戏的效果图,然后在为大家讲述怎么做这样一个分享功能,如果图片不直观,当然如果你也不介意我顺便宣传一下我的游戏,你可以点击以下这个链接,下载我的游戏,进去体验一下里面的这个分享功能:http://zhushou.360.cn/detail/index/soft_id/2954399?recrefer=SE_D_BubbleDeer 好了,接下来我们就来一起探讨一下这个分享功能怎么做. (1)提供下载一个社会化分析的SDK,这个我用的是mob.com网的ShareSDK,

iOS友盟社会化分享完全攻略

1 简介 现如今几乎所有人都有社交账号和社交App,而分享功能也几乎随处可见.本文的目的在于介绍分享功能的基本实现.使用的是友盟的社会化分享组件,这样就不用一个一个对接各个平台的接口,可以使用一套接口来实现多个平台的分享功能.本文以分享到微信.QQ.微博为例. 2 开发者账号 这里说的不是创建苹果的开发者账号,而是创建友盟和各个要分享到的平台的开发者账号.和苹果开发者账号一样,要使用友盟的服务,要分享到各个平台,都需要对应的开发者账号去获取key. 2.1 友盟开发者账号及key 打开友盟的首页

如何使用友盟 Cocos2d-x 分享组件实现 Android/iOS 分享功能

Cocos2d-x作为一款优秀的跨平台游戏引擎,已经被越来越多的开发者使用,而在游戏中使用分享组件能够有效的提供用户粘性,通过分享回流来提高APP安装量,但是目前市面上能够在Cocos2d-x环境下使用的分享插件并不多,开发者们只能自己对原生分享SDK进行封装来实现,前一段时间友盟推出Cocos2d-x分享组件,能够帮助开发者快速集成.友盟也把组件的源码放在GitHub上,有好的想法也可以直接在GitHub上修改(PS.在GitHub上提bug可以获得友盟的小奖品),同样也可以对源码进行学习,对

Android开发经验分享-GridView、ListView内容错乱

在使用GridView.ListView的过程中遇到内容错乱的问题,费了较长时间才找到问题的根源,特地总结一下. 1.在自定义adapter中没有给每一项都设置内容导致内容错乱: @Override public View getView(final int position, View convertView, ViewGroup parent) { if( null == convertView ){ mGridHolder = new GridHolder( ); convertView