可视化大屏构建平台

一、需求分析

1、来自大屏的需求

2、项目上只是需要简单的大屏效果功能

3、基于未来的发展,我们前端组需要构建可视化大屏的底座

4、不能够直接按照可视化大屏的方式去做工作台等

5、为长远打算我们需要把底层能力制作完成,支持服务场景迁移

6、要确保该注重前端能力,核心部分减少后端依赖过多依赖,后端负责资源与存储

7、前端项目的可视化搭建

二、功能设计

1、组件

注册配置,注册交互,注册行为函数

2、数据

3、交互

4、可视化界面(半段)

三、可视化大屏

  • 全局数据

    • Url 数据
    • 模板数据
    • 临时数据
    • 全局变量
      • 当前页面的固有数据变量
  • 设计器

image.png
  • 渲染

    • 布局组件
      • 容器组件<div>
      • 文字组件<span>
      • 图片组件 <img>
      • group组件
        • 外层控制样式展示,内层递归寻找数据,实现列组件递归渲染。变体:轮播图模式
    • 表单属性组件
    • 组件模式
      • 设计
      • 编辑
      • 预览
  • 模板语法

https://baidu.github.io/amis/zh-CN/docs/concepts/data-mapping

  • 模板(待开发)

    • 场景
      • 数据流向
      • 结构
      • 菜单
    • 模板设计器
  • 资源

    • 组件

自定义组件 + 系统的基础组件

  • 表单功能

  • 组件配置

    • 渲染方式相关
    • 接收数据限定与数据显示相关
      • 字典类
      • 时间
      • 头像
      • 进度条
    • 数据处理方式
      • Cover 外部数据直接覆盖默认值
      • 并集
      • 差集
      • 合集
    • 事件与行为注册 (可视化交互)
      • 能够对外发布事件
      • 接收外部传入的行为
    • 切换
    • 交互拼装(待开发)
  • 数据源

通过插件注入的方式,集成不同类型的数据源

  • 系统自带httpRequest 接口请求

  • BI数据源 表查询与过滤条件(下周开发)

  • 脚本 (底座)(待开发)

  • 样式

样式作为大屏非常重要的部分,样式的设计更贴合真实开发,除了配置的方式外,还可以添加css 文本脚本

  • 样式解析器

  • Option To Style

  • Css To Option

  • 主题变量 (未)

  • 图片

    • 接收url 方便做动态图片
  • 字典

    • 字典类的数据多关联其他的动态状态
      • 动态样式
        • 组件的字典不同使用不一样的动态样式
      • 动态脚本
        • 根据组件字典值的不同执行脚本
  • 动画 (半成品)

    • 组件的入场、出场动画以及特殊触发条件
    • 不同类型组件的动效
      • 数字翻牌
      • Group list 组件的载入
      • 多模块入场动画
  • Timeline

    • animation
      • Action itme
  • 位置

  • 缩放

  • 旋转

  • Layer

  • 状态 (待开发)

    • 样式状态管理
    • 组件状态
  • 3D编辑器 https://tengge1.gitee.io/shadoweditor-examples/ (待开发)

    • 资源
      • 几何体
      • 模型库
        • 场景
        • 模型
        • 贴图
        • 材质
        • 音频
        • 动画
        • 粒子
        • 预设体
        • 截图
        • 视频
        • 日志
      • 资源导入方式
      • 组件
    • 树形图
      • 场景
        • 灯光
        • 环境光
        • 平行光
        • 点光源
        • 聚光灯
        • 半球光
        • 矩形光
      • 相机
  • 插件

    • 资源注入
    • 资源生命周期
      • 接口日志拦截,数据查看
      • 资源使用情况面板
      • 脚本执行单元测试

[交互]

配合组件注册的时间行为,搭建交互逻辑

  • Node

    • 组件
    • 逻辑单元
  • Edge

    • 关联
  • 多场景

    • 独立项目大屏开发

    • 业务项目中进行页面开发

    • BI可视化大屏集成

    • IDE远程连接BI自定义组件

  • 多端

    • H5应用
    • 自适应布局方式,基于styleOption
  • 多模式

    • 可视化设计模式

    • 预览模式

    • 函数式开发

    • Option To Code

    • Static Page To Option

  • API

    • 预留 接口配置
    • Core
      • Component

        • addChild
        • setConfig
        • setStyle
      • Interact

        • fromEvent
        • addNode
  • 智能化

    • tag标签
    • 数据格式

2、配置

Component

componentName: 'text-box',
option: {
    initialValue: '',
    valueType: '',
    valueHandler: 'cover',
    fieldName: '',
    fieldType: 'String',
    config: {
    },
    attrs: {
     alt: ''
    },
    dataSever: {
     created: '',
    },
    animation: {
     on: false
    }
},

Style / imge

style: {
 options: {
  default: {
   color: 'white',
   __image: {
    id: 'viewRank',
   },
   height: '35px',
   marginTop: '16px',
   width: '100%',
   position: 'relative',
  },
 }
}

Data

[
 {
  type: 'interface-option',
  triggerModes: ['created'],
  option: {
   method: 'get',
   params: {
    pageSize: 10,
    pageNum: 1
   },
   url: '/everdc-stand-model/model/page?t=1630923934229',
   response: {
    key: 'list'
   },
   mode: 'remote',
   isRemoteErrorMockOn: true,
   mockData: [
    {
     name: '张三1',
     type: 1,
    },
    {
     name: '张四2',
     type: 0,
    },
   ]
  }
 }
]

Dict

dict: {
 id: 'modelType',
 option: {
  dynamicStyleId: {
   'unactive': 0,
   'active': 1
  },
 },
}

交互配置

 {
 nodes: [
     {
         id: '',
         inputs: [],
         output: [],
     }
 ],
 edges: [

 ]
 }

3、未完成

  • 地图
  • 动画合集制作
  • echarts 图与数据
  • 模板功能
  • 多个原子组件形成稳定的组件独立体
  • 容器化部署
  • 权限,业务,数据流程管理
  • 主题

四、意见需求收集

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,290评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,399评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,021评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,034评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,412评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,651评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,902评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,605评论 0 199
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,339评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,586评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,076评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,400评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,060评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,083评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,851评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,685评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,595评论 2 270

推荐阅读更多精彩内容