gojs 将图片作为画笔时的序列化储存

2023-12-19 12:38

本文主要是介绍gojs 将图片作为画笔时的序列化储存,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在项目开发中遇到问题,将轨道图片进行拉长,达到长轨道的目的。

但是动态渲染出轨道显然是麻烦的事情。因此通过查找api,找到了一种将图片作为画笔的方法。

链接为点击打开链接  中的:Pattern Brushes

但是此方法有弊端,官方人员也说了,Brushes are automatically converted into JSON by the Model.toJson and fromJson methods. Of course, there is a limit to what kinds of brushes that can be faithfully converted -- it cannot handle patterns.【点击打开链接】

因此需要有一种方法将用图片当成笔刷的方法并且可以保存json。

以下是我进行的方法。

首先需要进行初始化一个图片笔刷:

        var img = new Image();img.src = 'track.png'; var patternBrush = objGo(go.Brush, "Pattern", { pattern: img});


然后初始化一个图片笔刷模板

        var trackPenTemplate =objGo(go.Node, "Spot",{resizable: true,resizeObjectName: 'SHAPE',locationSpot: new go.Spot(0, 0, 25, 25) //控制鼠标拖拽过来后的位置},new go.Binding("position", "pos", go.Point.parse).makeTwoWay(go.Point.stringify), objGo(go.Shape, "Rectangle",{ name: 'SHAPE', strokeWidth: 0,stroke: null,width:30,height:30,minSize: new go.Size(30, 30),},new go.Binding("desiredSize", "size", go.Size.parse).makeTwoWay(go.Size.stringify),new go.Binding("fill","color",function(){return patternBrush}) ));
注意红色字体中重新定义了填充,与官网不同的是我不考虑fill中具体的填充值是什么,而是如果节点用了此模板,则直接返回填充的笔刷。因此在json中,fill对应的color属性填任何值都没关系。因为直接return 了笔刷。

接着,进行逻辑处理:首先是初始化节点---保存节点---读取节点。

如何初始化这个节点?我的方法是:首先定义一个工具画布,将此节点直接放置于工具画布上。因此,他就有了对应的属性映射关系:

myPalette.model = new go.GraphLinksModel([ {text: "货架",text2:"0", color: "pink", size: "50 50"    ,category:"shape" },{category:"four","size":"100 50","text":"货场"},{text: "生产区",category:"sec" },{category:"pic",color:"123"},{category:"pic2",color:"123"}]);

此时当将这个节点拖拽至主画布时,对应的节点也将成为color:123的属性。


此时在将图片拉伸即可动态填充。直接将此json存至数据库即可。


保存的逻辑处理好之后,就完成了。下次直接从数据库都时,初始化方法将不考虑color中的具体值,而直接返回使用此模板的画笔。

这篇关于gojs 将图片作为画笔时的序列化储存的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/512183

相关文章

使用 Python 和 LabelMe 实现图片验证码的自动标注功能

《使用Python和LabelMe实现图片验证码的自动标注功能》文章介绍了如何使用Python和LabelMe自动标注图片验证码,主要步骤包括图像预处理、OCR识别和生成标注文件,通过结合Pa... 目录使用 python 和 LabelMe 实现图片验证码的自动标注环境准备必备工具安装依赖实现自动标注核心

Java中JSON字符串反序列化(动态泛型)

《Java中JSON字符串反序列化(动态泛型)》文章讨论了在定时任务中使用反射调用目标对象时处理动态参数的问题,通过将方法参数存储为JSON字符串并进行反序列化,可以实现动态调用,然而,这种方式容易导... 需求:定时任务扫描,反射调用目标对象,但是,方法的传参不是固定的。方案一:将方法参数存成jsON字

Java操作xls替换文本或图片的功能实现

《Java操作xls替换文本或图片的功能实现》这篇文章主要给大家介绍了关于Java操作xls替换文本或图片功能实现的相关资料,文中通过示例代码讲解了文件上传、文件处理和Excel文件生成,需要的朋友可... 目录准备xls模板文件:template.xls准备需要替换的图片和数据功能实现包声明与导入类声明与

基于C#实现将图片转换为PDF文档

《基于C#实现将图片转换为PDF文档》将图片(JPG、PNG)转换为PDF文件可以帮助我们更好地保存和分享图片,所以本文将介绍如何使用C#将JPG/PNG图片转换为PDF文档,需要的可以参考下... 目录介绍C# 将单张图片转换为PDF文档C# 将多张图片转换到一个PDF文档介绍将图片(JPG、PNG)转

Qt QWidget实现图片旋转动画

《QtQWidget实现图片旋转动画》这篇文章主要为大家详细介绍了如何使用了Qt和QWidget实现图片旋转动画效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、效果展示二、源码分享本例程通过QGraphicsView实现svg格式图片旋转。.hpjavascript

使用opencv优化图片(画面变清晰)

文章目录 需求影响照片清晰度的因素 实现降噪测试代码 锐化空间锐化Unsharp Masking频率域锐化对比测试 对比度增强常用算法对比测试 需求 对图像进行优化,使其看起来更清晰,同时保持尺寸不变,通常涉及到图像处理技术如锐化、降噪、对比度增强等 影响照片清晰度的因素 影响照片清晰度的因素有很多,主要可以从以下几个方面来分析 1. 拍摄设备 相机传感器:相机传

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

Spring MVC 图片上传

引入需要的包 <dependency><groupId>commons-logging</groupId><artifactId>commons-logging</artifactId><version>1.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-

Prompt - 将图片的表格转换成Markdown

Prompt - 将图片的表格转换成Markdown 0. 引言1. 提示词2. 原始版本 0. 引言 最近尝试将图片中的表格转换成Markdown格式,需要不断条件和优化提示词。记录一下调整好的提示词,以后在继续优化迭代。 1. 提示词 英文版本: You are an AI assistant tasked with extracting the content of

研究人员在RSA大会上演示利用恶意JPEG图片入侵企业内网

安全研究人员Marcus Murray在正在旧金山举行的RSA大会上公布了一种利用恶意JPEG图片入侵企业网络内部Windows服务器的新方法。  攻击流程及漏洞分析 最近,安全专家兼渗透测试员Marcus Murray发现了一种利用恶意JPEG图片来攻击Windows服务器的新方法,利用该方法还可以在目标网络中进行特权提升。几天前,在旧金山举行的RSA大会上,该Marcus现场展示了攻击流程,