当前位置:主页 > 移动开发 > Android代码 >

Android实现新浪微博一键分享的实例代码

时间:2021-03-01 13:43:43 | 栏目:Android代码 | 点击:

写在本章前

愈来愈多的APP支持一键分享至QQ空间、微信朋友圈、新浪微博的功能,同时支持第三方账号登录,如QQ、微信、新浪微博等第三方平台的账号。本章结合当下流行的设计,兼顾免费的开源ShareSDK,结合项目中的实际需求,整合出一套分享源码,版权所有,如需转载请注明转载地址。

1. 开发环境及SDK下载

开发工具:Android studio2.1.3版本

ShareSDK:Mob官网(www.mob.com)下载最新社会化分享ShareSDK2.7.7版本,解压如图示


进入ShareSDK for Android文件,找到QuickIntegrater.jar文件,根据官网介绍双击打开,根据需求集成第三方平台,在某些情况如若双击无法打开,windows系统下,进入cmd找到QuickIntegrater.jar所在的当前目录,键入java -jar QuickIntegrater.jar,根据实际需求集成第三方平台,最后生成Sample的文件夹,包括需要使用到的libs等文件



复制新生成文件夹Sample下面的全部内容到自己所建立的project下,同时需要对加入到libs的jar文件添加库依赖



Mob进入后台,申请分享使用权限,获取APP key和APP secret


将申请到的APP key替换


2. 配置AndroidManifest.xml

<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" />

3. 添加必要的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" >
<!-- 调用新浪原生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>
<!--
   <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>

<!--微信分享回调
 <activity
   android:name="cn.sharesdk.demo.wxapi.WXEntryActivity"
   android:theme="@android:style/Theme.Translucent.NoTitleBar"
   android:configChanges="keyboardHidden|orientation|screenSize"
   android:exported="true"
   android:screenOrientation="portrait" />
 -->

备注:上述代码中,有关于微信和QQ的分享回调,本文只讲述新浪微博的分享使用,QQ和微信的activity添加可供参考

4. 替换mob后台申请的Appkey与各个平台申请的key

更换aseests下面的ShareSDK.xml中的APPkey,以及需要添加第三方应用需要的APPkey和AppSecret,以新浪微博为例.

4.1 新浪微博key申请

1)登录新浪微博,申请,填写账号,申请注册等信息,以个人为例,在申请结束后,获取“微连接”权限,点击“立即创建微连接”;


2)填写应用名称,勾选应用平台,以Android为例;


3)确认提交即可获取APP Key和Secret


4)新浪微博获取APP的Android包名和签名


5)通过进入申请的应用名称“Android实例”APP下的AndroidManifest.xml中获取包名;


6)Android签名的获取

通过4)中新浪微博提供的签名工具,github下载的“app_signatures.apk”,安装到手机,同时将APP“Android实例”安装到手机,输入Android包名,即可生成对应的Android签名



7)新浪微博测试权限

需要注意的是,此时并没有对APP进行上线,并没有通过审核,暂时只有测试权限可以关联15个测试账号使用;


5. 正式编程

此部分包括一键底部弹出对话框,按钮操作,第三方分享等操作;

5.1 自定义dialog

参考了多个博客,总结出自己所需要的dialog。

/**
 * Created by user on 2016/10/18.
 */
public class ShareDialog extends Dialog{
  private Dialog dialog;
  private Context context;
  private LayoutInflater inflater;
  private ImageView iv_share_sina, iv_share_qqzone, iv_share_wxfriend;

  public ShareDialog(Context context){
    super(context);
    init(context);
  }
  private void init(Context context){
    View view = inflater.from(context).inflate(R.layout.bottom_share_dialog, null);
    dialog = new Dialog(context, R.style.shareDialog_style);
    dialog.setContentView(view);

    RelativeLayout rl_dialog_bg = (RelativeLayout)view.findViewById(R.id.rl_dialog_bg);
    rl_dialog_bg.setOnClickListener(new View.OnClickListener() {
      @Override
      public void onClick(View v) {
        dialog.dismiss();
      }
    });
    //设置铺满
    Window dialogWindow = dialog.getWindow();
    dialogWindow.setGravity(Gravity.BOTTOM);//设置显示位置
    WindowManager.LayoutParams lp = dialogWindow.getAttributes(); // 获取对话框当前的参数值
//    lp.x = 0; // 新位置X坐标
//    lp.y = -20; // 新位置Y坐标

    lp.width = WindowManager.LayoutParams.MATCH_PARENT; // 宽度
   lp.height = WindowManager.LayoutParams.WRAP_CONTENT; // 高度
   lp.alpha = 9f; // 透明度
    dialogWindow.setAttributes(lp);
    /* //设置铺满
    Window window = dialog.getWindow();
    WindowManager.LayoutParams wl = window.getAttributes();
    wl.x = 0;
    wl.y = ((Activity) context).getWindowManager().getDefaultDisplay()
        .getHeight();
    wl.width = ViewGroup.LayoutParams.MATCH_PARENT;
    wl.height = ViewGroup.LayoutParams.WRAP_CONTENT;
    // 设置显示位置
    dialog.onWindowAttributesChanged(wl);*/

    iv_share_sina = (ImageView) view.findViewById(R.id.iv_share_sina);
    iv_share_qqzone = (ImageView) view.findViewById(R.id.iv_share_qqzone);
    iv_share_wxfriend = (ImageView) view.findViewById(R.id.iv_share_wxfriend);
  }

  /**
   * 设置新浪微博监听事件
   */
  public void setSinaClickListener(View.OnClickListener clickListener){
    iv_share_sina.setOnClickListener(clickListener);
  }
  /**
   * 设置QQ空间监听事件
   */
  public void setQQZoneClickListener(View.OnClickListener clickListener){
    iv_share_qqzone.setOnClickListener(clickListener);
  }
  /**
   * 设置微信朋友圈监听事件
   */
  public void setWXFriendClickListener(View.OnClickListener clickListener){
    iv_share_wxfriend.setOnClickListener(clickListener);
  }
  public void show(){
    dialog.show();
  }
  public void dismiss(){
    dialog.dismiss();
  }
}

对话框如图示;


5.2 ShareSDK初始化

在需要activity分享界面,或者在MainActivity的OnCreate()函数中进行初始化

//ShareSDK初始化
ShareSDK.initSDK(mActivity);

5.3 获取和保存当前屏幕的截图,用以第三方的分享

作为第三方分享的一个点,如何将屏幕的截图,通过新浪微博一键分享到微博中。

/**
 * 获取和保存当前屏幕的截图
 * 用以第三方分享
 */
private Bitmap GetandSavaCurrentImage(Activity activity) {
  // 1.获取windows中最顶层的view
  View view = activity.getWindow().getDecorView();
  view.buildDrawingCache();

  // 2.获取状态栏高度
  Rect rect = new Rect();
  view.getWindowVisibleDisplayFrame(rect);
  int statusBarHeights = rect.top;
  Display display = activity.getWindowManager().getDefaultDisplay();

  // 3.获取屏幕宽和高
  int widths = display.getWidth();
  int heights = display.getHeight();

  // 4.允许当前窗口保存缓存信息
  view.setDrawingCacheEnabled(true);

  // 5.去掉状态栏
  Bitmap bmp = Bitmap.createBitmap(view.getDrawingCache(), 0,
      statusBarHeights, widths, heights - statusBarHeights);

  // 销毁缓存信息
  view.destroyDrawingCache();

  return bmp;
}

/**
 * 将截取的图片保存到sdcard中并且命名
 */
private void saveToSD(Bitmap bmp, String fileName) {
  //判断SD卡是否存在
  if (hasSdcard()){
    Log.i("wzl", "存储卡存在,可以调用。");
    try {
      File file = new File(fileName);
      if (!file.exists()){
        file.createNewFile();
      }
      FileOutputStream fos = new FileOutputStream(file);
      if (null != fos){
        // 第一参数是图片格式,第二个是图片质量,第三个是输出流
        bmp.compress(Bitmap.CompressFormat.PNG, 100, fos);
        // 用完关闭
        fos.flush();
        fos.close();
      }
    } catch (Exception e) {
      e.printStackTrace();
    }
  }
}

/**
 * @return 检查是否存在SDcard
 */
public static boolean hasSdcard(){
  String sdcardstate = Environment.getExternalStorageState();
  if (sdcardstate.equals(Environment.MEDIA_MOUNTED)) {
    //有存储的SDCard
    return true;
  } else {
    Log.i("wzl", "没有检测到SDCard!");
    return false;
  }
}

5.4 监听事件

点击新浪微博,直接弹出图文分享界面,所需要的图片为对于当前屏幕的截图,同时加载自己添加的文字以及网址链接,这部分可以作为APP分享的网址下载链接,下列代码也给出了新浪微博分享的一些其他使用案例,可以根据个人喜好或者项目的实际需求进行更改;

/**
 *
 * 在弹出的9宫格分享页面中,会有很多平台,如果有些平台不希望显示,可以有两种方法,
  1.删除项目引用的两个工程之一的MainLibs目录下的libs里面对应的平台的jar包,删除九格宫不要的平台,只要删除对应平台的jar就行
  2.配置ShareSDK.conf文件,不想显示的平台设置Enable="false"
 */
  /**
   * ShareSDK集成方法有两种

   * 1、第一种是引用方式,例如引用onekeyshare项目,onekeyshare项目再引用mainlibs库

   * 2、第二种是把onekeyshare和mainlibs集成到项目中,本例子就是用第二种方式
   请看“ShareSDK
   * 使用说明文档”,SDK下载目录中
   或者看网络集成文档
   * http://wiki.sharesdk.cn/Android_%E5%BF%AB
   * %E9%80%9F%E9%9B%86%E6%88%90%E6%8C%87%E5%8D%97
   * 3、混淆时,把sample或者本例子的混淆代码copy过去,在proguard-project.txt文件中
   *
   * 平台配置信息有三种方式: 1、在我们后台配置各个微博平台的key
   * 2、在代码中配置各个微博平台的key,http://sharesdk.cn/androidDoc
   * /cn/sharesdk/framework/ShareSDK.html
   * 3、在配置文件中配置,本例子里面的assets/ShareSDK.xml,
   */

  private void showShare() {
    //实例化一个OnekeyShare对象
    OnekeyShare oks = new OnekeyShare();
    // 分享时Notification的图标和文字 2.5.9以后的版本不调用此方法
    //oks.setNotification(R.drawable.ic_launcher, getString(R.string.app_name));
    //关闭sso授权
    oks.disableSSOWhenAuthorize();
    //指定微博平台,如果不添加这行,则弹出9宫格供用户选择
    oks.setPlatform(SinaWeibo.NAME);
    //分享内容的标题
    // title标题,印象笔记、邮箱、信息、微信、人人网和QQ空间使用
//    oks.setTitle("新浪微博分享");
    // titleUrl是标题的对应的网址链接,仅在人人网和QQ空间使用,如果没有可以不设置
//    oks.setTitleUrl("http://sharesdk.cn");
    //分享网络图片,新浪微博分享网络图片需要通过审核后申请高级写入接口,否则请注释掉测试新浪微博
    //分享网络图片,新浪分享网络图片,需要申请高级权限,否则会报10014的错误
    //权限申请:新浪开放平台-你的应用中-接口管理-权限申请-微博高级写入接口-statuses/upload_url_text
    //注意:本地图片和网络图片,同时设置时,只分享本地图片
    //oks.setImageUrl("http://f1.sharesdk.cn/imgs/2014/02/26/owWpLZo_638x960.jpg");
    oks.setImagePath(fileName);
    //是否直接分享(true则直接分享),false是有九格宫,true没有
    oks.setSilent(false);
    //Platform.ShareParams sina_weibo = new Platform.ShareParams();
    //sina_weibo.setText("第一次分享" + " " + "www.baidu.com");
    //imagePath是图片的本地路径,Linked-In以外的平台都支持此参数
    //sina_weibo.setImagePath("/sdcard/share_pic.jpg");//确保SDcard下面存在此张图片
    /*oks.setShareContentCustomizeCallback(new ShareContentCustomizeCallback() {
      @Override
      public void onShare(Platform platform, Platform.ShareParams paramsToShare) {
        if(SinaWeibo.NAME.equals(platform.getName())) {
          paramsToShare.setText("初始使用" + " " + "http://www.baidu.com");
          paramsToShare.setUrl(null);
        }
      }
    });*/
    //设置分享的文本内容,所有平台都需要这个字段
    oks.setText("新浪微博第一次分享" + " " + "http://www.baidu.com");
    //url仅在微信(包括好友和朋友圈)中使用
//    oks.setUrl("http://sharesdk.cn");
    // comment是我对这条分享的评论,仅在人人网和QQ空间使用
    //oks.setComment("我是测试评论文本");
    // site是分享此内容的网站名称,仅在QQ空间使用
    //oks.setSite("ShareSDK");
    // siteUrl是分享此内容的网站地址,仅在QQ空间使用
    //oks.setSiteUrl("http://sharesdk.cn");

    /*oks.setShareContentCustomizeCallback(new ShareContentCustomizeCallback() {
      @Override
      public void onShare(Platform platform, Platform.ShareParams paramsToShare) {
        if (SinaWeibo.NAME.equals(platform.getName())) {
          paramsToShare.setText("分享文本" + " " + "www.baidu.com");
          paramsToShare.setUrl(null);
        }
      }
    });*/
    oks.setCallback(new PlatformActionListener() {
      @Override
      public void onComplete(Platform platform, int i, HashMap<String, Object> hashMap) {
        //分享完成
        Message msg = new Message();
        msg.what = MSG_ACTION_CCALLBACK;
        msg.arg1 = 1;
        msg.obj = platform;
        handler.sendMessage(msg);
      }

      @Override
      public void onError(Platform platform, int i, Throwable throwable) {
        //分享失败
        throwable.printStackTrace();
        Message msg = new Message();
        msg.what = MSG_ACTION_CCALLBACK;
        msg.arg1 = 2;
        msg.obj = throwable;
        handler.sendMessage(msg);
      }

      @Override
      public void onCancel(Platform platform, int i) {
        //分享取消
        Message msg = new Message();
        msg.what = MSG_ACTION_CCALLBACK;
        msg.arg1 = 3;
        msg.obj = platform;
        handler.sendMessage(msg);
      }
    });
    oks.show(mActivity);
  }

6. 新浪微博实例分享

在正确使用shareSDK后,点击新浪微博的图形按钮,会弹出如下图的图文分享框,输入文字即可完成。

如图示


备注:如若分享网址链接,必须加上“http://”, 否则分享出去的仅是www.baidu.com


登录


授权


分享成功

备注:分享成功后,会有响应提示,需自行添加,登录新浪微博,即可看到个人信息中的分享,因为未未上线,因此“来自未通过审核应用”,当点击“百度”,即可进行界面跳转


成功分享

通过以上的核心部分的讲解,应该对新浪微博的分享有了基本的认识和使用能力。具体的细节,如如何创建界面,按钮,查询没有做过多的讲解。如果有需要,可以直接给我发简信,或者留言。

此外,针对上述的知识有不明白,异议,亦或是不正确的地方,还请帮忙指正,谢谢。

您可能感兴趣的文章:

相关文章