码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 抖音实战~分享模块~生成短视频二维码


    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

    文章目录

            • 一、可见范围
              • 1. 自己发布短视频
              • 2. 其他人发布短视频
            • 二、源码分析
              • 2.1. 底部窗口popup
              • 2.2. 实现组件uQRCode
              • 2.3. 插件涉及组件
              • 2.4. 组件改造
              • 2.5. 实现原理
            • 三、作品鉴赏
              • 3.1. 生成短视频二维码
              • 3.2. 微信扫描
              • 3.3. 抖音扫描

    一、可见范围

    保存到相册、复制链接、二维码 都是前端完成的

    1. 自己发布短视频

    自己发布的短视频会有“保存到相册、复制链接、二维码、转为私密”

    2. 其他人发布短视频

    其他人发布短视频,自己只能看到“保存到相册、复制链接、二维码”

    二、源码分析
    2.1. 底部窗口popup
    <view>
    			<!-- 底部窗口popup -->
    			<uni-popup ref="comment" type="comment">
    				<uni-popup-comments :thisVlogerId="thisVlogerId" :thisVlogId="thisVlogId"></uni-popup-comments>
    			</uni-popup>
    			<uni-popup ref="share" background-color="#fff" type="share">
    				<uni-popup-share :thisVlogerId="thisVlogerId" :thisVlogId="thisVlogId" :vlogUrl="thisVlog.url"
    					:isPrivate="thisVlog.isPrivate"></uni-popup-share>
    			</uni-popup>
    		</view>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    2.2. 实现组件uQRCode

    插件链接:https://ext.dcloud.net.cn/plugin?id=1287
    在这里插入图片描述

    组件案例:
    在这里插入图片描述

    2.3. 插件涉及组件

    在这里插入图片描述

    2.4. 组件改造

    uQRCode基于uqrcode.js实现

    		gotoQRCode() {
    				uni.navigateTo({
    					url: "/pages/qrcode/qrcode?vlogId=" + this.thisVlogId
    				})
    			},
    			
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    onReady() {
    			var vlogId = this.vlogId;
    			var content = {
    				type: "vlog",
    				content: vlogId
    			};
    			var contentStr = JSON.stringify(content);
    		    uQRCode.make({
    		        canvasId: 'qrcode',
    		        componentInstance: this,
    		        size: 170,
    		        margin: 10,
    		        text: contentStr,
    		        backgroundColor: '#ffffff',
    		        foregroundColor: '#0f0827',
    		        fileType: 'png',
    		        errorCorrectLevel: uQRCode.errorCorrectLevel.H
    		    })
    		    .then(res => {
    		    })
    		  },
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    2.5. 实现原理
    • 1.其实生成短视频二维码就是短视频的发布ID
    • 2.当微信扫描只会显示二维码生成的type和content文字内容,是因为没有对文字进行其他的操作。
    • 3.咱们抖音app当你扫描二维码时,做了以下几件事:
      • 3.1. 第一件事和微信扫描一样解析二维码后面的文字信息
      • 3.2. 获取短视频发布ID后,调用了后端短视频详情的api接口
      • 3.3.调用完接口后,有对短视频详情进行了短视频信息转视频的处理(其实就是预览短视频而已),和搜索页面实现的原理是一样的。

    后期会补充实现原理流程图,为大家详细揭晓

    三、作品鉴赏
    3.1. 生成短视频二维码

    在这里插入图片描述

    3.2. 微信扫描

    在这里插入图片描述

    3.3. 抖音扫描

    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    Kafka - kafka环境配置以及参数分析
    MR混合现实情景实训教学
    红外成像人员检测数据集
    【Git】git多人共享协作添加成员并授权与git拉取或提交冲突解决
    老卫带你学---leetcode刷题(46. 全排列)
    C++(二)
    【office办公-pdf篇】pdf合并与拆分让我们摆脱付费软件的功能限制好不好
    【图像分类】【深度学习】【Pytorch版本】VggNet模型算法详解
    剑指offer --- 用两个栈实现队列的先进先出特性
    数据库、数据中台、数据仓库、数据湖区别
  • 原文地址:https://blog.csdn.net/weixin_40816738/article/details/125466519
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号