0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

动态模板-流程设计

汽车电子技术 来源:程序猿搬砖 作者:坏人 2023-03-03 10:05 次阅读

动态绑定XML的逻辑已经完成了,接下来就是拆分整合各模块,实现渲染流程的每一个环节。

具体的渲染逻辑如下:

图片

「由于antlr编译支持库很大,所以这里设计了一个中间语言IR,以减小在Native上的引擎大小。」

原始测试XML如下:

<View flexDirection="row" width="300" height="auto"
    maxHeight="1000"
    left="20"
    top="50"
    justify="spaceAround"
    alignItems="stretch"
    paddingTop="10"
    paddingBottom="20"
    paddingLeft="15"
    paddingRight="15"
    backgroundColor="#FFCDB2">
    <View flex="2" height="auto" justify="center" alignItems="center" backgroundColor="#B5838D">
        <View width="{{ 50 / 2 + 10 }}"
            height="{{ 59 + 2.5 *2 -3 }}"
            backgroundColor="#6D6875"
            borderColor="#e63946"
            borderWidth="2"
            shadowColor="#d00000"
            shadowRadius="15"
            shadowOpacity="0.5"
            >class="hljs-name"View>
    class="hljs-name"View>
    <View flex="2" height="200" backgroundColor="#90B36D" justify="start" alignItems="center">
        <Label text="for测试: {{item[name]}} - {{ item[age] }}" fontSize="20" color="#ffd23f" for="{{ for item in items }}">class="hljs-name"Label>
        <Label text="测试标题2测试标题2测试标题2"
            fontSize="20"
            color="#ef233c"
            marginTop="10"
            lineNumber="3"
            backgroundColor="#00ff00">class="hljs-name"Label>
    class="hljs-name"View>
class="hljs-name"View>

通过模板编辑器(目前只实现了功能,没有实际意义上的编辑器工具)将表达式部分编译成IR,代码如下:

<View flexDirection="row" width="300" height="auto" maxHeight="1000" left="20" top="50" justify="spaceAround" alignItems="stretch" paddingTop="10" paddingBottom="20" paddingLeft="15" paddingRight="15" backgroundColor="#FFCDB2">
    <View flex="1" height="auto" justify="center" alignItems="center" backgroundColor="#B5838D">
        <View width="{{W3siTGVmdCI6IHsiTGVmdCI6IHsiU3ViVHlwZSI6ICJJbnQiLCAiVHlwZSI6ICJQcmltYXJ5IiwgIlZhbHVlIjogIjUwIn0sICJPUCI6ICIvIiwgIlJpZ2h0IjogeyJTdWJUeXBlIjogIkludCIsICJUeXBlIjogIlByaW1hcnkiLCAiVmFsdWUiOiAiMiJ9LCAiVHlwZSI6ICJCaW5hcnkifSwgIk9QIjogIisiLCAiUmlnaHQiOiB7IlN1YlR5cGUiOiAiSW50IiwgIlR5cGUiOiAiUHJpbWFyeSIsICJWYWx1ZSI6ICIxMCJ9LCAiVHlwZSI6ICJCaW5hcnkifV0=}}" height="{{W3siTGVmdCI6IHsiTGVmdCI6IHsiU3ViVHlwZSI6ICJJbnQiLCAiVHlwZSI6ICJQcmltYXJ5IiwgIlZhbHVlIjogIjU5In0sICJPUCI6ICIrIiwgIlJpZ2h0IjogeyJMZWZ0IjogeyJTdWJUeXBlIjogIkRvdWJsZSIsICJUeXBlIjogIlByaW1hcnkiLCAiVmFsdWUiOiAiMi41In0sICJPUCI6ICIqIiwgIlJpZ2h0IjogeyJTdWJUeXBlIjogIkludCIsICJUeXBlIjogIlByaW1hcnkiLCAiVmFsdWUiOiAiMiJ9LCAiVHlwZSI6ICJCaW5hcnkifSwgIlR5cGUiOiAiQmluYXJ5In0sICJPUCI6ICItIiwgIlJpZ2h0IjogeyJTdWJUeXBlIjogIkludCIsICJUeXBlIjogIlByaW1hcnkiLCAiVmFsdWUiOiAiMyJ9LCAiVHlwZSI6ICJCaW5hcnkifV0=}}" backgroundColor="#6D6875" borderColor="#e63946" borderWidth="2" shadowColor="#d00000" shadowRadius="15" shadowOpacity="0.5"/>
    class="hljs-name"View>
    <View flex="2" height="200" backgroundColor="#90B36D" justify="start" alignItems="center">
        <Label text="for测试: {{W3siS2V5IjogIm5hbWUiLCAiTm9kZSI6IHsiU3ViVHlwZSI6ICJJRCIsICJUeXBlIjogIlByaW1hcnkiLCAiVmFsdWUiOiAiaXRlbSJ9LCAiVHlwZSI6ICJFdmFsIn1d}} - {{W3siS2V5IjogImFnZSIsICJOb2RlIjogeyJTdWJUeXBlIjogIklEIiwgIlR5cGUiOiAiUHJpbWFyeSIsICJWYWx1ZSI6ICJpdGVtIn0sICJUeXBlIjogIkV2YWwifV0=}}" fontSize="20" color="#ffd23f" for="{{eyJBcnJheU5hbWUiOiAiaXRlbXMiLCAiSXRlbUtleSI6ICJpdGVtIiwgIlR5cGUiOiAiRm9yIn0=}}"/>
        <Label text="测试标题2测试标题2测试标题2" fontSize="20" color="#ef233c" marginTop="10" lineNumber="3" backgroundColor="#00ff00"/>
    class="hljs-name"View>
class="hljs-name"View>

生成如上代码,就可以交给引擎去渲染了,下面是项目整体的架构设计:

图片

目前Demo(iOS端)部分的调研效果已经有了,帖一下上面IR XML渲染效果,如下:

图片

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • XML
    XML
    +关注

    关注

    0

    文章

    183

    浏览量

    32936
  • 动态
    +关注

    关注

    0

    文章

    70

    浏览量

    20534
  • 渲染
    +关注

    关注

    0

    文章

    60

    浏览量

    10752
收藏 人收藏

    评论

    相关推荐

    什么是模板匹配?模板匹配的原理讲解 图像处理与模板匹配算法

    一:什么是模板匹配? 在OpenCV教程中这样解释模板匹配: 模板匹配是一项在一幅图像中寻找与另一幅模板图像最匹配(相似)部分的技术. 这里说的模板
    的头像 发表于 05-05 09:25 3.1w次阅读
    什么是<b class='flag-5'>模板</b>匹配?<b class='flag-5'>模板</b>匹配的原理讲解 图像处理与<b class='flag-5'>模板</b>匹配算法

    基于指纹模板的考勤系统设计

    上传完毕所有考勤记录;如果保存错误,转到(1)重新执行。(4),(5),(6)步中重新执行(1)最多三次,三次以上就认为上传考勤记录失败。  图3 上传考勤记录流程图  3.3 上传指纹模板  为了备份员工
    发表于 11-13 16:14

    怎样去新建一种基于STM32CubeMX的模板

    怎样去新建一种基于STM32CubeMX的模板?有哪些流程
    发表于 09-29 08:32

    模块化编程&工程模板设计

       九层妖塔 起于垒土【蓝桥杯】—{模板Template}—{Part1:模块化编程&工程模板}一、流程图二、基础知识1、编译预处理2、变量的定义和说明3、`extern`三、操作流程
    发表于 11-30 07:18

    ppt课件模板下载

    Zzone 精美PPT模板,一共有六十套,非常的经典。还有动态的哦。
    发表于 12-03 19:02 0次下载
    ppt课件<b class='flag-5'>模板</b>下载

    动态ppt课件模板

    动态的ppt课件模板,带动画的细纹设计课件模版, 动态魔方课件模版
    发表于 12-03 19:10 0次下载
    <b class='flag-5'>动态</b>ppt课件<b class='flag-5'>模板</b>

    SmartCortex_M3-1700工程模板-工程模板LPC1700

    SmartCortex_M3-1700工程模板-工程模板for LPC1700
    发表于 07-08 11:33 3次下载

    单片机C语言编程模板(基础模板)资料分享

    单片机C语言编程模板(基础模板)资料分享
    发表于 04-13 09:56 38次下载

    SMT模板设计和模板生产技术的简介

    今天,各种材料和制造技术使供应商能够设计出能够应对微妙斜坡挑战的模板,小零件和高密度封装板。此外,模板技术现在是一种广泛的成像材料,而模板设计师已经获得了丰富的知识和经验。他们知道一个洞有多大,形状会影响矿床。钢网有两个基本功能
    的头像 发表于 07-31 15:05 1452次阅读

    SMT加工模板印刷的基本操作流程

    SMT加工模板印刷作为最基本的SMT贴片加工厂焊膏印刷方式,尽管现代印刷设备有多种,但其印刷基本过程一样。下面要求来了解一下它的基本操作流程
    的头像 发表于 01-10 11:36 5516次阅读

    项目流程图怎么画?项目流程图经典免 费模板分享

    Linux系统平台)且具有亿图在线版支持在浏览器网页直接使用,多平台支持使用满足用户不同的使用需求。软件内置260多种绘图类型,3000+模板素材,丰富多样的绘制素材帮助办公人士快速绘制:项目流程图、思维
    的头像 发表于 07-28 11:58 3030次阅读

    模板函数以及模板类的基本概念以及原理

    最近使用C++做些编程,把日常遇到的些比较重要的概念总结分享一下。本文来分享一下模板类的原理,以及为什么需要模板类,使用时的基本要点。
    的头像 发表于 07-11 10:42 913次阅读

    动态模板语义分析-动态绑定XML

    DynamicDSL将遵循以下的交互展示逻辑: 描述文件(XML,Widget) --->(绑定数据)--->渲染模板--->渲染--->事件驱动--->数据改变 这样循环下来的,最终我们看到的就是App上的界面与交互效果了。
    的头像 发表于 03-03 10:06 403次阅读
    <b class='flag-5'>动态</b><b class='flag-5'>模板</b>语义分析-<b class='flag-5'>动态</b>绑定XML

    隔离设计流程+动态函数交换示例

    电子发烧友网站提供《隔离设计流程+动态函数交换示例.pdf》资料免费下载
    发表于 09-14 09:31 0次下载
    隔离设计<b class='flag-5'>流程</b>+<b class='flag-5'>动态</b>函数交换示例

    如何通过模板模式重构代码

    法的某些特定步骤。 说人话:父类模板方法定义不变的流程,子类重写流程中的方法。 2、模板模式定义 ①、AbstractClass 抽象
    的头像 发表于 10-08 16:15 241次阅读
    如何通过<b class='flag-5'>模板</b>模式重构代码