【HarmonyOS】鸿蒙应用接入微博分享

【HarmonyOS】鸿蒙应用接入微博分享

一、下载微博分享SDK

微博分享SDK官网地址:https://open.weibo.com/wiki/SDK

点击鸿蒙SDK下载DEMO项目压缩包,下载完成后得到以下压缩包:

二、修改项目工程配置,签名

压缩包解压后,通过IDE(DevEco Studio)打开该项目,修改其项目工程配置。因为微博上传得项目版本比较老,且签名和SDK相关引用得配置也提交了,需要手动进行修改。否则项目跑不起来。

  1. 删除oh-package-lock.json5文件

  2. 删除local.properties中的sdk引用地址

  3. 删除build-profile.json5中无用的core模块引用。而上方的签名配置,通过自动签名重新同步即可。

    最后检查oh-package.json5其中的devDependencies引入版本信息与你的IDE和SDK配套版本是否一致。

后续微博的压缩包还会更新,跑不起来项目,可以通过新建示例项目配置的检查顺序做对比( 用你的IDE新建一个项目进行对比检查。)

三、运行微博SDK项目,copy分享相关代码进行接入

以上是微博SDK项目跑起来的效果。因为我们的目标是集成微博分享,看图说话。所以只需要SDK初始化和分享两个按钮的实现操作。有了思路就好办事了。下面开始。

1.首先获取微博SDK:

2.微博SDK初始化:

初始化很简单,直接调用WBAPI进行单例的获取,自己在进行状态标记。copy,copy走,完事。

Index.ets

dart 复制代码
  private initSdk() {
    this.isInit = true
    this.mWBAPI = WBAPI.getInstance();
  }

3.微博SDK分享API:

可以看到直接跳转到了一个分享页,分享单独创建了一个SharePage进行分享api能力的示例。以下是分享页面的效果:

我们可以看到鸿蒙的微博分享,有三种形式文本,图片和视频。与Android和IOS差不多。点击开始分享后的效果如下图所示:

点击允许后,会直接跳转到转发微博发送,如下图所示。(在你安装了微博并且登录的情况下)

但是经过我的实际操作验证,发现不管勾选了文本,还是图片,以及视频。亦或者是全部勾选,都会跳转到这个页面。

【之后我反复操作进行了重新验证,发现进行勾选类型是有效果的,看来刚才是bug。 O.o ? 】

例如我勾选了文本和图片的效果如下:

在你分享完成或者点击左上角取消之后,微博也会提示再跳转回去的弹框:

整个分享过程搞明白之后,我们就开始根据操作,copy分享api调用的代码逻辑即可。

API代码分享示例:

SharePage.ets

dart 复制代码
 private async doWeiboShare() {
    let message: WeiboMultiMessage = new WeiboMultiMessage();
    let textObject = new TextObject();
    let text = "我正在使用微博客户端发博器分享文字。";
    if(this.shareText) {
      text = "这里设置您要分享的内容!";
      textObject.text = text;
      message.textObject = textObject;
    }
    //多图分享
    if(this.shareMultiImage) {
      let multiImage = new MultiImageObject();
      try {
        let uris = new ArrayList<string>();
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/aaa.png"));
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/bbb.png"));
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/ccc.png"));
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/ddd.png"));
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/eee.png"));
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/fff.png"));
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/ggg.png"));
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/hhhh.png"));
        uris.add(fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + "/kkk.png"));
        multiImage.uriStrs = uris.convertToArray();
      } catch (e) {
        let err = e as BusinessError
        Utils.logger.error("zhaojun8", "multi image file operation failed, error msg = " + err.message);
      }
      message.multiImageObject = multiImage;
    }

    if(this.shareVideo) {
      let videoObj = new VideoSourceObject();
      try {
        let videoFilePath = Utils.getVideoCacheFile(getContext()) + '/eeee.mp4';
        let videoUri = fileUri.getUriFromPath(videoFilePath);
        let coverUri = fileUri.getUriFromPath(Utils.getImageCacheFile(getContext()) + '/cover.png');
        videoObj.videoPath = videoUri;
        videoObj.coverPath = coverUri;
      } catch (e) {
        let err = e as BusinessError;
        Utils.logger.error("zhaojun8", "video file operation failed, error msg = " + err.message + ", e: " + e);
      }
      message.videoSourceObject = videoObj;
    }

    if(this.mWBAPI != null) {
      let listener: WbASListener = {
        onComplete: () => {
          promptAction.showToast({
            message: '分享成功',
            duration: 2000
          });
        },
        onError: (error: UiError) => {
          promptAction.showToast({
            message: '分享出错: ' + error.errorMessage,
            duration: 2000
          });
        },
        onCancel: () => {
          promptAction.showToast({
            message: '分享取消',
            duration: 2000
          });
        }
      };
      this.mWBAPI.shareMessage(this.context, message, listener);
    }
  }

目前来看鸿蒙微博分享API调用起来很简单。集成很方便。快来集成微博分享吧。

相关推荐
深海的鲸同学 luvi3 小时前
【HarmonyOS NEXT】华为分享-碰一碰开发分享
华为·harmonyos·碰一碰·华为分享
沅霖10 小时前
鸿蒙harmony json转对象(2)
harmonyos
AGI学习社12 小时前
2024中国排名前十AI大模型进展、应用案例与发展趋势
linux·服务器·人工智能·华为·llama
kirk_wang1 天前
Flutter调用HarmonyOS NEXT原生相机拍摄&相册选择照片视频
flutter·华为·harmonyos
星释1 天前
鸿蒙Flutter实战:17-无痛上架审核指南
flutter·华为·harmonyos
jikuaidi6yuan1 天前
鸿蒙操作系统的安全架构
华为·harmonyos·安全架构
HarderCoder1 天前
鸿蒙开发者认证-题库(二)
harmonyos
轻口味1 天前
HarmonyOS Next 最强AI智能辅助编程工具 CodeGenie介绍
人工智能·华为·harmonyos·deveco-studio·harmonyos-next·codegenie
jikuaidi6yuan1 天前
除了基本的事件绑定,鸿蒙的ArkUI
华为·harmonyos
GY-931 天前
Flutter中PlatformView在鸿蒙中的使用
flutter·harmonyos