好玩的调度技术-场景编辑器

好玩的调度技术-场景编辑器

文章目录


前言

这两天写前端写上瘾了,顺手做了个好玩的东西,好玩系列也好久没更新,正好作为素材写一篇文章,我真的觉得蛮好玩的,如果有创造力可以创造出所有的东西

一、演示

这玩意真的太简单了,简单到我只用了半天多点的时间就做好了,所以也不知道写点什么,直接看演示把。

场景编辑器

一、代码

昨晚有个人找我说,你说的很简单,我根本想象不到是怎么做的,我突然意识到一个问题,我认为很简单的东西你们可能觉得很难,所以我把代码贴出来你们直接参考把。

html 复制代码
<div class="cardDragAndDrop " style="display: none;">
    <div draggable="true" class="ItemDragAndDrop ">蛇形线</div>
    <div  draggable="true" class="ItemDragAndDrop ">矩形</div>
    <div  draggable="true" class="ItemDragAndDrop ">圆形</div>
    <div  draggable="true" class="ItemDragAndDrop ">文本</div>
    <div  draggable="true" class="ItemDragAndDrop ">背景</div>
    <div  draggable="true" class="ItemDragAndDrop ">容器</div>
  </div>
css 复制代码
   .cardDragAndDrop {
  max-width: fit-content;
  border-radius: 15px;
  display: flex;
  flex-direction: column;
  align-content: center;
  justify-content: center;
  gap: 1rem;
  backdrop-filter: blur(15px);
  box-shadow: inset 0 0 20px rgba(255, 255, 255, 0.192),
    inset 0 0 5px rgba(255, 255, 255, 0.274), 0 5px 5px rgba(0, 0, 0, 0.164);
  transition: 0.5s;
  position: absolute;
      top: 40px;
      left: 10px;
      z-index: 999;
}
.ItemDragAndDrop{
  margin: 10px;
  padding: 10px 5px;
  color: #ffffff;
  text-align: center;
}
javascript 复制代码
function loadModel() {
  let event = allStage.localView.getMouseXY();

  if (DragAndDropInnerText == '蛇形线') {
    const link = new Link(null, { x: event.x, y: event.y }, { x: event.x + 5000, y: event.y });
    allScene.addChild(link);
    toTube(link, TUBE_Diameter, '#E0FFFF');
  }
  if (DragAndDropInnerText == '矩形') {
    const toNode = new Node('To', event.x, event.y, 1800, 1800);

    toNode.userData = { isEdit: true };
    toNode.css({
      fillStyle: '#167cff'
    });
    allScene.addChild(toNode);
  }
  if (DragAndDropInnerText == '圆形') {
    const node = new CircleNode(null, event.x, event.y);
    node.setRadius(1400);
    node.css({
      'strokeStyle': '#E1E1E1',
      'fillStyle': '#167cff'
    });
    node.userData = { isEdit: true };
    allScene.addChild(node);
  }
  if (DragAndDropInnerText == '文本') {
    let textNode = new TextNode('添加你自己的文字', event.x, event.y);
    textNode.css({
      font: 'italic 500px sans-serif',
      padding: 10,
      color: '#16fffc',
    });
    textNode.zIndex = 10;
    textNode.userData = { isEdit: true };
    allScene.addChild(textNode);
  }
  if (DragAndDropInnerText == '背景') {
    let imgNode = new Node(null, event.x, event.y, 26000, 6400);
    // png、jpg、jpeg 、bmp、svg、gif、base64字符串 或者一个cavnas
    imgNode.setImage('../Map/images/chanxian.png');
    imgNode.userData = { isEdit: true };
    imgNode.zIndex = -100;
    allScene.addChild(imgNode);
  }
  if (DragAndDropInnerText == '容器') {
    allStage.styleSystem.defClass('.group', {
      borderColor: '#F0F0F0',
      borderRadius: 50,
      borderWidth: 10,
      padding: 80,
      backgroundColor: 'rgba(128,128,128,0.2)',
      lineWidth: 10,
      strokeStyle: 'gray',
      fontSize: '12px',
    });
    allStage.styleSystem.defClass('.focus', {
      borderWidth: 3,
      borderColor: 'yellow'
    });
    const group1 = new Node('Group1', event.x, event.y, 2000, 3000);
    group1.dropAllowed = true; //since 2.4.0
    group1.userData = { isEdit: true };
    group1.addClass('.group');
    allScene.addChild(group1);

  }

}

总结

目前就先这样如果后面有时间了就在优化一下。

好玩系列

好玩的调度技术
好玩的调度技术-录制和回放
调度的多维空间技术
好玩的调度技术-生成式三维技术
好玩的调度技术-场景编辑器

相关推荐
小周不摆烂37 分钟前
探索JavaScript前端开发:开启交互之门的神奇钥匙(二)
javascript
匹马夕阳2 小时前
Vue 3中导航守卫(Navigation Guard)结合Axios实现token认证机制
前端·javascript·vue.js
我想学LINUX3 小时前
【2024年华为OD机试】 (A卷,100分)- 微服务的集成测试(JavaScript&Java & Python&C/C++)
java·c语言·javascript·python·华为od·微服务·集成测试
深度混淆3 小时前
C#,入门教程(04)——Visual Studio 2022 数据编程实例:随机数与组合
开发语言·c#
screct_demo3 小时前
詳細講一下在RN(ReactNative)中,6個比較常用的組件以及詳細的用法
javascript·react native·react.js
chance_664 小时前
C# ASP.NET MVC项目内使用ApiController
c#
钢铁男儿8 小时前
C# 委托和事件(事件)
开发语言·c#
喜-喜9 小时前
C# HTTP/HTTPS 请求测试小工具
开发语言·http·c#
CodeClimb9 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
susan花雨10 小时前
winfrom项目,引用EPPlus.dll实现将DataTable 中的数据保存到Excel文件
c#