【2023最新】超详细图文保姆级教程:App开发新手入门(5)

上文回顾,我们已经完成了一个应用的真机调试,本章我们来了解一下如何引入YonBuilder移动开发的(原生)移动插件, 并利用移动插件完成一个简单的视频播放器。

8. 「移动插件」的使用

8.1 什么是 「移动插件」?

用通俗的话来解释,YonBuilder移动开发内的「移动插件」,是指使用原生语言(android,Object-C)封装好的具备特定功能的SDK程序, 在YonBuilder移动开发引擎的支持下,可以让开发者在JavaScript的编程环境内直接调用使用。开发者无需关心移动插件的内部实现,只需简单的函数调用,即可完成各种复杂原生功能的开发。因为移动插件内部是使用原生语言开发的,所以在运行性能上同原生应用一致,不存在运行性能上的差异,YonBuilder移动开发的「移动插件」是打破混合应用性能瓶颈的绝佳利器。

当前YonBuilder移动开发官网已上线1400+的各种功能的「移动插件」供开发者使用,有兴趣的同学可以访问官方开发者中心 -> 资源市场 -> 移动插件,进行查看 (本方式无需登录)

快速传送门

在这里插入图片描述

可以登录横向的功能分类导航条 或 点击右侧的搜索按钮输入关键词的方式,去查找对应功能的移动插件

8.1.1 移动插件详情页的简单介绍

点击页面列表中的任意一个移动插件图标,即可进入移动插件详情介绍页,查看该插件的具体功能介绍。

在这里插入图片描述

8.1.2 搜索查找需要的功能移动插件,比如我们在搜索框输入”播放器“,就可以显示出和播放器相关的功能移动插件

在这里插入图片描述

8.2. 如何使用移动插件

上面介绍了未登录状态下,查看移动插件的方式,当真正想要使用移动插件时,还是需要在登录状态下进行。当前官方提供两种添加移动插件的方式,下面以集成一个 moviePlayer 为例(这个是官方封装的免费的视频播放器移动插件),详细讲述下如何使用YonBuilder移动开发的移动插件。

8.2.1 添加移动插件

8.2.1.1 方式一:资源市场添加方式

即在登录状态下,按上面 8.1 介绍的方式,访问资源市场 ,搜索栏输入关键词 moviePlayer,找到对应的插件,点击打开插件详情页,然后点击「立即使用」按钮,在弹出的弹窗上选择对应的租户和应用,即可完成插件的添加。

在这里插入图片描述

8.2.1.2 方式二:在应用管理页面内添加(常用推荐)

首先我们先进入云端的应用管理页。

页面访问路径:

  • 登录用友开发者中心网站:developer.yonyou.com - 点击左侧菜单栏中的「移动开发」(或 点击左上角「大风车」图标,选择 云平台-低代码开发平台-移动APP开发)

    在这里插入图片描述

  • 列表页选择对应的应用,点击即可进入应用的管理界面 - 切换导航到「移动插件」- 二级导航切换到「移动插件库」- 搜索栏输入关键词 moviePlayer - 找到对应的插件,点击 + 按钮,完成插件的添加

    在这里插入图片描述

    PS1: 如果想查看插件的功能介绍或者使用文档,可以点击对应的插件左侧的图片,即可弹出详情介绍弹窗;

    在这里插入图片描述

    PS2: 此处「移动插件库」页面的搜索栏,默认是支持全类别搜索的。

    在这里插入图片描述

8.2.2 查看已添加的移动插件

切换导航到「已添加插件」,可查看当前应用已添加的所有移动插件。

在这里插入图片描述

8.2.3 重新编译应用安装包(重要)

每当有新的移动插件添加到应用中时,为了使移动插件在代码中生效,我们需要重新进行一次移动打包编译(自定义Loader或者「移动打包」页的[ 正式版|测试版 ]。其内在原理是 所有的原生移动插件代码源码都存储在官网服务器上,当某个应用需要使用某个移动插件时,服务器需要通过「移动打包」的编译功能动态的将移动插件对应的代码注入到具体的应用中,这样新添加的移动插件才可以在这个应用中生效。

本次教程使用的是自定义Loader进行演示,我们切换导航到「Loader调试」

在这里插入图片描述

编译成功后,重新下载自定义loader,并安装到手机移动端(或者模拟器上)。

在这里插入图片描述

8.3 [实战示范]:引用移动插件并编写对应代码

打开YonStudio开发工具,按以下描述进行代码修改

8.3.1 修改html/main.html文件

先提供一下修改后的 mian.html 文件的完整代码(可以直接复制替换原有的 mian.html 内代码)

<!DOCTYPE HTML>
<html>
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="maximum-scale=1.0, minimum-scale=1.0, user-scalable=0, initial-scale=1.0, width=device-width" />
    <meta name="format-detection" content="telephone=no, email=no, date=no, address=no">
    <title>Hello APP</title>
    <link rel="stylesheet" type="text/css" href="../css/apiutil.css" />
    <style>
        label {
            margin: 10px;
            font-size: 24px;
            color: red;
        }
        ul {
            margin-bottom: 10px;
        }
        ul li {
            margin: 5px 10px;
            padding: 5px;
            color: #000;
            word-wrap: break-word;
        }
        .video-wrap {
            width: 100%;
            height: 300px;
        }
    </style>
</head>

<body>
    <div id="wrap" class="video-wrap"></div>
    <label>YonBuilder移动开发 视频播放器</label>
    <div id='sys-info'></div>
</body>
<script type="text/javascript" src="../script/apiutil.js"></script>
<script type="text/javascript">
    apiready = function() {        
        // 调用执行初始化播放器
        initMoviePlayer();
    };

    // 定义一个函数,用于初始化 moviePlayer 移动插件对象
    function initMoviePlayer () {
        // 初始化 moviePlayer 移动插件对象
        var moviePlayer = api.require('moviePlayer');
        // 获取上个页面传递的navH参数值
        var navH = api.pageParam.navH;
        // 获取id = wrap dom元素的宽高尺寸
        var videoRect = $api.offset($api.byId('wrap'));
        // 启动播放器
        moviePlayer.open({
            // 设置播放器的尺寸
            rect: { 
                x: videoRect.l,
                y: navH, // 设置播放器具体顶部的距离,用于避免覆盖顶部的NavBar
                w: videoRect.w,
                h: videoRect.h
            },
            // 设置播放器的外观样式
            styles: {
                head: {
                    height: 0
                },
                foot: {
                    bg: 'rgba(0,0,0,0.5)',
                    height: 44,
                    currentTimeLabel: {
                        textSize: 14,
                        textColor: "#FFF",
                        textWidth: 43,
                        marginLeft: 5
                    },
                    totalTimeLabel: {
                        textSize: 14,
                        textColor: "#FFF",
                        textWidth: 43,
                        marginRight: 5
                    }
                }
            },
            // 测试的视频资源地址
            path: 'https://media.w3.org/2010/05/sintel/trailer.mp4',
            // 设置播放器初始化后,是否自动播放
            autoPlay: true
        }, function (ret, err) {
            // 这里的回调参数当播放器状态改变后,会触发相关回调,可以在这里写一些交互逻辑
        });
    };
</script>

</html>

下面对修改的部分,简单进行一下代码逻辑讲解:

    1. 修改 html 页面内的代码,在 body 标签内加入一个 dom 占位元素<div id="wrap" class="video-wrap"></div>,并修改 label 标签内的文字 <label>YonBuilder移动开发 视频播放器</label>
    <body>
        <div id="wrap" class="video-wrap"></div>
        <label>YonBuilder移动开发 视频播放器</label>
        <div id='sys-info'></div>
    </body>
    

    PS: moviePlayer 移动插件是使用原生语音开发的,并不在html的dom文档流内,所以需要创建一个dom元素去占位,避免 播放器的界面遮挡了原来的dom元素内容。

    1. style标签内添加 步骤3 新增的dom元素需要的样式代码
    <style>
        
        <!--省略原有代码-->
    
        .video-wrap {
            width: 100%;
            height: 300px;
        }
    </style>
    
    1. 在底部的script脚本标签内部,新增定义一个 initMoviePlayer 函数方法,用于初始化 moviePlayer 移动插件
    // 定义一个函数,用于初始化 moviePlayer 移动插件对象
    function initMoviePlayer () {
    	// 初始化 moviePlayer 移动插件对象
    	var moviePlayer = api.require('moviePlayer');
    	// 获取上个页面传递的navH参数值
    	var navH = api.pageParam.navH;
    	// 获取id = wrap dom元素的宽高尺寸
    	var videoRect = $api.offset($api.byId('wrap'));
       	// 启动播放器
    	moviePlayer.open({
    	    // 设置播放器的尺寸
    	    rect: { 
    	        x: videoRect.l,
    	        y: navH, // 设置播放器具体顶部的距离,用于避免覆盖顶部的NavBar
    	        w: videoRect.w,
    	        h: videoRect.h
    	    },
       		<!--其余代码略,具体参见上面的完整代码-->
       	});
    };
    

    PS1: 语句var navH = api.pageParam.navH;, 使用了一个 api.pageParam api方法,这个是官方提供的api对象的方法,具体作用是 获取上个页面传递过来的参数值。 更多的关于 api 对象方法的介绍,可见 API对象 官方文档

    PS2: 语句 var videoRect = $api.offset($api.byId('wrap'));, 目的是获取 步骤1 添加的 dom占位元素的宽高尺寸,因为 moviePlayer 初始化时,需要给 rect 参数设置播放器的宽高等位置尺寸,这里获取就是为了保持一致。

    PS3: 语句 var videoRect = $api.offset($api.byId('wrap')); 这部分的代码里使用了 两个 $api 对象方法,$api.byId方法是可以根据 id值去获取 页面内的 dom元素, 功能同 document.getElementById, $api.offset 方法是获取dom元素的形状尺寸, 这个 $api 对象是引入的 script/apiutil.js 脚本实现的, apiutil.js 是官方封装的一个前端工具框架,具体可见 YonBuilder移动开发前端框架 官方文档

    <script type="text/javascript" src="../script/apiutil.js"></script>
    
    1. 修改apiready方法,清空原内部的逻辑代码,并加入了调用 步骤1函数的语句。
    apiready = function() {        
        // 调用执行初始化播放器
        initMoviePlayer();
    };
    

    PS: apiready 方法是 YonBuilder移动开发中 每一个 html 文件的入口启动函数,官方提供的大量api方法(如 api.openWin 等)都需要等页面加载 api 对象后才可以使用,否则程序会报错。而 apiready 函数方法就是 html 页面加载完 api 对象后,会主动调用执行的函数方法。所以我们可以理解为 apiready 函数就是 html 页面的入口自执行启动函数。

8.3.2 修改index.html文件

在 index.html 页面内的 79 行,为 api.openFrame 增加以下 pageParam 参数, 具体代码如下

pageParam: {
    navH: headerH // 顶部NavBar的高度值
}

该修改是为了呼应 8.3.1 操作中 第 3 步 中PS3 描述的 获取 api.pageParam 参数值,将页面顶部 NavBar占据的高度值(包括 statusBar 占据的高度) 发给 main.html 页面,供 播放器 设置距离顶部的距离。

在这里插入图片描述

PS: 每次修改文件后,记得保存文件,这样修改才能生效。

8.3.3 同步代码

    1. 启动自定义AppLoader,并与 YonStudio工具进行连接(要保证 自定义AppLoader内的。(具体还不会的同学,可以查看上个大章节(4)的相关介绍 )
    1. 鼠标右键点击 widget 文件夹,并选择 WIFI同步(全量) (或者可以直接使用对应的快捷键)

    在这里插入图片描述

同步后,即可在AppLoader端查看到运行效果,如下图( 是不是很方便 -

在这里插入图片描述

8.4 后话

上面仅仅是简单的示范了一下使用移动插件的方法,为了方便新手理解,并没有深入的扩展。比如上面使用的moviePlayer移动插件就有很多的方法,有兴趣的同学可以查看移动插件对应的开发文档,自行修改查看运行效果。

moviePlayer的开发说明文档地址

另外,官方也提供了「自定义插件」的扩展原生插件机制,支持开发者去根据需要自行封装「移动插件」。

友情提示:「自定义移动插件」这块属于扩展功能,不会也完全不影响正常的应用开发,建议掌握了android开发或iOS开发能力的同学查看,其他人可忽略

更多关于「自定义移动插件」的介绍说明,可查看以下链接

  • 移动原生插件开发设计规范
  • 移动原生插件开发指南-iOS
  • 移动原生插件开发指南-AndroidEclipse
  • 移动原生插件开发指南-AndroidStudio

(未完待续…)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/12022.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HDLBits-Modules 题解【Verilog模块例化】(中文翻译+英文原文,可顺带学习英文)

Moudule 概念介绍 到目前为止&#xff0c;你已经熟悉了一个模块&#xff0c;它是一个通过输入和输出端口与其外部交互的电路。更大、更复杂的电路是通过将较小的模块和其他连接在一起的部分&#xff08;例如赋值语句和always块&#xff09;组合而成的更大模块来构建的。因为模…

对决:Kubernetes vs Docker Swarm - 谁才是最优秀的容器编排方案?

✅创作者&#xff1a;陈书予 &#x1f389;个人主页&#xff1a;陈书予的个人主页 &#x1f341;陈书予的个人社区&#xff0c;欢迎你的加入: 陈书予的社区 文章目录一、介绍1. 什么是Kubernetes2. 什么是Docker Swarm3. 为什么需要容器编排&#xff1f;二、 架构比较1. Kubern…

C++【栈队列(3种)反向迭代器】

文章目录一、容器适配器二、栈&#xff08;一&#xff09;栈定义&#xff08;二&#xff09;栈使用接口&#xff08;三&#xff09;栈模拟实现(1) 栈模拟实现解析(2) 栈模拟实现代码(3) 栈模拟结果三、队列&#xff08;一&#xff09;普通队列&#xff08;1&#xff09;普通队列…

30天学会《Streamlit》(3)

30学会《Streamlit》是一项编码挑战&#xff0c;旨在帮助您开始构建Streamlit应用程序。特别是&#xff0c;您将能够&#xff1a; 为构建Streamlit应用程序设置编码环境 构建您的第一个Streamlit应用程序 了解用于Streamlit应用程序的所有很棒的输入/输出小部件 第3天 - st.…

实验三、图像复原

1. 实验目的 (1) 理解退化模型。 (2) 掌握常用的图像复原方法。 2. 实验内容 (1) 模拟噪声的行为和影响的能力是图像复原的核心。 示例 1 &#xff1a;使用 imnoise 添加噪声。 J imnoise(I,gaussian) 将方差为 0.01 的零均值高斯白噪声添加到灰度图像 I。 J imnoise(I,g…

最近ChatGPT封号太严重了,这里是解封攻略步骤(建议收藏)

这个周末&#xff0c;先是意大利暂时封杀ChatGPT&#xff0c;限制OpenAI处理本国用户信息。 接着&#xff0c;据韩国媒体报道&#xff0c;三星导入ChatGPT不到20天&#xff0c;便曝出机密资料外泄。 还没结束&#xff0c;又有大量网友发现ChatGPT目前停止注册&#xff0c;开始…

​力扣解法汇总1026. 节点与其祖先之间的最大差值

目录链接&#xff1a; 力扣编程题-解法汇总_分享记录-CSDN博客 GitHub同步刷题项目&#xff1a; https://github.com/September26/java-algorithms 原题链接&#xff1a;力扣 描述&#xff1a; 给定二叉树的根节点 root&#xff0c;找出存在于 不同 节点 A 和 B 之间的最大值…

Samba共享

关闭selinux跟防火墙 setenforce 0 systemctl stop firewalld 安装samba以及客户端 yum install samba samba-client -y 创建共享目录 mkdir -p /data/share1 mkdir -p /data/public 添加samba用户并配置权限 useradd zsuser smbpasswd -a zsuser 修改配置文件并重启服…

【Hello Linux】信号量

作者&#xff1a;小萌新 专栏&#xff1a;Linux 作者简介&#xff1a;大二学生 希望能和大家一起进步&#xff01; 本篇博客简介&#xff1a;简单介绍linux中信号量的概念 信号量信号量的概念信号量的使用信号量函数二元信号量模拟互斥功能基于环形队列的生产者消费者模型空间资…

23-Ajax-axios

一、原生Ajax <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice-width…

中科大ChatGPT学术镜像小白部署教程,全民都可以拥抱AI

docker…不会用…python不会用…服务器默认python版本3.6不会升级…代理也不会配置…各种命令不会用… 那么下面就是最简单办法&#xff0c;点点点即可【希望有帮助&#xff1f;】 文章目录一、体验镜像地址二、 基本配置2.1 config.py文件2.2 main.py文件三、下载项目四、项目…

【C++】哈希表:开散列和闭散列

&#x1f4dd; 个人主页 &#xff1a;超人不会飞)&#x1f4d1; 本文收录专栏&#xff1a;《C的修行之路》&#x1f4ad; 如果本文对您有帮助&#xff0c;不妨点赞、收藏、关注支持博主&#xff0c;我们一起进步&#xff0c;共同成长&#xff01; 目录前言一、基于哈希表的两个…

一条更新语句的执行流程又是怎样的呢?

当一个表上有更新的时候&#xff0c;跟这个表有关的查询缓存会失效&#xff0c;所以这条语句就会把表T上所有缓存结果都清空。这也就是我们一般不建议使用查询缓存的原因。 接下来&#xff0c;分析器会通过词法和语法解析知道这是一条更新语句。优化器决定要使用ID这个索引。然…

JAVA+SQL离散数学题库管理系统的设计与开发

题库、试卷建设是教学活动的重要组成部分&#xff0c;传统手工编制的试卷经常出现内容雷同、知识点不合理以及笔误、印刷错误等情况。为了实现离散数学题库管理的信息化而开发了离散数学题库管理系统。 该系统采用C/S 模式&#xff0c;前台采用JAVA&#xff08;JBuilder2006&am…

如何选择合适的网络自动化工具

通过网络自动化工具实现网络自动化是所有网络组织的关键。如果没有合适的网络自动化工具&#xff0c;拥有由许多设备组成的大型网络环境的组织将无法执行重要操作&#xff0c;例如按时备份配置、实时跟踪不需要的更改以及遵守行业法规。当组织未能使用正确的网络自动化工具来执…

四百左右哪款蓝牙耳机比较好?400元价位蓝牙耳机推荐

除了日常通勤以及休息前听歌以外&#xff0c;随着加班变得频繁&#xff0c;工作时也戴起了耳机&#xff0c;由于市面上的耳机种类繁多&#xff0c;因此许多人不知道从而选择&#xff0c;小编发现更多的人是追求性价比&#xff0c;所以整理了一期四百左右性能表现优异的款式给大…

量化择时——LSTM深度学习量化择时(第1部分—因子测算)

之前我们尝试使用SVM&#xff0c;将时序数据转为横截面的数据&#xff0c;使用机器学习的方法进行预测 量化择时——SVM机器学习量化择时&#xff08;第1部分—因子测算&#xff09;&#xff1a; https://blog.csdn.net/weixin_35757704/article/details/129909497 但是因为股…

DHCP及中继(UOS)

DHCP服务器 中继器 客户端 服务器 安装DHCP apt install isc-dhcp-server -y 编辑配置文件 vim /etc/dhcp/dhcpd.conf 重启服务 systemctl restart isc-dhcp-server 配置监听网卡 vim /etc/default/isc-dhcp-server 中继器 安装dhcp yum install dhcp -y nmtui 修改…

pytest测试报告Allure - 动态生成标题生成功能、添加用例失败截图

一、动态生成标题 默认 allure 报告上的测试用例标题不设置就是用例名称&#xff0c;其可读性不高&#xff1b;当结合 pytest.mark.parametrize 参数化完成数据驱动时&#xff0c;如标题写死&#xff0c;其可读性也不高。 那如果希望标题可以动态的生成&#xff0c;采取的方案…

Hadoop 生态圈及核心组件简介Hadoop|MapRedece|Yarn

文章目录大数据时代HadoopHadoop概述Hadoop特性优点Hadoop国内外应用Hadoop发行版本Hadoop集群整体概述HDFS分布式文件系统传统常见的文件系统数据和元数据HDFS核心属性HDFS简介HDFS shell操作Map Reduce分而治之理解MapReduce思想分布式计算概念MapReduce介绍MapReduce产生背景…