mob 之 ShareSDK第三方分享

来源:互联网 发布:欧洲为什么发达 知乎 编辑:程序博客网 时间:2024/05/17 00:00

现在很多应用都有分享的功能,下面我就给大家介绍一个第三方分享的框架

使用步骤
1.访问 http://dashboard.mob.com/#/share/index 注册应用获取AppKey
登录之后点击头像进入–>管理后台 –>选择要集成的服务 ShareSDK
进入之后点击上面标题栏中的 添加 按钮 –>然后添加一个新的安卓应用 –>添加完之后就会生成一个app key

这里写图片描述


这里写图片描述


这里写图片描述


这里写图片描述


2.访问 http://www.mob.com/#/downloadDetail/ShareSDK/android 下载SDK

进入网页点击下载ShareSDK–> 选择要集成的分享–>应用 – >更多选项可选择是否需要接口文档或者评论和赞的功能 需要的话 一起勾选 –>点击下载sdk

这里写图片描述


这里写图片描述


这里写图片描述


3.解压下载回来的SDK,
有三个文件夹
这里写图片描述
第一个是 sdk 第二个是api文档 ,第三个是其他的一些 评论和咱的功能

双击打开ShareSDK for Android中的QuickIntegrater.jar,
如果双击打不开, 就要看一下java的环境变量是否配置的有问题

填入应用的名称和包名,让工具生成相关的资源文件.
并将其全部拷贝到工程当中


4.拷贝完之后 首先要在清单文件中配置权限

<uses-permission android:name="android.permission.GET_TASKS" /><uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /><uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /><uses-permission android:name="android.permission.READ_PHONE_STATE" /><uses-permission android:name="android.permission.MANAGE_ACCOUNTS"/><uses-permission android:name="android.permission.GET_ACCOUNTS"/><!-- 蓝牙分享所需的权限 --><uses-permission android:name="android.permission.BLUETOOTH" /><uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />

5.在清单文件中还要添加分享需要的activity信息,这个是必须要添加的

<activity     android:name="com.mob.tools.MobUIShell"     android:theme="@android:style/Theme.Translucent.NoTitleBar"     android:configChanges="keyboardHidden|orientation|screenSize"     android:screenOrientation="portrait"     android:windowSoftInputMode="stateHidden|adjustResize" >     <intent-filter>        <!-- 腾讯后面的appid要保持和您配置的QQ的appid一致 -->         <data android:scheme="这个需要单独去平台申请" />         <action android:name="android.intent.action.VIEW" />         <category android:name="android.intent.category.BROWSABLE" />         <category android:name="android.intent.category.DEFAULT" />     </intent-filter>    <!-- 调用新浪原生SDK,需要注册的回调activity -->    <intent-filter>        <action android:name="com.sina.weibo.sdk.action.ACTION_SDK_REQ_ACTIVITY" />        <category android:name="android.intent.category.DEFAULT" />    </intent-filter></activity>

6.如果您集成了微信,易信,新浪微博支付宝还需要添加下面回调的activity处理

    <!--微信分享回调 -->     <activity         android:name=".wxapi.WXEntryActivity"         android:theme="@android:style/Theme.Translucent.NoTitleBar"         android:configChanges="keyboardHidden|orientation|screenSize"         android:exported="true"         android:screenOrientation="portrait" />    <!--易信分享回调 -->     <activity         android:name=".yxapi.YXEntryActivity"         android:theme="@android:style/Theme.Translucent.NoTitleBar"         android:configChanges="keyboardHidden|orientation|screenSize"         android:exported="true"         android:screenOrientation="portrait" />     <!-- 支付宝分享回调 -->    <activity        android:name=".apshare.ShareEntryActivity"        android:theme="@android:style/Theme.Translucent.NoTitleBar"        android:configChanges="keyboardHidden|orientation|screenSize"        android:exported="true"/>

7.更改assets/ShareSDK中的配置信息.根据自己的实际情况更改每一个平台的信息
这里写图片描述


<ShareSDK         AppKey = "之前注册后的appkey"/> <!-- 修改成你在sharesdk后台注册的应用的appkey"-->

并且需要将shareSDK里面对应的需要分享的应用的appkey 等信息都需要去对应的平台去申请 然后替换成你自己申请的 appkey等信息 否则在分享的时候会出问题 , 具体的一些信息 在 assets/ShareSDK.xml 中都有详细的介绍,

SortId=”1” 这个是指的 要分享应用的排序

具体的信息也可以参考 开发文档
这里写图片描述


这里写图片描述


8.分享.示例代码:

**配置万之后 接下来就是在代码中做开发了

首先是布局文件 :**

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns: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"    android:paddingBottom="@dimen/activity_vertical_margin"    android:paddingLeft="@dimen/activity_horizontal_margin"    android:paddingRight="@dimen/activity_horizontal_margin"    android:paddingTop="@dimen/activity_vertical_margin"    tools:context="com.demomob.MainActivity">    <Button        android:onClick="share"        android:layout_width="wrap_content"        android:layout_height="wrap_content"        android:text="分享"        android:id="@+id/button"        android:layout_alignParentTop="true"        android:layout_centerHorizontal="true"        android:layout_marginTop="162dp" /></RelativeLayout>

开发代码:

package com.demomob;import android.os.Bundle;import android.support.v7.app.AppCompatActivity;import android.view.View;import cn.sharesdk.framework.ShareSDK;import cn.sharesdk.onekeyshare.OnekeyShare;public class MainActivity extends AppCompatActivity {    @Override    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);    }    public void share(View v) {        showShare();    }    private void showShare() {        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空间使用    **注意**  *这里需要自己定义一个title*         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);    }}

定义代码中需要的title

<resources>    <string name="app_name">DemoMob</string>    <string name="share">分享的标题</string></resources>

安卓交流群 : 595856941

0 0
原创粉丝点击