添加资源池

根据项目需求 添加,

实例两个数据

{
"mainData": [
{
"x": 0,
"y": 0,
"w": 4,
"h": 4,
"i": 0,
"Component": "planExecution",
"IsResource": false
}
]
}

layoutData.json

{
"mainData": [{
"x": 0,
"y": 0,
"w": 2,
"h": 2,
"i": 0,
"Component": "productionLine",
"IsResource": true
},
{
"x": 0,
"y": 0,
"w": 2,
"h": 2,
"i": 0,
"Component": "takeTime",
"IsResource": true
},
{
"x": 0,
"y": 0,
"w": 4,
"h": 2,
"i": 0,
"Component": "yieldStatistics",
"IsResource": true
}
]
}

resourcesData.json

引到页面中

  import layoutData from '@/virtualData/layoutData.json'
import resourcesData from '@/virtualData/resourcesData.json'

增加 资源数据 并且给页面数据 赋值

      // 初始化数据
init() {
this.layoutData = layoutData.mainData
this.ResourceData = resourcesData.mainData
}

初始化页面之后,把资源池数据添加到页面数据中

 // 打开资源池
OpenResource() {
// 资源起始点
const x = 12
// 计算向下高度
let y = 0
// 是否行并行
let wFlag = false
// 并行高度
let tempY = 0
const Resource = this.ResourceData
for (const item of Resource) {
if (item.w === 2) {
if (wFlag) {
// 第二个并行
item.x = x + 2
item.y = tempY
tempY = false
} else {
// 第一个并行行
item.x = x
item.y = y
tempY = y
wFlag = true
}
} else {
item.x = x
item.y = y
}
item.i = this.layoutConfig.index
y += item.h
this.layoutConfig.index += 1
}
this.layoutData = this.layoutData.concat(Resource)
this.historyLayout = JSON.parse(JSON.stringify(this.layoutData))
},

然后把资源池和页面数据分开,并且加上校验。

<div class="Main_border" v-if="layoutConfig.ToolVisible">
</div>
 .Main_border {
height: 75%;
width: 75%;
position: absolute;
box-sizing: border-box;
border: 1px solid #000000;
}

加上分割线,然后添加移动监听。

  // 监听组件移动结束位置
movedEvent(i, newX) {
const item = this.layoutData.find(t => t.i === i)
const itemW = item.w
if (newX + itemW <= 12) { // 放到线中 允许添加
console.log('放到线中 允许添加')
item.IsResource = false
this.historyLayout = JSON.parse(JSON.stringify(this.layoutData))
} else if (newX >= 12) { // 不在线中 允许添加
this.historyLayout = JSON.parse(JSON.stringify(this.layoutData))
item.IsResource = true
console.log('不在线中 允许添加')
} else { // 压线 禁止添加
this.layoutData = JSON.parse(JSON.stringify(this.historyLayout))
console.log('压线 禁止添加')
}
}

 

利用vue-gird-layout 制作可定制桌面 (二)的更多相关文章

  1. 利用vue-gird-layout 制作可定制桌面 (一)

    安装 vue-gird-layout https://github.com/jbaysolutions/vue-grid-layout 先跑一遍demo 运行起来. # install with np ...

  2. 使用vue全家桶制作博客网站

    前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用vue全家桶制作的博客网站 概述 该项目是基于vue全家桶(vue.vue-router.vuex.v ...

  3. 转载: 使用vue全家桶制作博客网站 HTML5 移动网站制作的好教程

    使用vue全家桶制作博客网站   前面的话 笔者在做一个完整的博客上线项目,包括前台.后台.后端接口和服务器配置.本文将详细介绍使用vue全家桶制作的博客网站 概述 该项目是基于vue全家桶(vue. ...

  4. 一步一步教你用 Vue.js + Vuex 制作专门收藏微信公众号的 app

    一步一步教你用 Vue.js + Vuex 制作专门收藏微信公众号的 app 转载 作者:jrainlau 链接:https://segmentfault.com/a/1190000005844155 ...

  5. 利用Vue.js实现拼图游戏

    之前写过一篇<基于Vue.js的表格分页组件>的文章,主要介绍了Vue组件的编写方法,有兴趣的可以访问这里进行阅读:http://www.cnblogs.com/luozhihao/p/5 ...

  6. 【百度地图API】如何利用自己的数据制作社交地图?只显示可视区域内的标注

    原文:[百度地图API]如何利用自己的数据制作社交地图?只显示可视区域内的标注 摘要:如果你自己的数据已经超过1万个,如何进行合理的显示?除了聚合marker外,还有一个办法.那就是,只显示可视区域内 ...

  7. C/S模式开发中如何利用WebBrowser控件制作导航窗体

    原文:C/S模式开发中如何利用WebBrowser控件制作导航窗体 转自: CSDN 相信不少同学们都做过MIS系统的开发,今天这里不讨论B/S模式开发的问题.来谈谈winform开发.用过市面上常见 ...

  8. 利用css+原生js制作简易钟表

    利用css+原生js制作简单的钟表.效果如下所示 实现该效果,分三大块:html.javascript.css html部分html部分比较简单,定义一个clock的div,内部有原点.时分秒针.日期 ...

  9. 利用U盘启动制作GHO镜像

    利用U盘启动制作GHO镜像 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. In a realproduction environment. 我们我们可能遇到频繁的安装系统,安装环境 ...

随机推荐

  1. 善用性能工具进行SQL整体优化

    SQL优化是一个复杂的工程,首先要讲究从整体到局部.今天我们首先学习关于数据库整体优化都有哪些性能工具,接着分析这些工具的特点,并结合案例进行探索,最后再进行总结和思考. 总体学习思路如下图所示: 都 ...

  2. 0301mysql数据库建表情况

    转自博客:http://blog.csdn.net/dreamcode/article/details/8557197 一. 表设计 库名.表名.字段名必须使用小写字母,“_”分割. 库名.表名.字段 ...

  3. 【c++版数据结构】之循环单链表的实现(带头结点以及尾节点)

    所实现的循环单链表的结构例如以下图所看到的: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill ...

  4. Java基础:异常捕获顺序

    转载请注明出处:jiq•钦's technical Blog public voidtestException(){ int a[] = {1,2,3};int q = 0; try{ for(int ...

  5. Windows下搭建ffmpeg+VS2008开发环境详细教程【转】

    本文转载自:http://www.voidcn.com/article/p-vxdntdgc-bkq.html 由于个人是从事音视频开发相关的工作,所以也把自己的一些过程写下来,方便大家以及自己查看, ...

  6. 深度学习将会变革NLP中的中文分词——TODO 待好好细看

    见:https://www.leiphone.com/news/201608/IWvc75oJglAIsDvJ.html TODO 待好好细看

  7. C# Log4Net简单使用方法

    log4net库是Apache log4j框架在Microsoft .NET平台的实现,是一个帮助程序员将日志信息输出到各种目标(控制台.文件.数据库等)的工具. 使用log4net,一个很明显的好处 ...

  8. 康少带你玩转JavaScript

    目录 1.JavaScript简述 2.JavaScript引入方式 3.JavaScript语法基础 4.JavaScript数据类型 5.运算符 6.流程控制 7.函数 8.内置对象和方法 1.J ...

  9. Linux Shell Scripting Cookbook 读书笔记 7

    ping, du, ps, kill, 收集系统信息 判断网络中哪些主机是活动主机 #!/bin/bash for ip in 10.215.70.{1..255}; do ( ping $ip -c ...

  10. python print 显示不同的字体

    显示格式: print('\033[显示方式;字体颜色;背景色m.....\033[0m') ------------------------------- 显示方式 | 效果 ----------- ...