当前位置:首页 > 科技  > 软件

图形编辑器开发:属性显示与格式转换

来源: 责编: 时间:2023-10-10 18:30:15 379观看
导读大家好,我是前端西瓜哥。今天简单讲讲图形编辑器的显示属性值时,会遇到的格式转换问题。编辑器 github 地址:https://github.com/F-star/suika线上体验:https://blog.fstars.wang/app/suika/单位转换图形编辑器中的数据,通

aX428资讯网——每日最新资讯28at.com

大家好,我是前端西瓜哥。aX428资讯网——每日最新资讯28at.com

今天简单讲讲图形编辑器的显示属性值时,会遇到的格式转换问题。aX428资讯网——每日最新资讯28at.com

编辑器 github 地址:aX428资讯网——每日最新资讯28at.com

https://github.com/F-star/suikaaX428资讯网——每日最新资讯28at.com

线上体验:aX428资讯网——每日最新资讯28at.com

https://blog.fstars.wang/app/suika/aX428资讯网——每日最新资讯28at.com

单位转换

图形编辑器中的数据,通过 UI 层进行展示时,可能不会直接将数据源的原始值展示出来,而是会额外进行单位的转换,变成另一种格式。aX428资讯网——每日最新资讯28at.com

这里以简单而常见的弧度为例。aX428资讯网——每日最新资讯28at.com

图形的旋转在数据源中,会用弧度(radian)表示。因为弧度更适合进行数学计算,且很多 API 比如 Math.sin(x) 都需要你提供弧度。aX428资讯网——每日最新资讯28at.com

但在面向用户的 UI 层,我们通常会提供角度(degree),因为日常生活中人们更常使用,它更直观。aX428资讯网——每日最新资讯28at.com

aX428资讯网——每日最新资讯28at.com

但数据中我们还是要保存弧度的。aX428资讯网——每日最新资讯28at.com

转换算法

我们需要明确的点是:aX428资讯网——每日最新资讯28at.com

  • 数据源要用唯一格式,这样可以确保运算逻辑的一致性。比如旋转不建议即可以保存弧度,也可以保存角度。另外,尽量选择精度高的。
  • 如果有显示另一种格式的需求,你需要实现源格式转其他格式算法。比如弧度转角度显示到用户界面上;
  • 如果有修改其他格式然后修改源数据的需求,你需要实现其他格式转源数据的算法。
/** * 弧度转角度 */export function radian2Degree(radian: number) {  return (radian * 180) / Math.PI;}/** * 角度转弧度 */export function degree2Radian(degree: number) {  return (degree * Math.PI) / 180;}

需要注意,格式的转换通常会丢失一些精度的。aX428资讯网——每日最新资讯28at.com

这里弧度和角度的转换就是一个例子。aX428资讯网——每日最新资讯28at.com

圆周率是一个无限不循环小数,计算的时候,会对其丢掉一些精度再参与计算,最后的结果自然也丢失了精度。aX428资讯网——每日最新资讯28at.com

这里给一下 UI 层实现思路,以 React 组件为例,核心实现大致如下:aX428资讯网——每日最新资讯28at.com

const [radian, setRadian] = useState(0);useEffect(() => {  rect.onRotationChange((val) => {    // 从编辑器内核同步过来的状态    setRadian(val);  })});<NumberInput  label="旋转"  value={remainDecimal(radian2Degree(radian))}  onBlur={(e) => {    const degree =  e.target.value;    const radian = normalizeRadian(degree2Radian(degree));    rect.setRotation(radian);  }}/>

题外话,UI 层会直接更新编辑器中的状态,成功更新后通过事件订阅通知回 UI 层,同步状态。aX428资讯网——每日最新资讯28at.com

弧度还是比较简单的场景。aX428资讯网——每日最新资讯28at.com

像是复杂一点的属性,比如颜色值,通常要实现一个比较完善的拾色器,要支持多种格式,如RGBA、HSL、CMYK 等等,要实现的方法就更复杂也更多。aX428资讯网——每日最新资讯28at.com

降低显示精度

UI 层不会显示全精度,意义不大。aX428资讯网——每日最新资讯28at.com

比如 x 坐标的真实值是 52.24621202458749,但用户是不希望看到这么长的值的,他只是想知道这个点大概在什么位置。aX428资讯网——每日最新资讯28at.com

所以我们最好做一个四舍五入,比如保留有限的有效位显示为 52.25。aX428资讯网——每日最新资讯28at.com

需要注意的是,修改属性值时不用做降低精度再转为源格式,我们的数据源精度越高越好。aX428资讯网——每日最新资讯28at.com

只在显示时做降低精度。aX428资讯网——每日最新资讯28at.com

检验和补正

因为涉及到用户修改属性值,所以我们需要对用户的输入值进行处理,尝试得到一个合法值去修改属性。aX428资讯网——每日最新资讯28at.com

简单的做法是 严格校验,比如对于数字类型,出现非数字字符,就直接认为非法值。aX428资讯网——每日最新资讯28at.com

稍微好一点的是从字符串中提取符合格式的部分。aX428资讯网——每日最新资讯28at.com

更人性化的是猜测用户想干嘛,做补全。比如对于 hex 格式的颜色值,用户只输入一个 3,我们给他补全为 33333。aX428资讯网——每日最新资讯28at.com

aX428资讯网——每日最新资讯28at.com

最后

画一张图总结一下。aX428资讯网——每日最新资讯28at.com

aX428资讯网——每日最新资讯28at.com

展示层可能和数据源的格式不同,显示时要做格式转换,然后降低精度,比如对于数字通常保留 1 到 5 个小数位就够了。aX428资讯网——每日最新资讯28at.com

修改非源格式要做校验和补正,然后转回数据源格式保存起来。保存成功后再把新值传递到 UI 层。aX428资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-12675-0.html图形编辑器开发:属性显示与格式转换

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 30 个有用的 JavaScript 代码片段(下)

下一篇: veImageX 演进之路:Web 图片加载提速50%

标签:
  • 热门焦点
  • Find N3入网:最高支持16+1TB

    OPPO将于近期登场的Find N3折叠屏目前已经正式入网,型号为PHN110。本次Find N3在外观方面相比前两代有很大的变化,不再是小号的横向折叠屏,而是跟别的厂商一样采用了较为常见的
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • 如何正确使用:Has和:Nth-Last-Child

    我们可以用CSS检查,以了解一组元素的数量是否小于或等于一个数字。例如,一个拥有三个或更多子项的grid。你可能会想,为什么需要这样做呢?在某些情况下,一个组件或一个布局可能会
  • 得物效率前端微应用推进过程与思考

    一、背景效率工程随着业务的发展,组织规模的扩大,越来越多的企业开始意识到协作效率对于企业团队的重要性,甚至是决定其在某个行业竞争中突围的关键,是企业长久生存的根本。得物
  • 猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对&ldquo;势&rdquo;的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • 华为Mate 60保护壳曝光:硕大后置相机模组 凸起程度有惊喜

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • 华为Mate60系列模具曝光:采用硕大圆形后置相机模组+拼接配色方案

    据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将迎来更新,有望在9-10月份带来全新的华为Mate60
  • Windows 11发布,微软一改往常对老机型开放的态度

    距离 Windows 11 发布已经过去一周,在过去一周里,很多数码爱好者围绕其对 Android 应用的支持、对老机型的升级问题展开了激烈讨论。与以往不同的是,在这次大
  • onebot M24巧系列一体机采用轻薄机身设计,现已在各平台开售

    onebot M24 巧系列一体机目前已在线上线下各平台同步开售。onebot M24 巧系列采用一体化轻薄机身设计,最薄处为 10.15mm,拥有宝石红、午夜蓝、石墨绿、雅致
Top