首页 >>  正文

绕一点旋转作图方法

来源:baiyundou.net   日期:2024-08-31

克雷西 发自 凹非寺

量子位 | 公众号 QbitAI

只用五个字符,就能完成一幅像素画的绘制了。

这是一种新的绘图语言,一共支持8种颜色,画幅可达256*256。

它包含了“CFR[]”这五个符号,因此名字也就叫CFR[]了,主打的就是一个直观。

而且CFR[]免费开源,无需部署安装,在线就能体验。

虽然只有5个符号,但是它能绘制出的图像可并不简单,比如作者展示的这个DEMO:

CFR[]推出之后,在Reddit和The Hacker News上都引发了热烈讨论,网友们也纷纷晒出了自己的作品:

网友看了这些展示以后,不由得评价说真的是泰裤辣~

那么,这五个符号各自代表了什么含义,又该如何使用呢?

五个字符就能绘图

前面已经说到,这种绘图语言包含了“C”“F”“R”“[”和“]”这五个字符。

直观的不只是名字,这几个符号本身也是直观的英文首字母,它们的含义和用法是这样的:

C代表color,用来切换颜色,支持的颜色一共有八种,依次为黑、蓝、绿、蓝绿(Cyan)、红、品红(Magenta)、黄和白。

△最左边发灰的是白色

如果不输入C指令则默认为白色(画布为黑色),其他颜色则输入相应数量的C。

F则代表Forward,每输入一个F指令都会向前前进(绘制)出一个点(初始方向向上)。

R则是Rotate的首字母,也就是旋转,每一个R指令会使前进方向顺时针旋转45度。

有了上面这三个命令,就已经可以拿来画一些简单的图了。

不过这个工具一次性最多输入256个字符,所以只靠这些基本指令还没办法画得太复杂。

没关系,我们还有两个符号——“[”和“]”。

这两个符号是成对使用的,用来表示循环结构。

假如我们要画一条长度为32的线,直接输入32个F显然太麻烦了。

利用循环结构,我们就可以把它化简成[[[FFFF]]]。

在这样一个洋葱结构中,红色部分的FFFF会因为绿色括号的存在被执行两次。

同理,蓝色括号是把整个绿色括号执行两次,黑色则是执行两次蓝色,最终就画出了长度为2×[2×(2×4)]=32的线。

为了更好地理解循环的执行方式,我们来对比看看这两个命令:

先说结论,它们绘制出的效果分别是这样的:

还是同样的道理,绿色括号中的内容,即第一个指令中CF(这部分的一串F将用一个字母代替)首先重复一次形成最内部的循环体(CFCF),然后再经两次循环得到[(CFCF)(CFCF)]和{[(CFCF)(CFCF)]},其间颜色一共发生了8次变化。

而第二组命令中,F首先被绿色括号变成(FF),这样蓝色括号中的内容就是C(FF),重复后得到[C(FF)C(FF)],最终被黑色括号变成{[C(FF)C(FF)][C(FF)C(FF)]},一共涉及四次颜色变化,且每一个色条的长度都是第一种命令的两倍。

理解了这样的循环方式之后,我们就可以绘制各种复杂的图形了,比如作者展示的这组条带(相对于CFR的像素绘图方式,它只是看上去简单):

它由上图中所示的命令绘制而成,如果进行一下拆解的话是酱婶儿的(小编真的已经很尽力了):

如果展开则是这样的形式:{256个F-RRFRRRRRRR}循环32次然后加C作为新的循环体循环8次。

至于更复杂的图案,可能就需要丰富的想象力和逻辑运算能力了。

不过我们还试了试把这种新语言教给ChatGPT,前面的对话大概是给它介绍规则以及试着画了一个蓝色正方形。

ChatGPT理解了CFR[]的一部分规则,不过对于循环,它似乎还没理解透彻。

下图中ChatGPT给出的指令虽然是正确的,但还不是最简形式。

又经历了一轮“拉锯”之后,ChatGPT成功写出了最简形式的正方形指令。

需要说明的是,CFR[]绘制的图像必须是连续的,如果有断点则无法完成想要的效果。

不过,ChatGPT只能画一些简单图形,作者和网友们展示的案例还是有些困难的。

那么,CFR[]又是如何实现的呢?

“画板后藏着一只乌龟”

作者介绍,他是受到了教育编程语言Logo编程语言P′′的启发。

这里的Logo不是我们想的商标,而是希腊语中的“文字”或“思考”、“想法”。

这是MIT在LISP的基础之上专门为儿童开发的一种模块化语言,具有丰富的绘图功能。

而它的Web界面,则是利用Canvas和JavaScript实现的。

作者说,在界面中256*256的画布背后“隐藏着一只乌龟”,它包含了位置、颜色和方向三个参数。

值得一提的是,Logo语言的图表也是一只小乌龟。

这个乌龟的初始位置是画布正中,方向向上,颜色为白色。

当收到用户的指令时,这只“乌龟”就会按照用户要求的方向和距离移动,并留下相应颜色的痕迹。

想要体验一下的朋友,传送门放在下方了~

传送门:

https://susam.net/cfr.html

GitHub项目页:

https://github.com/susam/cfr

— 完 —

量子位 QbitAI · 头条号签约

","gnid":"936d94b6aa3bdc32a","img_data":[{"flag":2,"img":[{"desc":"","height":"428","title":"","url":"https://p0.ssl.img.360kuai.com/t01bd4b987aafb14dab.jpg","width":"1080"},{"desc":"","height":"1063","title":"","url":"https://p0.ssl.img.360kuai.com/t01ccfeb53090175551.jpg","width":"1080"},{"desc":"","height":"174","title":"","url":"https://p0.ssl.img.360kuai.com/t0135b5cb3d300bc442.jpg","width":"1080"},{"desc":"","height":"1257","title":"","url":"https://p0.ssl.img.360kuai.com/t01997675e08a3b16a9.jpg","width":"1080"},{"desc":"","height":"146","title":"","url":"https://p0.ssl.img.360kuai.com/t01f31c51742fccb141.jpg","width":"1080"},{"desc":"","height":"1066","title":"","url":"https://p0.ssl.img.360kuai.com/t01d254ec026c69cbdd.jpg","width":"1312"},{"desc":"","height":"782","s_url":"https://p0.ssl.img.360kuai.com/t014304de22c5a96312_1.gif","title":"","url":"https://p0.ssl.img.360kuai.com/t014304de22c5a96312.gif","width":"640"},{"desc":"","height":"782","s_url":"https://p0.ssl.img.360kuai.com/t012f6ca4e0b4912f30_1.gif","title":"","url":"https://p0.ssl.img.360kuai.com/t012f6ca4e0b4912f30.gif","width":"640"},{"desc":"","height":"782","s_url":"https://p0.ssl.img.360kuai.com/t01bf1a476343f6a6f4_1.gif","title":"","url":"https://p0.ssl.img.360kuai.com/t01bf1a476343f6a6f4.gif","width":"640"},{"desc":"","height":"233","title":"","url":"https://p0.ssl.img.360kuai.com/t01834312be345a9e20.jpg","width":"1005"},{"desc":"","height":"351","title":"","url":"https://p0.ssl.img.360kuai.com/t01523587ff36d9077b.jpg","width":"823"},{"desc":"","height":"94","title":"","url":"https://p0.ssl.img.360kuai.com/t015fed68a7aee460e3.jpg","width":"379"},{"desc":"","height":"810","title":"","url":"https://p0.ssl.img.360kuai.com/t01662c33fc142272aa.jpg","width":"1080"},{"desc":"","height":"284","title":"","url":"https://p0.ssl.img.360kuai.com/t01296456606db3f7c5.jpg","width":"906"},{"desc":"","height":"905","title":"","url":"https://p0.ssl.img.360kuai.com/t01073377efc640c459.jpg","width":"1080"},{"desc":"","height":"538","title":"","url":"https://p0.ssl.img.360kuai.com/t01211b7bd80403e8f3.jpg","width":"1080"},{"desc":"","height":"440","title":"","url":"https://p0.ssl.img.360kuai.com/t011685d31f046ece3a.jpg","width":"1080"},{"desc":"","height":"920","title":"","url":"https://p0.ssl.img.360kuai.com/t01060dba77a4f223a7.jpg","width":"1080"},{"desc":"","height":"436","title":"","url":"https://p0.ssl.img.360kuai.com/t0179456b4ed5a17008.jpg","width":"1080"}]}],"original":0,"pat":"art_src_3,fts0,sts0","powerby":"pika","pub_time":1698039660000,"pure":"","rawurl":"http://zm.news.so.com/d75da7eb3b5974c53d3f953695ee36a6","redirect":0,"rptid":"f09eaad3f84d5099","rss_ext":[],"s":"t","src":"量子位","tag":[{"clk":"ktechnology_1:乌龟","k":"乌龟","u":""}],"title":"仅5个字符的新绘图语言火了,ChatGPT都学会了

方诸鲍4316将下面的图案绕点O顺时针方向旋转90度,作出旋转后的图形. -
潘通肃13492418261 ______[答案] 所画图形如下所示:

方诸鲍4316画出将下面图形绕点O逆时针方向旋转90°后的图形. -
潘通肃13492418261 ______[答案] 作图如下:

方诸鲍4316画出绕点“O”顺时针旋转90度后的图形.画出绕点“A”逆时针旋转90度后的图形. -
潘通肃13492418261 ______[答案] 画出绕点“O”顺时针旋转90度后的图形.画出绕点“A”逆时针旋转90度后的图形.

方诸鲍4316将图A绕点O顺时针旋转90°,180°,270°. -
潘通肃13492418261 ______[答案] 作图如下:

方诸鲍4316画出三角形绕“O”点顺时针旋转90°后的图形. -
潘通肃13492418261 ______[答案] 画出三角形绕“O”点顺时针旋转90°后的图形(下图中三角形A′O′B′).

方诸鲍4316按要求画图.分别画出左边绕点O顺时针旋转90°和逆时针旋转90°后的图形. -
潘通肃13492418261 ______[答案] 分别画出左边绕点O顺时针旋转90°和逆时针旋转90°后的图形:

方诸鲍4316画出下面图形绕点O逆时针旋转90°和180°后的图形. -
潘通肃13492418261 ______[答案]

方诸鲍4316旋转的画图步骤如题,急啊!~~~~~~~~~~ -
潘通肃13492418261 ______[答案] 方法是正确的,但作两次垂线有点麻烦.可以用下面的作法,简单一点: 1、以O为圆心,适当长为半径作圆O,与直线L交于A、B,连接OA、OB 2、作圆心角∠AOC=∠BOD=α (可以有顺时针和逆时针两种位置,均符合题意.作出C后可以在圆O上取...

方诸鲍4316把图形A绕点O顺时针旋转90度得到图形B. -
潘通肃13492418261 ______[答案] 根据分析作图如下:

方诸鲍4316将如图所示方格中的阴影部分的图形绕着点O旋转90°,画出旋转后的图形. -
潘通肃13492418261 ______[答案]

(编辑:自媒体)
关于我们 | 客户服务 | 服务条款 | 联系我们 | 免责声明 | 网站地图 @ 白云都 2024