mob 之 ShareSDK第三方分享

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

使用步骤
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
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 8
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值