乐趣区

关于前端:Mob社会化分享集成ShareSDK

如何在我的项目曾经集成 SMSSDK 的状况下集成 ShareSDk 到我的项目中,须要应用创立 module 的形式引入 ShareSDk,次要内容如下:
1. 下载 ShareSDK
2. 引入 ShareSDK
3. 创立 MainLibs Module
4. 创立 OneKeyShare Module
5. 在我的项目中引入 Module
6. 配置权限
7. 配置 Application
8. 启用 ShareSDK

下载 ShareSDk

官网下载地址:ShareSDK,下载时选中要分享的平台,如下图所示:

下载的 ShareSDk 解压缩如下,这里下载的版本是 ShareSDK-Android-3.0.0,如下图所示:

引入 ShareSDK

首先,复制 ShareSDk 中的 ShareSDK.xml 文件到我的项目中的 assets 目录下,这里应用引入 module 的形式引入 ShareSDk,ShareSDK 外面次要引入如下两个 Libs,如下图所示:

上面演示一下 Module 的创立过程:

创立 MainLibs Module

1、在新建的我的项目中创立一个 Android Library,点击链接演示:
https://vdn6.vzuu.com/SD/fdff…
2. 删除新创建的 Library 中 main 上面的所有文件,及 java、res 两个文件夹和 AndroidManifest.xml 文件,如下图所示:

3. 复制要引入的 MainLibs 中的 res、AndroidMainfest.xml、libs(外面的 jar)到对应的文件夹,如下图所示:

导入 mainLibs 中构造如下:

此时,这个 module 就创立好了,这里应用 ShareSDK 提供的分享页面,故还需引入 OneKeyShare。

创立 OneKeyShare Module

创立 Module 的过程和上述一样,留神的是多了一个 src,外面是要应用的 java 文件,所以必须也得援用,如下图所示:

将 src 文件夹复制到 main 上面即可,build 之后如果不出错,阐明 Module 创立胜利了,上面依据依赖关系一如对应的 Module 即可。

在我的项目中引入 Module

这外面 OnKeyShareLibs 依赖 MainLibs , 只需 app 依赖 OnkeyShareLibs 即可,这里演示 OnKeyShareLibs 如何依赖 MainLibs,点击链接演示:
https://vdn6.vzuu.com/SD/186b…
而后,同样的形式 app 依赖 OnKeyShareLibs 即可。

配置权限

这里之前配置过 SMSSDK , 只需补充短少的权限即可,上面是同时集成了 SMSSDK 和 ShareSDK 所需的全副权限,如下:

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

配置 Application

如果之前配置过 SMSSDK,那么 MobUIShell 是配置过的,只需增加短少的 IntentFilter,集成 SMSSDK 和 ShareSDK 可共用 MobUIShell,如下:
<activity

android:name="com.mob.tools.MobUIShell"
android:theme="@android:style/Theme.Translucent.NoTitleBar"
android:configChanges="keyboardHidden|orientation|screenSize"
android:windowSoftInputMode="stateHidden|adjustResize">
<intent-filter>
    <data android:scheme="tencent100371282" />
    <action android:name="android.intent.action.VIEW" />
    <category android:name="android.intent.category.BROWSABLE" />
    <category android:name="android.intent.category.DEFAULT" />
</intent-filter>

</activity>
如果您的我的项目集微信或者微信朋友圈,请查看 AndroidManifest.xml 配置文件里的 package 门路, 须要在 package 目录下创立 wxapi 目录再搁置 WXEntryActivity。没有此 activity 在微信分享后回调会查看是否有此 activity, 没有将会报错:
<activity

android:name=".yxapi.YXEntryActivity"     
android:theme="@android:style/Theme.Translucent.NoTitleBar"
android:configChanges="keyboardHidden|orientation|screenSize" 
android:exported="true"     
android:screenOrientation="portrait" />

具体请参考:Android ShareSDK 残缺的集成文档

启用 SDK

通过 AndroidManifest.xml

在 Application 节点下增加以下属性:
android:name="com.mob.MobApplication"
在 Application 标签下增加 meta 参数:

<!-- 通过 AndroidManifest 配置 AppKey 和 AppSecret,如果你抉择通过代码配置,则不须要配置以下 meta-data -->
<meta-data android:name="Mob-AppKey" android:value="你的 AppKey"/>
<meta-data android:name="Mob-AppSecret" android:value="你的 AppSecret"/>

代码配置

// 通过代码注册你的 AppKey 和 AppSecret
MobSDK.init(context, "你的 AppKey", "你的 AppSecret");

上述两种形式,只应用其中一种即可初始化 ShareSDK 了。

调用分享界面

private void showShare() {OnekeyShare oks = new OnekeyShare();
     // 敞开 sso 受权
     oks.disableSSOWhenAuthorize(); 
     // 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);
}
退出移动版