Board logo

标题: 几何画板下的编程思考:javascript [打印本页]

作者: xklppp    时间: 2014-10-14 13:06     标题: 几何画板下的编程思考:javascript

这个题目有点大,我没那么深的造诣,只是想说明我的看法:几何画板作为很多算法的形象演练,是个绝妙的工具。
    javascript 比起其他的算法语言 basic,c,c++,java... 以及各式各样的可视化编程语言 vc,vb,c#,F#...来说,使用起来更加轻松随意,其最终效果有过之而无不及。
    尽管 javascript 也有着庞大的支撑系统和繁复的应用环境,但我们将尽可能的避开那些繁文缛节,我们的目的是娱乐,开心就好。
    对于 html+css+javascript 里面的一些细枝末节和扩展,网上俯拾皆是,为了精简,我们这里的讨论将不以语言为中心,程序用到哪我们就讨论到哪。
    我们这就开始吧:(大家学习愉快!!!)
New.gif
htm0000.rar (481 Bytes)

图片附件: New.gif (2014-10-14 19:14, 12.25 KB) / 下载次数 2990
http://forums.netpad.net.cn/attachment.php?aid=22555&k=2653a17202d29fb91e5a181f8ca4827a&t=1765167857&sid=yYLc25



附件: htm0000.rar (2014-10-14 13:06, 481 Bytes) / 下载次数 4452
http://forums.netpad.net.cn/attachment.php?aid=22556&k=d85d8a92b3f88c4e5c0a9f4a51694631&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-14 13:59

New.gif
htm0001.rar (938 Bytes)

图片附件: New.gif (2014-10-14 19:15, 22.27 KB) / 下载次数 3052
http://forums.netpad.net.cn/attachment.php?aid=22559&k=ee8de8a5aa2d05accf78f85595dcdd92&t=1765167857&sid=yYLc25



附件: htm0001.rar (2014-10-14 14:05, 938 Bytes) / 下载次数 4286
http://forums.netpad.net.cn/attachment.php?aid=22560&k=e155384bde5d99ad8c390cf875282026&t=1765167857&sid=yYLc25
作者: mjj_ljh    时间: 2014-10-14 16:54

我的脑细胞已经萎缩了。根本就跟不上大家的节奏,试着跟xklppp老师从头来一次。
作者: xklppp    时间: 2014-10-14 18:04

New.gif
htm0002.rar (888 Bytes)

图片附件: New.gif (2014-10-14 19:16, 33.13 KB) / 下载次数 3118
http://forums.netpad.net.cn/attachment.php?aid=22563&k=aee1af11ba3c2b26adf2e04f5ed4feea&t=1765167857&sid=yYLc25



附件: htm0002.rar (2014-10-14 18:04, 888 Bytes) / 下载次数 4524
http://forums.netpad.net.cn/attachment.php?aid=22564&k=ae4c7e9ba7d06d93122772f8382985da&t=1765167857&sid=yYLc25
作者: inRm    时间: 2014-10-14 19:18

大赞。
作者: lnszdzg    时间: 2014-10-14 20:27

但愿能跟上xklppp老师的步伐
作者: lnszdzg    时间: 2014-10-14 20:32

但愿能跟上xklppp老师的步伐
作者: xklppp    时间: 2014-10-14 22:14

New.gif
htm0003.rar (756 Bytes)

附件: htm0003.rar (2014-10-14 22:14, 756 Bytes) / 下载次数 4383
http://forums.netpad.net.cn/attachment.php?aid=22566&k=dee840d68b41a47cb961ff559af798a7&t=1765167857&sid=yYLc25

图片附件: New.gif (2014-10-16 09:14, 16.23 KB) / 下载次数 3098
http://forums.netpad.net.cn/attachment.php?aid=22568&k=1ea559cb562909fcc03ad30b75798997&t=1765167857&sid=yYLc25


作者: xklppp    时间: 2014-10-15 00:01

New.gif
htm0004.rar (1016 Bytes)

图片附件: New.gif (2014-10-16 09:17, 16.02 KB) / 下载次数 3091
http://forums.netpad.net.cn/attachment.php?aid=22569&k=ad39d237ed6e9641750a1957bb4f7f9d&t=1765167857&sid=yYLc25



附件: htm0004.rar (2014-10-15 00:01, 1016 Bytes) / 下载次数 4283
http://forums.netpad.net.cn/attachment.php?aid=22570&k=b3677ee1eb0bd432abd4a7ca10150f81&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-15 01:29

New.gif
    代码没有任何问题,思维惯性却让我们诧异:20+30 怎会等于 2030 呢?会的,程序的实际过程是:"20"+"30"="2030"。因为在放置 input 元素时,numA、numB 的 type 属性设置为 text,意为文本。为什么不设置为 type=number 呢?可以的,不过只有在 html5 中才行,当然还有其他的一些问题,这里不展开了。
    改写 showMess 函数:

    function showMess()
    {
        var a=numA.value;
        var b=numB.value;
        var c=a-b;
        var d=a*b;
        var e=a/b;
        a=parsInt(numA.value);
        b=parsInt(numB.value);
        var f=a+b;
        messBox.innerText="A-B="+c+"\n"+
                          "A*B="+d+"\n"+
                          "A/B="+e+"\n"+
                          "A+B="+f;
    }

    其中 parseInt 为 javascript 的内置方法(method 实际上就是函数),将文本转换为整型数值,与之相应的是 parseFloat 方法,将文本转换为浮点型数值。
    我们会发现,无论我们在两个输入框中输入什么内容,输出窗口是没有反应的,原因是 showMess 函数只是在浏览器打开网页后运行一次且仅一次。为此,我们需要在右边的窗口中增加一个输入元素:

    <input type=button value=刷新 onclick=showMess()>

    onclick 为单击鼠标时触发的事件。
    编程就是这样,刚解决了一个小问题,却又冒出来一堆的大问题。
htm0005.rar (462 Bytes)

图片附件: New.gif (2014-10-16 09:17, 3.73 KB) / 下载次数 3084
http://forums.netpad.net.cn/attachment.php?aid=22571&k=279b06b7a611130c92ff3addfe9c31e5&t=1765167857&sid=yYLc25



附件: htm0005.rar (2014-10-15 01:29, 462 Bytes) / 下载次数 4349
http://forums.netpad.net.cn/attachment.php?aid=22572&k=1e38ea538f870890e5f246396cd83f2d&t=1765167857&sid=yYLc25
作者: changxde    时间: 2014-10-15 10:00

javascript 中的  “-,*,/” 都是按数值进行,“+”  就按字符处理,不可想象。
作者: xklppp    时间: 2014-10-15 13:41

javascript 是一种宽松类型的语言。宽松类型意味着设计者不必显式地定义变量的数据类型。大多数情况下,javascript 将根据需要自动进行转换。例如,如果将一个数值添加到一个字符串,该数值将被系统自动转换为文本。
    在大型的软件开发中,我们最好还是不要享受这种语言的恩赐,原因有很多,主要的有两点:一是它很可能会在不经意间埋下不可预期的 bug;二是这种代码缺乏可移殖性。眼下,我们可以将 showMess 改成:
    function showMess()
    {
        var a=parseInt(numA.value);
        var b=parseInt(numB.value);
        var c=a-b;
        var d=a*b;
        var e=a/b;
        var f=a+b;
        messBox.innerText="A-B="+c+"\n"+
                          "A*B="+d+"\n"+
                          "A/B="+e+"\n"+
                          "A+B="+f;
    }
    尽管如此,showMess 的行为还是很怪异的,在输入框中输入数据时很吃力,我们应该提供一种机制,让用户的操作变得轻松一些。
    在往下走之前,这里有必要讨论一下程序设计的思维模式的问题:
    1.不管是哪一种语言,哪一种软件,解决同一个问题,所使用的语言、软件资源越少越好。
    2.不管遇到什么问题,最好不要往里钻,应该退一步,站得更高一点,看得更远一些。这个不大好理解,比方说:我们被一座金碧辉煌的殿堂所吸引,进到里面后很多人就出不来了,如果我们理智的退出来,站到更高更远的地方,我们将会看到更多的更辉煌的大殿。侠客行里的石破天改成金破天就索然无味了。
    3.程序设计时,不要被语言的规则所束缚,更多的应该遵循人的行为习惯。
    啰嗦了,请大家包容!!!
htm0006.rar (454 Bytes)

附件: htm0006.rar (2014-10-15 13:41, 454 Bytes) / 下载次数 2948
http://forums.netpad.net.cn/attachment.php?aid=22573&k=db7dcb2c1a5090d994e6030477fb4e8a&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-15 22:30

New.gif
    javascript 是一种基于对象、事件驱动的编程语言,在输入框输入数据时,系统会触发
onchange 事件,如是,我们便可以编写一个函数,捆绑到这个事件上来,其目的是:当用户输入数据后,立马由该函数对输入的数据进行审核并校正,使输入框内的数据总是在可控的范围内,也就是数据的有效性验证:
    function dataVerify(obj,min,def,max,parseNum)
    {
        var n=parseNum(obj.value);
        if(isNaN(n)||n<min||n>max)n=def;
        obj.value=n;
    }
    这里,我们定义了一个 dataVerify 函数,它接收五个参数:
    obj:接受数据审核的对象
    min:输入框内允许的最小值
    def:通不过审核时设定的默认值
    max:输入框内允许的最大值
    parseNum:将文本转换为数值的系统方法(parseInt 或 parseFloat)
    这意味着我们可以将方法(函数)名作为参数在调用和被调用的函数之间进行传递,这一特性在
编制大型和复杂的程序时非常管用,有点像函数式编程。
    当 n=parseNum(obj.value) 将文本转换为数值出现异常时,isNaN(n)返回逻辑真 true,否则,返回逻辑假 false。
    现在,我们在两个输入框的 html 代码中加入 onchange 事件属性:
A=<input id=numA type=text size=16 value=20
   onchange=dataVerify(this,-1000000,20,1000000,parseInt)><br>
B=<input id=numB type=text size=16 value=30
   onchange=dataVerify(this,-1000000,30,1000000,parseFloat)><br>
    这里的 this 表示对象本身(有点像面向对象编程里的 this);对于 numA 我们传递了将文本转换为整型数值的方法 parseInt,而对于 numB 我们传递了将文本转换为浮点型数值的方法
parseFloat,此举并非程序需要,只是体验一下而已。
    相应的 showMess:
    function showMess()
    {
        var a=parseInt(numA.value);
        var b=parseFloat(numB.value);
        var c=a-b;
        var d=a*b;
        var e=a/b;
        var f=a+b;
        messBox.innerText="A-B="+c+"\n"+
                          "A*B="+d+"\n"+
                          "A/B="+e+"\n"+
                          "A+B="+f;
    }
    这里,留一个问题给大家:如果输入框内允许的最大最小值为 +∞-∞,该如何写代码呢?
htm0007.rar (570 Bytes)

图片附件: New.gif (2014-10-16 09:13, 4.83 KB) / 下载次数 1698
http://forums.netpad.net.cn/attachment.php?aid=22577&k=787bf6e71a28143b2db38fb2978077af&t=1765167857&sid=yYLc25



附件: htm0007.rar (2014-10-15 22:30, 570 Bytes) / 下载次数 2943
http://forums.netpad.net.cn/attachment.php?aid=22578&k=6d8888eb6c1c4d02da3e2ccc2487c8bf&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-16 19:07

htm0008.jpg
    就 html 来说,对于 input 元素,我们可以通过 onmousewheel(鼠标滚轮)事件使用 javascript 来提供一种稍为高级一点的数据输入方式:
A=<input id=numA type=text size=16 value=20
  onchange=dataVerify(this,-1000000,20,1000000,parseInt)
  onmousewheel=dataVerify2(event.wheelDelta,10,this,-1000000,20,1000000,parseInt)><br>
B=<input id=numB type=text size=16 value=30
  onchange=dataVerify(this,-1000000,30,1000000,parseFloat)
  onmousewheel=dataVerify2(event.wheelDelta,0.1,this,-1000000,20,1000000,parseFloat)><br>
    系统触发各种鼠标事件后,会建立一个名为 event 的对象记录下鼠标的各种状态,鼠标向前滚动时 event.wheelDelta 大于零,反之小于零。这里的代码设定 numA 的变化幅度为±10,numB 的变化幅度为±0.1。这样,可以将 dataVerify2 写成如下的样子:
    function dataVerify2(d,dn,obj,min,def,max,parseNum)
    {
        var n=parseNum(obj.value)+dn*Math.abs(d)/d;
        if(isNaN(n)||n<min||n>max)n=def;
        obj.value=n;
    }
    这里 Math.abs 是 javascript 的内置对象 Math 的求绝对值的方法,所以,Math.abs(d)/d,将取值 1 或 -1,这样,代码就实现了输入框内的数值随着鼠标的滚动朝相应的方向变化。
htm0008.rar (638 Bytes)

图片附件: htm0008.jpg (2014-10-16 19:06, 33.26 KB) / 下载次数 1701
http://forums.netpad.net.cn/attachment.php?aid=22581&k=8b5af5b31ddf2ff8439059e498d45806&t=1765167857&sid=yYLc25



附件: htm0008.rar (2014-10-16 19:07, 638 Bytes) / 下载次数 3002
http://forums.netpad.net.cn/attachment.php?aid=22582&k=5d4d3a12b789960be29044fc2cff58f6&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-16 22:08

比较一下 dataVerify 和 dataVerify2:
    function dataVerify(obj,min,def,max,parseNum)
    {
        var n=parseNum(obj.value);
        if(isNaN(n)||n<min||n>max)n=def;
        obj.value=n;
    }
    function dataVerify2(d,dn,obj,min,def,max,parseNum)
    {
        var n=parseNum(obj.value)+dn*Math.abs(d)/d;
        if(isNaN(n)||n<min||n>max)n=def;
        obj.value=n;
    }
    两个函数可以并作一个:
    function dataVerify(d,dn,obj,min,def,max,parseNum)
    {
        var n=parseNum(obj.value)+dn*Math.abs(d)/d;
        if(isNaN(n)||n<min||n>max)n=def;
        obj.value=n;
    }
    修改一下 numA 和 numB:
A=<input id=numA type=text size=16 value=20
      onchange=dataVerify(1,0,this,-1000000,20,1000000,parseInt)
  onmousewheel=dataVerify(event.wheelDelta,10,this,-1000000,20,1000000,parseInt)><br>
B=<input id=numB type=text size=16 value=30
      onchange=dataVerify(1,0,this,-1000000,30,1000000,parseFloat)
  onmousewheel=dataVerify(event.wheelDelta,0.1,this,-1000000,20,1000000,parseFloat)><br>
    当触发 onchange 事件并执行 dataVerify 时,dn*Math.abs(d)/d 恒等于零。
    至此,我们终于写出了一个颇具价值的 javascript 函数 dataVerify。这可是一劳永逸的业绩,在后面的复分形编程中,有着一大堆的参数,少了这段代码将是很难想像的。当然,我们可以把这个dataVerify 函数写得更复杂一些,功能更强大一些。
htm0009.rar (633 Bytes)

附件: htm0009.rar (2014-10-16 22:08, 633 Bytes) / 下载次数 3030
http://forums.netpad.net.cn/attachment.php?aid=22583&k=f29e1cdd41cf5b46341d732c463cc568&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-17 02:03

关于数据的输入,到现在暂且告一段落,接下来讨论作图,也即 html5 的画布 canvas。
    在此之前,我们稍事休息,有两个问题在这里说明一下:
    一、这里的讨论有一个默认的前提,那就是各位朋友应该对编程语言具备一定的知识,这种知识的来源有两个途径,首先,所有的编程语言都有相通的地方;其次,对于 html、css、javascript 这三种语言的细节,应该先作些功课,我手上倒是有些资料,打了个包,260 MB,可我不知道怎么传,如有需要,给个邮箱地址。
    二、解释一下本贴的主题“几何画板下的编程思考”。
    前面提到过,几何画板作为很多算法的形象演练,是个绝妙的工具,比方说,hilbert 曲线的制作,除了原生的字符串重写系统,其他的诸如,迭代、递归、矩阵都可以,但不怎么轻松。然而在几何画板里,通过逆向思维,把 hilbert 曲线的过程倒过来,竟然找到了一种既简单又巧妙的方法。各位老师的画板作品,更是让我心动,虽然弄不明白其中的数学原理,却使我明白了一个道理,我们原来编的程序都是那么生硬,是因为没有在数据可视化上下功夫。
    下面就是受几何画板的启发编写的万花曲线规(须在 ie10 下运行),如果可以继续的话,后面将以它为蓝本进行讨论。
htm0010.jpg
万花曲线规html.rar (2.18 KB)

图片附件: htm0010.jpg (2014-10-17 02:02, 89.37 KB) / 下载次数 2275
http://forums.netpad.net.cn/attachment.php?aid=22584&k=a20fd7de9fdfe702430e98a348256f65&t=1765167857&sid=yYLc25



附件: 万花曲线规html.rar (2014-10-17 02:03, 2.18 KB) / 下载次数 3553
http://forums.netpad.net.cn/attachment.php?aid=22585&k=6a8f0542dc1754687c6448b32354151a&t=1765167857&sid=yYLc25
作者: lnszdzg    时间: 2014-10-17 10:13

感谢您的精彩文章,受益匪浅。
想索取您的资料,留个邮箱——1043622345@qq.com
谢谢!
作者: 一线天    时间: 2014-10-17 16:39

赞一个!很有意义的研究,不过几何画板对javascript的支持比较有限吧,如果是在GerGebra上研究javascript会强大的多。
作者: 一线天    时间: 2014-10-17 16:51

再看了一遍,发现并不是几何画板支持javascript,而是单纯的javascript语言实现几何画板的部分效果。
而GerGebra是原生支持javascript并可以输出网页文件的,可以说做数学网络课件GerGebra是最佳选择。
作者: myzam    时间: 2014-10-18 08:11

1# xklppp
不错。有意的工作。
不过我也说两点:
第1点:学习js代码最好的地方是网络上的w3cschool(w3c学校),我就是从那里起步的。
第2点:几何画板无法使用编程,这是几何画板的缺陷,同时也是优点,因为编程会让操作抽象化,但编程又可以让画板做更多更细腻的事情,几何画板的作者在这两者间做了选择,他选择了取消编程,采用形象化的操作。GGb可以支持js编程。
最后,对你的工作致敬。
作者: xklppp    时间: 2014-10-18 12:54

谢谢各位老师,很专业,也很诚恳,真的是很高兴。
    如果不嫌冒昧的话,我在这里想和大家说几句推心置腹的话:几何画板作复变分形,体现出了老师们超凡卓越的能力,给人们展现的不仅仅是专业上的造诣,更多的是精神上的感动,至少我是被感动了。我总是觉得,老师们的业绩非常伟大,但也未免太过悲壮,几何画板玩分形,太辛苦了,希望老师们别怪罪,我说的是心里话。
    无论是几何画板还是复变分形,我真的不敢恭维自己。老师们越是包容我心里越是惭愧,跟着这个论坛学了这么多东西,怎么样才能对得起大家呢,开这个帖子的时候,我是犹豫了很久的:就 javascript 而言,深度和广度我都不具备,myzam 老师说得对,javascript 资料、教程和网站有很多,这是画板论坛,在这里专门讨论 javascript 是很不合时宜的。想了很久,最后大起胆子决定以“几何画板下的编程思考”为题来展开讨论,我知道这个祸闯大了,第一,对于我来说,题目太大了,编程的思维模式和行为习惯是个仁者见仁智者见智的问题。第二,这个题目不准确,让人以为是要对几何画板的功能进行编程模拟,在此特向大家道歉!
    我想把题目改成:“几何画板带给编程者的思考”,又觉得怪怪的,我的意思是:就编程来说,几何画板改变了我的行为习惯和思维模式。唉,总之,说来说去,结结吧吧的。哪位老师若有高见,请不吝赐教,谢谢了!
    实际上,脚本语言 javascript 是编程世界里的一个冤大头,对于不熟悉它的人来说,其问题出在“脚本”二字上,这里不展开,只是建议大家从认识上去掉“脚本”两个字,javascript 它就是一门纯粹的算法语言。对于熟悉它的人来说,建议看一下
    http://blog.csdn.net/uoyevoli/article/details/744915
和其他的有关文章。重复一下:javascript 作为 web 浏览器的前端脚本语言有着渗透网络世界所有领域的趋势。
    这个帖子之所以到现在要歇一下,就是希望得到各位老师的提携和指点,以使帖子朝着正确的方向走下去(如果可以的话)。
    上面贴出的那个“万花曲线规”,不是要讨论它的算法和实现,而是我们将要讨论更为高级的一种数据输入方式:屏幕输入。
    再次谢谢各位老师的包容和指教!!!
作者: myzam    时间: 2014-10-18 13:47

21# xklppp
论坛贵在论字上,也就是说你想怎么写就怎么写。你表达你的观点就行,别人接不接受是另一回事。大胆的写吧,总有人会看的。顶起。论坛要的就是百花齐放的效果。
作者: xiaongxp    时间: 2014-10-18 14:11

21# xklppp
强烈支持!这才是取长补短,相得益彰!
作者: lnszdzg    时间: 2014-10-18 19:48

资料收到,谢谢分享。
作者: xklppp    时间: 2014-10-18 23:44

就软件界面而言,如果程序只涉及到文本,数据的输入有了前面介绍的两种方式即:键盘输入和鼠标输入(不是很准确)也可以应付一般的情况了。若需要绘图,则屏幕输入方式就显得非常重要。比方说:作复变分形时,在 mandbrot 集中寻找 julia 集,以及复分形的缩放,只用现有的输入方式会使得编程很是艰难。
    html5 用来处理图形图像的 canvas(画布) 元素,提供了一个二维接口 getContext('2d'),脚本语言就是通过这个接口来进行图形图像编程的。如:
      <canvas id=mCanvas width=300 height=200></canvas>
    这里放置了一个名为 mCanvas,宽高为 300,200 的画布,画布的默认状态是透明的。由于解释起来比较繁复和啰嗦,我都写入到了代码的注释里面。
New1.gif
canvas 绘图功能非常强大,虽然目前只提供 2D 接口,但当下网上关于 canvas 3D 应用的视觉冲击力简直是不可思议。就 2D 来说,photoshop 的很多功能和特效都可以通过 javascript 不难的编程实现,在动画方面,flash 已经不能望其项背了。
    从程序运行效果来看,现有的参数输入方式,已经显得很笨拙,必须改善其性能,不过接下来的讨论会稍为艰难一点,谢谢大家的耐心!
htm0100.rar (1.45 KB)

图片附件: New1.gif (2014-10-20 09:09, 4.68 KB) / 下载次数 3026
http://forums.netpad.net.cn/attachment.php?aid=22587&k=da407d511761bfc79ed1f377e7da328b&t=1765167857&sid=yYLc25



附件: htm0100.rar (2014-10-18 23:44, 1.45 KB) / 下载次数 4467
http://forums.netpad.net.cn/attachment.php?aid=22588&k=a0b6036ed17bde787a47c58b171c5a02&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-19 11:31

很多人不太愿意搭理 javascript,它不就是个前端脚本工具吗,做大型网站有的是后台脚本语言,况且,从美工的角度来考虑,有了html 和 css 网页就可以做得很炫很酷,只是在设计页面交互功能和简单动画时用到 javascript 而已。
    其实,简单的说,html+css+javascript 可以做两个方面的事情,一是做网页,二是做软件。做网页不是这个帖子讨论的内容,我们要讨论的是如何使用 javascript 开发软件,太多的人没朝这方面去想,尽管现在 javascript 像个疯子一样在网络世界横行霸道,但也只是个敲边鼓,跑龙套的角色。
    就软件开发而言:第一,网络世界涌现出越来越多的在线软件,像雨后春笋。第二,这个帖子的开篇有提示过,“把文件的扩展名 .htm 改为 .hta 然后双击该文件,好了,我们竟然开发出了一个软件!”,之所以这样说,首先这是事实,其次,这可以成为我们学习 javascript 的动力,为我们学习 javascript 找到一个足以自豪的理由!
    如果有学习过可视化编程,如:vb,vc,c#,我们会发现:在工程项目的代码文件夹中,主要的有两类文件,一是算法代码,二是窗体代码,算法代码就是一般意义上的数据处理的程序代码,这一点,帖子在后面的复变分形中会涉及一些,真要讨论算法的话,得另外开个专题。为扣主题,本贴只讨论第二个方面的问题,窗体代码,也就是软件的界面代码,为方便见,以后我们把软件的界面就称之为窗体,也就是 html 的 body 元素。
    窗体代码主要作三件事:
    1.在窗体(body)中放置程序需要的对象(元素)。
    2.给各对象添加事件。
    3.编写事件的响应代码。
    这就是可视化编程要做的事情,我们就按照这种结构来编写我们的 javascript 代码。大家从前一个文件 htm0100.htm 中可以看得出来,窗体中只放置了五六个对象,其代码就显得有些拥挤不堪。事实上,它不像软件代码,只是个网页代码而已,并且会给后面的编程带来难以想象的麻烦。
    为此,我们编写一个名为 formSetup 的窗体函数,里面再嵌套 initComponents 放置对象,addEvent 添加事件和相应事件响应等函数,如是,我们的代码看起来像这个样子:
<script>
    function drawing()
    {
    }
    function formSetup()
    {
        var dataVerify=function(){}
        var addEvent=function(){}
        var initComponents=function(){}
    }
</script>
<body></body>
    没有新的内容,只是调整了一下结构。到现在,我们这才真的有点编程、做软件的意思了!
htm0101.rar (1.91 KB)

附件: htm0101.rar (2014-10-19 11:31, 1.91 KB) / 下载次数 4337
http://forums.netpad.net.cn/attachment.php?aid=22589&k=158a370d2551410a94a8f2be9bda9257&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-20 00:13

程序编到这里,仍然有两个问题:
    1.在输入框中输入数据后,须点击“绘图”按钮,输出窗口才会被刷新。
    2.几乎所有的绘图软件都提供了另外一种所见所得的数据输入方式,对于这种几何图形,更直观的方式是通过拖动图形的关键点来即时改变其形状,我们暂且称之为屏幕输入。
    这里先解决第一个问题,唯有如此,才能解决第二个问题。
    进一步调整代码:
<script>
    function Cycloid(){}
    function formSetup()
    {
        var RR,rr,pp;
        var drawing=function(){}
        var resetCycle=function(){}
        var dataVerify=function(){}
        var initComponents=function(){}
        var addEvent=function(){}
    }
</script>
New.gif
这里,我们有一个基本的原则:除非万不得已,一般不在算法代码中处理窗体元素的各种数据,而算法中需要的各种参数,应该在窗体函数 formSetup 中预处理完毕后通过函数调用传递过去,开发大型软件时,这一点显得尤为重要。
htm0102.rar (1.42 KB)

图片附件: New.gif (2014-10-20 09:09, 4.72 KB) / 下载次数 2956
http://forums.netpad.net.cn/attachment.php?aid=22591&k=5379ae2b4b09188607ec836e6efcccb1&t=1765167857&sid=yYLc25



附件: htm0102.rar (2014-10-20 00:35, 1.42 KB) / 下载次数 4519
http://forums.netpad.net.cn/attachment.php?aid=22594&k=3c39146e8e0556ffa61759bfbe30deb7&t=1765167857&sid=yYLc25
作者: 一线天    时间: 2014-10-20 14:48

27# xklppp


可以感觉到,楼主的不断研究,最终成就一个基于网页的几何画板,期待尽早实现。
作者: xklppp    时间: 2014-10-21 00:29

由于代码是以万花曲线规为蓝本,代码中的 R、r、p 分别为定圆半径、动圆半径、笔孔。在程序输出窗口的画布中,设置了三个关键点:定圆圆心、动圆圆心、笔孔。为简化编程其中只有动圆圆心、笔孔被设置为可控屏幕点。R 由 mCanvas 的鼠标滚轮事件控制(这样安排主要是为了后面复分形的缩放留出代码空间),r、p 则通过 mCanvas 的鼠标拖拽来操纵。
    鼠标滚轮事件的代码很简单,和前面的一样,不再赘述。然而,鼠标拖拽却比较麻烦。一个鼠标拖拽动作包括三个事件:
    onmousedown 在对象上按下鼠标
    onmousemove 在对象上移动鼠标
      onmouseup 在对象上释放鼠标
    像大多数绘图软件的鼠标吸附(捕捉)功能一样,再加上一个吸附(捕捉)半径,就可以编写鼠标拖拽事件的程序代码了。
New1.gif
    关于数据输入,讨论到这里就告一段落了。由于我们编写的是小程序,窗体设计中的诸如菜单栏、工具条、快捷按钮,属性面板,弹出窗口等等,本贴就不再涉及了。
    万花曲线规中还用到动画效果和多图层技术,这些我们将留在后续的复分形编程中讨论。
htm0103.rar (1.89 KB)

图片附件: New1.gif (2014-10-21 09:35, 5.09 KB) / 下载次数 2907
http://forums.netpad.net.cn/attachment.php?aid=22595&k=4d2724b77b0abf90be6450511c621a90&t=1765167857&sid=yYLc25



附件: htm0103.rar (2014-10-21 00:29, 1.89 KB) / 下载次数 4218
http://forums.netpad.net.cn/attachment.php?aid=22596&k=73cc988f6d87a7fed8c14ac9136b5f11&t=1765167857&sid=yYLc25
作者: 周传高    时间: 2014-10-21 15:13

看不懂,但坚决支持!
作者: xklppp    时间: 2014-10-21 15:42

30# 周传高
谢谢版主的提携,非常感谢!!!
作者: xklppp    时间: 2014-10-21 23:42

大家都是玩复形的高手,所以,我们这里只需就程序设计的思路和代码的结构展开讨论。
    对于 mandbrot 集,我们有伪代码:
    扫描 C 平面
    {
        对当前扫描点进行几何变换(如果需要的话).......变换模块
        对当前点按给定的算法(如:z=z^2+c)进行迭代....迭代模块
        根据迭代结果对当前点进行着色.................着色模块
    }
    把里面的功能模块独立出来写成函数,我们很容易就能写出 mandbort 集的 javascript 代码框架:
    function Mandbrot()
    {
        var iterator=function(){}     //迭代算法
        var transPlane=function(){}   //对扫描平面进行几何变换
        var setColor=function(){}     //设置当前扫描点的颜色
        var scanCplane=function(){}   //扫描 C 平面
    }
    在窗体代模块中,我们设置几个变量:
    var Zr=0,Zi=0,Cr=0,Ci=0,eM=2,eT=20;
    其中 z=(Zr,Zi)、c=(Cr,Ci)、eM(逃逸半径)、eT(逃逸时间),Cr、Ci暂时没用。
3.gif
htm0201.rar (933 Bytes)
后面我们将一步一步地完善其代码。

图片附件: 3.gif (2014-10-25 18:09, 3.01 KB) / 下载次数 2924
http://forums.netpad.net.cn/attachment.php?aid=22597&k=8aa16882d44f534d2bd60b37fb342fcc&t=1765167857&sid=yYLc25



附件: htm0201.rar (2014-10-21 23:42, 933 Bytes) / 下载次数 3886
http://forums.netpad.net.cn/attachment.php?aid=22598&k=bf78a37404945911f62b5f566914d467&t=1765167857&sid=yYLc25
作者: room901    时间: 2014-10-22 15:14

支持楼主,唯一可惜html5暂时很多版本的浏览器都不支持,发一个简单动画(兼容性比较好).

附件: 简单动画.rar (2014-10-22 15:14, 482 Bytes) / 下载次数 2625
http://forums.netpad.net.cn/attachment.php?aid=22599&k=d160f1875571b605b2b1c70fcc46dc39&t=1765167857&sid=yYLc25
作者: wdpfox    时间: 2014-10-22 15:51

尽管不太明白,但也要表示感谢与支持,学习学习:wdpfox@sina.com
作者: xklppp    时间: 2014-10-23 01:31

前面讨论的 canvas 绘图用的是矢量模式,而作复分形是复平面的逐点扫描,必须用另外一种
模式,即位图模式。html5 用一维数组来存储 canvas 画布上从左到右从上到下每一个像素的颜色数据:r,g,b,a,分别为红、绿、蓝、alpha 通道(不透明度),其取值均为 0-255。
    这样,一维数组从第 0 个元素开始,每四个元素存储 canvas 画布的一个像素的颜色数据,
javascript 就是通过修改这个数组的各个元素的值来实现位图模式绘图的。
    在窗体代码中,我们增加了 initmSet 和 mSet 两个函数,前者用来初始化或重设扫描平面的数据,后者用来启动算法程序。
    在算法代码中,为简单见,我们使用的是 z=z^2+c 模型。原文件给出了详细的注释。
3.jpg

    在 ZR、ZI 的输入框中滚动鼠标,会看到一些在别的软件中不太容易看到的景象,我们的
代码才刚刚起步,就能有如此的成绩,相信大家会有兴趣走下去。
    后面的讨论会越来越艰难,我们将放慢节奏,祝大家学习愉快!!!
htm0202.rar (2.14 KB)

图片附件: 3.jpg (2014-10-27 08:34, 24.92 KB) / 下载次数 2872
http://forums.netpad.net.cn/attachment.php?aid=22600&k=27959f04d91fb76a2b6e501924279c79&t=1765167857&sid=yYLc25



附件: htm0202.rar (2014-10-23 01:31, 2.14 KB) / 下载次数 3953
http://forums.netpad.net.cn/attachment.php?aid=22604&k=21f334a0e779b0d877c83d1ae523cbf0&t=1765167857&sid=yYLc25
作者: lnszdzg    时间: 2014-10-23 10:15

美不胜收啊
作者: room901    时间: 2014-10-23 13:45

非常强大!
作者: xklppp    时间: 2014-10-24 12:43

现在,我们在程序中增加缩放模块,下面是放大图像的原理图:
New.jpg
放大(缩小)图像实际上就是把当前的复平面裁剪(扩大)后重新映射到画布。对此,我们为 mCanvas 画布增加一个鼠标滚轮事件并在窗体代码中增加 scalePlane 和 changeET 两个函数,scalePlane 用来修改复平面,changeET 则用来修改逃逸时间阈值。
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
图像缩放的算法和屏幕输入的设计有很多,我们这里使用的是最简单的一种。当我们熟练了以后,就可以对其功能和模式进行扩展。
    程序编到这里,代码仍然是非常的简单,但是,它却可以让我们随着鼠标滚轮的滚动在硬件允许的精度下来探索 mandbrot 集中所有的细节。
htm0203.rar (2.21 KB)

图片附件: New.jpg (2014-10-25 18:04, 18.61 KB) / 下载次数 2881
http://forums.netpad.net.cn/attachment.php?aid=22617&k=bf27cce57ce56d843bc86a606cdf46c7&t=1765167857&sid=yYLc25



图片附件: 1.jpg (2014-10-25 18:08, 12.41 KB) / 下载次数 2858
http://forums.netpad.net.cn/attachment.php?aid=22618&k=44bd4c8a927c1dbbcaaff21a447292f0&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-10-25 18:08, 13.25 KB) / 下载次数 2932
http://forums.netpad.net.cn/attachment.php?aid=22619&k=195d63f56e058b809d63f928def68a75&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-10-25 18:08, 14.96 KB) / 下载次数 2904
http://forums.netpad.net.cn/attachment.php?aid=22620&k=93a63ec6ebc672cbc47e4f682c20cb57&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-10-25 18:08, 15.62 KB) / 下载次数 2869
http://forums.netpad.net.cn/attachment.php?aid=22621&k=2f8694ab1b16612c649de95eff537e29&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-10-25 18:08, 17.41 KB) / 下载次数 2930
http://forums.netpad.net.cn/attachment.php?aid=22622&k=cddd71b2a24ba1917692e15ac4352047&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-10-25 18:08, 16.63 KB) / 下载次数 2854
http://forums.netpad.net.cn/attachment.php?aid=22623&k=fe6159d7245ad2ca4a431d4147fe4de8&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-10-25 18:08, 15.79 KB) / 下载次数 2916
http://forums.netpad.net.cn/attachment.php?aid=22624&k=460261ae0c18080f8409be92000b60ff&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-10-25 18:08, 15.88 KB) / 下载次数 2866
http://forums.netpad.net.cn/attachment.php?aid=22625&k=d365d4e932d9365dddae271408d33aaa&t=1765167857&sid=yYLc25



附件: htm0203.rar (2014-10-24 12:43, 2.21 KB) / 下载次数 3924
http://forums.netpad.net.cn/attachment.php?aid=22626&k=ad313f8721a8087e36ca5d5925585c70&t=1765167857&sid=yYLc25
作者: xfzch    时间: 2014-10-24 22:44

发一份资料给我,谢谢!
xfzch@qq.com
作者: xklppp    时间: 2014-10-26 14:34

M 集的显示基本上可以告一段落,剩下的就是迭代算法、着色算法以及复平面的转换。
    这里,我们在程序中加入显示 J 集的功能,有研究说:M 集实际上就是 J 集的特征集,J 集的结构是由 M 集中各点位置所决定的。这样,我们就有了程序设计的思路:
    以 M 集为背景来探寻 J 集,为使其过程直观形象,我们在 M 集画布 mCanvas 的上面叠加一块显示 J 集的画布 jCanvas,就像 photoshop 中的图层一样,这里,我们也将使用多图层技术来进行余下的编程。
    html 中的元素叠加必须由 css 来实现,大家可以查阅相关资料或手册,这里不方便展开。
    为了后面代码编写的方便,我们对程序里的一些变量命名和函数做了稍为的调整,原理和结构是没有变的,由于增加了 J 集,代码将会显得稍为复杂一些,所以,关于 J 集,我们将分两步讨论,这里,显示 J 集需要的 c=(a,b) 是简单的由 Cr,Ci 输入框输入的:
1.jpg
2.jpg
     尽管我们在窗体代码和算法代码中增加了一些函数模块,但复变模型仍然是 z=z^2+c,不难看出,我们现在所做的都是些基础工程,实际上就是搭建软件的运作平台,这与可视化编程 vc、vb、c# 等的窗体搭建是完全一样的,虽然平台的搭建需要耗费大量的精力和时间,好在这项工作是一劳永逸的,其价值也应就不言而喻了。
htm0204.rar (2.87 KB)

图片附件: 1.jpg (2014-10-27 08:33, 16.68 KB) / 下载次数 2822
http://forums.netpad.net.cn/attachment.php?aid=22637&k=cdcbbe39d2f6e4655ee265affafe6524&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-10-27 08:33, 16.43 KB) / 下载次数 2833
http://forums.netpad.net.cn/attachment.php?aid=22638&k=9333c3cfa27856177d5be5836e9d4c7c&t=1765167857&sid=yYLc25



附件: htm0204.rar (2014-10-26 14:34, 2.87 KB) / 下载次数 3965
http://forums.netpad.net.cn/attachment.php?aid=22639&k=51e2770477c905d8ec6d2fc1a0d37ea3&t=1765167857&sid=yYLc25
作者: a2569875    时间: 2014-10-26 16:59

29# xklppp
xklppp 发表于 2014-10-21 00:29
关于圆上的可动点、可选取移动的圆、轨迹、轨迹上的可动点又要如何制作或定义呢?
作者: xklppp    时间: 2014-10-26 21:16

41# a2569875
摆线方程:
      x=(R-r)cost+pcos(1-R/r)t
      y=(R-r)sint+psin(1-R/r)t
其中的 p 就是轨迹上的动点
     代码实现请参考 16 楼的原文件,为简单见,这个帖子没有准备就特殊问题的特殊算法展开讨论,这里只就编程思路略作探讨,请原谅!!!
作者: xklppp    时间: 2014-10-27 12:58

理论上讲,显示 J 集所需要的 c=(a,b) 属于连续型变量。一方面使用 html 的 input 输入框输入这种类型的数值很辛苦;另一方面,结构细腻的 J 集都位于 M 集的边界处。
    尽管由于硬件精度和屏幕空间的原因,不能达到真正意义上的连续性,但要显示 J 集,屏幕输入的方式输入 c=(a,b) 仍不失为最佳选择。
    因此,我们在窗体代码中为 J 集画布 jCanvas 添加 onclick 和 onmousewheel 两个鼠标事件,前者当鼠标单击 jCanvas 时,将鼠标在画布上的位置映射到显示 M 集时的复平面 c,从而显示各式各样的 J 集;后者用来缩放 J 集,其原理与 M 集相同,只不过缩放 J 集时,裁剪或扩大的是复平面 z。
    要注意的是:必须 √ 选 show_J 复选框才能使用屏幕输入显示和缩放 J 集。
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
d.jpg
e.jpg
    到此,我们只要修改算法代码中 iterator 函数的迭代算法,就可以欣赏到很多复变模型的 M 集和 J 集的精妙结构,虽然只是灰度图像,却也不乏乐趣。
htm0205.rar (2.12 KB)

图片附件: 1.jpg (2014-10-29 22:10, 16.25 KB) / 下载次数 2161
http://forums.netpad.net.cn/attachment.php?aid=22646&k=90c79e7ff8c1d6f646268458a279cfaa&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-10-29 22:10, 15.55 KB) / 下载次数 2161
http://forums.netpad.net.cn/attachment.php?aid=22647&k=a388eae50b3d49900595035e11541bd9&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-10-29 22:10, 16.86 KB) / 下载次数 2151
http://forums.netpad.net.cn/attachment.php?aid=22648&k=6d8419fb418b9d7847819812ba7b02e8&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-10-29 22:10, 18.64 KB) / 下载次数 2155
http://forums.netpad.net.cn/attachment.php?aid=22649&k=8e534063fbb84914d2057476567e64d2&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-10-29 22:10, 18.58 KB) / 下载次数 2174
http://forums.netpad.net.cn/attachment.php?aid=22650&k=b3d1fb1a18169f24f22aa56a40c3c998&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-10-29 22:10, 17.54 KB) / 下载次数 2123
http://forums.netpad.net.cn/attachment.php?aid=22651&k=e632ab9489d7ca5d4bf419b9badc0104&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-10-29 22:10, 18.72 KB) / 下载次数 2207
http://forums.netpad.net.cn/attachment.php?aid=22652&k=6caa7b000d7adc76c05fe6b2d75fd732&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-10-29 22:10, 17.8 KB) / 下载次数 2166
http://forums.netpad.net.cn/attachment.php?aid=22653&k=369b30ac37a5491c859e70fb13222218&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-10-29 22:10, 18.05 KB) / 下载次数 2173
http://forums.netpad.net.cn/attachment.php?aid=22654&k=5dce266247040632dd817c21b8b28d11&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-10-29 22:10, 20.22 KB) / 下载次数 2158
http://forums.netpad.net.cn/attachment.php?aid=22655&k=c74ed66659975dfda4b4f7cb8eaee43e&t=1765167857&sid=yYLc25



图片附件: d.jpg (2014-10-29 22:13, 20.35 KB) / 下载次数 2136
http://forums.netpad.net.cn/attachment.php?aid=22656&k=81a9c5c5efc3a3456f33fd8042ceed5c&t=1765167857&sid=yYLc25



图片附件: e.jpg (2014-10-29 22:13, 37.16 KB) / 下载次数 2176
http://forums.netpad.net.cn/attachment.php?aid=22657&k=2dd47c7374e3649fdd496a782a7994fc&t=1765167857&sid=yYLc25



附件: htm0205.rar (2014-10-27 12:58, 2.12 KB) / 下载次数 3576
http://forums.netpad.net.cn/attachment.php?aid=22658&k=0c761b86b36cc3c992cc1f42ca45e423&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-29 12:56

关于复分形的着色,各位老师都是大师级高手,我只知道一些初浅的方法。接下来,我们讨论一下着色模块的代码编写。在窗体中加入 html 的颜色对话框元素:
    <object classid='clsid:3050f819-98b5-11cf-bb82-00aa00bdce0b'></object>
    而 javascript 则是通过该对象的 chooseColorDlg 方法显示颜色对话框并让用户选取颜色的。
    在现有的窗体代码中,显示 M 集和 J 集的两块画布被重叠在一起并放置在一个名为 bColor 的 div 块元素之中,如其名,bColor 用来设置背景色,与此同时,设置一个画布前景色,在迭代过程中,依据逃逸时间,由浅到深设置各像素的不透明度,这样就获得了基于前景色和逃逸时间的囚集图像。
    为便于扩展,这次对窗体代码进行了简化处理并稍为调整了一下界面的视觉效果,相应的增加了setBcolor 和 setRibbon 两函个数,前者设置背景色,后者设置前景色,之所以取名 setRibbon,是因为后面有需要使用“色带”的着色算法。
1.jpg
2.jpg
    程序对 iterator 和 setColor 的返回值进行了必要的扩展,以适应更多的着色算法。
htm0301.rar (2.48 KB)

图片附件: 1.jpg (2014-10-29 22:18, 15.9 KB) / 下载次数 2164
http://forums.netpad.net.cn/attachment.php?aid=22661&k=9d183ec7aac1035ada840ae2636c4dd7&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-10-29 22:18, 18.81 KB) / 下载次数 2148
http://forums.netpad.net.cn/attachment.php?aid=22662&k=f1b28656be992222bf993c89e83102dd&t=1765167857&sid=yYLc25



附件: htm0301.rar (2014-10-29 12:56, 2.48 KB) / 下载次数 3501
http://forums.netpad.net.cn/attachment.php?aid=22663&k=044ddaebd4ee61e284dbb9be92de9334&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-10-31 23:08

在算法代码 Mandbrot 中,有三个功能模块:iterator(迭代)、setColor(着色)和transPlane(变换)。无论是哪个模块,理论上讲,都有着无数的可能性。由于采用的是传统的结构化编程,继续往下扩展遇到了瓶颈,所以,我们必须引入面向对象的编程机制。
    纯粹的面向对象编程其实是蛮吓人的,吓退了为数不少的编程爱好者。 所以,我们这里只能就程序的需要初浅的认识一下:

function Mandbrot(p,c,mC,M)//定义了一个 Mandbrot 函数
{
    var iterator=function(x,y,a,b){} //Mandbrot内嵌函数
    var transPlane=function(){}     //Mandbrot内嵌函数
    var setColor=function(e){}      //Mandbrot内嵌函数
    var scanCplane=function(){}   //Mandbrot内嵌函数
    var scanZplane=function(){}   //Mandbrot内嵌函数
    if(is_M)scanCplane();
     else scanZplane();
}  // Mandbrot 能完成一系列的功能,可以有返回值,也可以没有

function formSetup()
{
    Mandbrot(p,c,mC,M);//调用 Mandbrot 函数
                           //这里的 Mandbrot 是一个完成特定功能的程序模块
                           //这就是结构化编程
}
=========================================
将代码调整为:
function Mandbrot()//定义了一个 Mandbrot 类(对象模板)
{
    var iterator=function(x,y,a,b){}   //Mandbrot私有方法
    var transPlane=function(){}       //Mandbrot私有方法
    var setColor=function(e){}        //Mandbrot私有方法
    var scanCplane=function(){}     //Mandbrot私有方法
    var scanZplane=function(){}     //Mandbrot私有方法

    var showSet=function(p,c,mC,M)  //Mandbrot私有方法
    {
        if(is_M)scanCplane();
        else scanZplane();
    }

    return {show:showSet}//返回一个对象,该对象有一个名为 show 的属性
                            //其属性值为该类的私有方法 showSet
}//Mandbrot 类和 Mandbrot 函数很相似,但不完成任何操作,只是
//定义了一个对象模板
//定义类时,必须以对象的形式提供返回值,这个返回值就是所谓
//的接口或入口。

function formSetup()
{
    var Mj=new Mandbrot();//创建一个名为 Mj 的 Mandbrot 实例对象
                              //所以,Mj 就是一个 Mandbrot 对象,Mj 的
                              //所有功能都必须通过接口才能实现
    Mj.show(p,c,mC,M);     //调用 show 属性所指向的方法:showSet
                                     //这里的 Mandbrot 是一个类模板
                              //这里的 Mj 是一个 Mandbrot 实例
                              //这里的 Mj 是一个对象
                              //Mandbrot 类定义的所有功能都必须通过接口
                              //由其实例对象 Mj 来实现
                              //这就是面向对象编程
}

      这里的讨论很不专业,甚至有点谐虐,没关系,我们不想把“面向对象”作为一个包袱来背,只是使用“面向对象”编程中的一些便利机制,来增强程序代码的可扩展性能。如是,我们对代码作出了调整,使其看起来像面向对象编程的样子。虽然现在还看不出这有什么好处,但在后续的编程中,这种调整给编程带来的便利将会越来越明显。
htm0302.rar (2.57 KB)

附件: htm0302.rar (2014-10-31 23:08, 2.57 KB) / 下载次数 3654
http://forums.netpad.net.cn/attachment.php?aid=22668&k=275db84bf9619ecadb9c6c2974292153&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-2 00:56

现在,可以很方便地来扩展算法代码中的 setColor 功能模块了,尽管这里给出了 16 种着色方案,由于 javascript 具备面向对象的语言能力,所以,代码还是很简单的。需要说明的是:我没有能力提供成熟的着色算法,很是抱歉。这里只是向大家展示了程序的结构,当大家熟悉了 javascript 后,在编写自己的程序时,便可将那些惊艳的算法植入其中。
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
htm0303.rar (3.93 KB)

图片附件: 1.jpg (2014-11-2 08:40, 20.42 KB) / 下载次数 2127
http://forums.netpad.net.cn/attachment.php?aid=22669&k=4ac2a1cbe7a7c74011270650d0150dcf&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-2 08:40, 28.63 KB) / 下载次数 2105
http://forums.netpad.net.cn/attachment.php?aid=22670&k=d1f1176ac314eb5c28b73425a9e19317&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-2 08:40, 13.55 KB) / 下载次数 2125
http://forums.netpad.net.cn/attachment.php?aid=22671&k=b2cbc2264fd557817f0fad39597061df&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-2 08:40, 14.07 KB) / 下载次数 2122
http://forums.netpad.net.cn/attachment.php?aid=22672&k=1ccfb734f07adaaaa944495046f74ff6&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-2 08:40, 14.49 KB) / 下载次数 2120
http://forums.netpad.net.cn/attachment.php?aid=22673&k=f61c26d20c7c27c73e0b9465eaab965f&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-2 08:40, 15.64 KB) / 下载次数 2134
http://forums.netpad.net.cn/attachment.php?aid=22674&k=fffe8aea013aae17cc52c80273d14e64&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-2 08:40, 24.58 KB) / 下载次数 2152
http://forums.netpad.net.cn/attachment.php?aid=22675&k=af8bda00a834face65150cd6110ec3b2&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-2 08:40, 24.55 KB) / 下载次数 2104
http://forums.netpad.net.cn/attachment.php?aid=22676&k=2a3ca5b4af0971456aa497ce55afa34a&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-2 08:40, 26.02 KB) / 下载次数 2166
http://forums.netpad.net.cn/attachment.php?aid=22677&k=6ad2b858d19bf2cf80115a65f167c18d&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-2 08:40, 25.72 KB) / 下载次数 2103
http://forums.netpad.net.cn/attachment.php?aid=22678&k=b182dec52607e2dfb2bb00be86d6face&t=1765167857&sid=yYLc25



附件: htm0303.rar (2014-11-2 00:56, 3.93 KB) / 下载次数 3451
http://forums.netpad.net.cn/attachment.php?aid=22679&k=65b41e8f9ab8decd98d9947513300f7d&t=1765167857&sid=yYLc25
作者: 周传高    时间: 2014-11-2 09:49

大赞!

图片附件: FS0013.png (2014-11-8 17:15, 26.03 KB) / 下载次数 1622
http://forums.netpad.net.cn/attachment.php?aid=22745&k=99c02872d2a13a8c09b8a57f8350e816&t=1765167857&sid=yYLc25


作者: lnszdzg    时间: 2014-11-2 12:19

太强大了,喜欢!
作者: xklppp    时间: 2014-11-2 23:05

随着程序功能的增加,要输入的参数会越来越多,对于那些应用于绝大多数或所有状况的参数,可以设计成即时响应;而对于那些只应用于少部份甚至是个别状况的参数,要设计成即时响应一般比较麻烦,所以,我们在窗体中放置了一个刷新reFresh 按钮,以应付这种状况,当改变参数而程序没有反应时,便可点击这个 reFresh 按钮。这样,程序编写起来会简单一些。这一次,我们充实了一下 transPlane 功能模块,由于其方法和 setColor 差不多,这里就不啰嗦了。
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
htm0304.rar (3.79 KB)

图片附件: 1.jpg (2014-11-4 14:42, 14.73 KB) / 下载次数 2156
http://forums.netpad.net.cn/attachment.php?aid=22680&k=c45a50b1a85f847c7975c2e6d8fa9862&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-4 14:42, 17.35 KB) / 下载次数 2160
http://forums.netpad.net.cn/attachment.php?aid=22681&k=94add750a6ce6c8576b6ee1cb8fc2fc9&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-4 14:42, 14.19 KB) / 下载次数 2115
http://forums.netpad.net.cn/attachment.php?aid=22682&k=c4464a0270bd1e0ad598b22dbfc118ae&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-4 14:42, 11.82 KB) / 下载次数 2121
http://forums.netpad.net.cn/attachment.php?aid=22683&k=0b88ddf0f9f443287ef13ccb646a971d&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-4 14:42, 14.29 KB) / 下载次数 2133
http://forums.netpad.net.cn/attachment.php?aid=22684&k=82941d02734402bfff29599971e88b92&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-4 14:42, 13.63 KB) / 下载次数 2125
http://forums.netpad.net.cn/attachment.php?aid=22685&k=5b2af38970b72ef48d3345637b67432d&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-4 14:42, 15.32 KB) / 下载次数 2170
http://forums.netpad.net.cn/attachment.php?aid=22686&k=1572883a2d88800f6843345a344982ab&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-4 14:42, 13.49 KB) / 下载次数 2143
http://forums.netpad.net.cn/attachment.php?aid=22687&k=c6db27871a2e8ab911d43c96128c37c9&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-4 14:42, 17.24 KB) / 下载次数 2125
http://forums.netpad.net.cn/attachment.php?aid=22688&k=330f806ea59923e113ed4dcd42d843ac&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-4 14:42, 16.34 KB) / 下载次数 2174
http://forums.netpad.net.cn/attachment.php?aid=22689&k=e9e04704b1dc12130721f2bf594ae0d4&t=1765167857&sid=yYLc25



附件: htm0304.rar (2014-11-2 23:05, 3.79 KB) / 下载次数 3559
http://forums.netpad.net.cn/attachment.php?aid=22690&k=fd7e7e736f5f5e2c8f2a6e8737c34af5&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-3 23:37

上面在 transPlane 功能模块中添加的都是单一的几何变换,这里再增加四种可以进行组合的稍为复杂一点的变换,不同的组合有 14 种,与前面的 12 种再组合,一共有一百多种,其中有效的组合变换也不下一百种。其实,关于几何变换我真的是不太懂,只是觉得加到程序里面蛮好玩的。尽管如此,程序的结构是没问题的,大家可以把真正意义上的几何变换植入到自己的程序中,免得像我一样让人笑话。
    这一次的代码更加简单,所以代码中没有写注释,相信大家花点时间是能看得懂的。
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
b.jpg
c.jpg
htm0305.rar (4.03 KB)

图片附件: 1.jpg (2014-11-4 14:48, 18.05 KB) / 下载次数 2100
http://forums.netpad.net.cn/attachment.php?aid=22694&k=d75aad4827bca293d454d70fed26f5e0&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-4 14:48, 14.25 KB) / 下载次数 2092
http://forums.netpad.net.cn/attachment.php?aid=22695&k=7f0d0b7cc56ad5f80f6435b1233bd144&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-4 14:48, 18.28 KB) / 下载次数 2088
http://forums.netpad.net.cn/attachment.php?aid=22696&k=c906f204e3c0ca9ce3eca4e3446c0792&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-4 14:48, 13.52 KB) / 下载次数 2112
http://forums.netpad.net.cn/attachment.php?aid=22697&k=2ef89b779dd14927e125bc8214106afc&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-4 14:48, 14.04 KB) / 下载次数 2112
http://forums.netpad.net.cn/attachment.php?aid=22698&k=de7c64934ca662908d0f20a33f3612d8&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-4 14:48, 14.04 KB) / 下载次数 2088
http://forums.netpad.net.cn/attachment.php?aid=22699&k=4b91de3d49aa8870166a7eed3e2c647d&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-4 14:48, 16.33 KB) / 下载次数 2107
http://forums.netpad.net.cn/attachment.php?aid=22700&k=f5dd2971d24b34eac20b3cb7d534607e&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-4 14:48, 21.58 KB) / 下载次数 2128
http://forums.netpad.net.cn/attachment.php?aid=22701&k=63835b4c31b643c441a7aa50b61fe10e&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-4 14:48, 16.81 KB) / 下载次数 2105
http://forums.netpad.net.cn/attachment.php?aid=22702&k=d9c4c42043304847a3204f72a38a7f07&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-4 14:48, 19.4 KB) / 下载次数 2170
http://forums.netpad.net.cn/attachment.php?aid=22703&k=4506175fe0df6105eea44b427c7b09e4&t=1765167857&sid=yYLc25



图片附件: b.jpg (2014-11-4 14:48, 31.99 KB) / 下载次数 2106
http://forums.netpad.net.cn/attachment.php?aid=22704&k=d92bfd649c16268d4ef97b59e1feefe2&t=1765167857&sid=yYLc25



图片附件: c.jpg (2014-11-4 14:48, 22.99 KB) / 下载次数 2102
http://forums.netpad.net.cn/attachment.php?aid=22705&k=427c2a18a5bbbda9b542247906935316&t=1765167857&sid=yYLc25



附件: htm0305.rar (2014-11-3 23:37, 4.03 KB) / 下载次数 3514
http://forums.netpad.net.cn/attachment.php?aid=22706&k=7b6747504e6d17dfde8642a27831ecca&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-4 23:38

如果我们在组合变换的基础上再叠加一次简单变换,将会得到更多的图像,不过这种设计近乎钻牛角尖,所以,尽管编写了代码,这一功能还是少用为宜,因为它是以牺牲速度为代价的。
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
htm0306.rar (4.1 KB)

图片附件: 1.jpg (2014-11-8 14:46, 15.22 KB) / 下载次数 2375
http://forums.netpad.net.cn/attachment.php?aid=22707&k=0c4ccbb1908806c3da4a30344069aba0&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-8 14:46, 15.62 KB) / 下载次数 2394
http://forums.netpad.net.cn/attachment.php?aid=22708&k=081da1f904e5b735f361d65f40f88dd2&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-8 14:46, 18.26 KB) / 下载次数 2359
http://forums.netpad.net.cn/attachment.php?aid=22709&k=5f0fd05ac6338e117140f5bad98845ec&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-8 14:46, 21.98 KB) / 下载次数 2406
http://forums.netpad.net.cn/attachment.php?aid=22710&k=99bdd341949767bf27309671ef340d56&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-8 14:46, 18.96 KB) / 下载次数 2370
http://forums.netpad.net.cn/attachment.php?aid=22711&k=a686d3fc784eeb3b51d8002c988a98cf&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-8 14:46, 25.18 KB) / 下载次数 2352
http://forums.netpad.net.cn/attachment.php?aid=22712&k=a818df4d13d51f7bc99cc65bf72d958e&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-8 14:46, 27.2 KB) / 下载次数 2368
http://forums.netpad.net.cn/attachment.php?aid=22713&k=5119aab73b053c98c0b7a841b00e01e9&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-8 14:46, 30.03 KB) / 下载次数 2372
http://forums.netpad.net.cn/attachment.php?aid=22714&k=c1f65e086e37c63cf1127b5ab0cac4b1&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-8 14:46, 27.01 KB) / 下载次数 2327
http://forums.netpad.net.cn/attachment.php?aid=22715&k=16b56f9dc8e316db1866455a41992a96&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-8 14:46, 19.3 KB) / 下载次数 2380
http://forums.netpad.net.cn/attachment.php?aid=22716&k=ae00e8b8bd314f1db9b873d0e1368e33&t=1765167857&sid=yYLc25



附件: htm0306.rar (2014-11-4 23:38, 4.1 KB) / 下载次数 3701
http://forums.netpad.net.cn/attachment.php?aid=22717&k=7160ab80757e6d0c1dd8eae686cb0682&t=1765167857&sid=yYLc25
作者: wdpfox    时间: 2014-11-5 14:45

下载学习,多谢楼主慷慨分享好资料!
作者: lnszdzg    时间: 2014-11-5 16:16

非常感谢xklppp老师的讲解,虽然对于javascript学习起来很吃力——原先没有接触过——我会慢慢学习。
我把您的思路用UF写出来了——尽管UF是专业的分形软件,但是您实现的功能在UF用一点难度——不知您是否介意我把它贴出来?
作者: lnszdzg    时间: 2014-11-5 16:24

捕获34.PNG 捕获35.PNG 捕获36.PNG 捕获37.PNG

图片附件: 捕获34.PNG (2014-11-5 16:24, 51.97 KB) / 下载次数 2285
http://forums.netpad.net.cn/attachment.php?aid=22718&k=7ee7628e0d1c90d6533ee84d5f1897dd&t=1765167857&sid=yYLc25



图片附件: 捕获35.PNG (2014-11-5 16:24, 30.18 KB) / 下载次数 2052
http://forums.netpad.net.cn/attachment.php?aid=22719&k=dbf6abccf45bb717be234d1f4c8bae3a&t=1765167857&sid=yYLc25



图片附件: 捕获36.PNG (2014-11-5 16:24, 37.92 KB) / 下载次数 2076
http://forums.netpad.net.cn/attachment.php?aid=22720&k=b035772e9a8d0068deb4df11b37e14c5&t=1765167857&sid=yYLc25



图片附件: 捕获37.PNG (2014-11-5 16:24, 39.67 KB) / 下载次数 2066
http://forums.netpad.net.cn/attachment.php?aid=22721&k=24a9d2b2c34f89427db43787366d4fd3&t=1765167857&sid=yYLc25


作者: lnszdzg    时间: 2014-11-5 16:29

New.jpg

图片附件: New.jpg (2014-11-8 14:48, 14.82 KB) / 下载次数 2060
http://forums.netpad.net.cn/attachment.php?aid=22722&k=f87debca357081a79e341d510de4baa9&t=1765167857&sid=yYLc25


作者: xklppp    时间: 2014-11-5 18:21

55# lnszdzg
杜老师好!你是对的,对于软件和语言,每个人都有自己的偏好,要人放弃自己手头上称手的工具而从头再来是件蛮痛苦的事情,几何画板也好,UF,mathCad 也好,vb,vc,c#,javascript 也好,统统都不重要,重要的是使用这些工具时的思维意识和行为模式,这个帖子讨论到这里,程序所具有的功能和效果,用 javascript 实现并非上上之选,但比起其他的算法语言和软件来,javascript 却是最简单最轻松的。不过,这也还不是这个帖子的最终目的,我只是想借 javascript 编写复变分形程序中遇到的一些问题向大家传递一个信息:复变分形在最后图形的渲染上确实有着很多精妙绝伦的手法,产生出令人震撼的视觉冲击。然而,作为初学者,复分形的结构本身才是首先要解决的问题,所以,选择一个恰当的起点和视角是非常必要的。
谢谢杜老师,衷心希望能多贴美图,多提意见。
作者: lnszdzg    时间: 2014-11-6 16:29

谢谢xklppp老师!
感谢您的讲解。虽然只知皮毛,但是我从您的程序中学到了不少东西——最主要的一点事:程序的模块化思想——太精妙了!我把UF的代码发到Mathcad吧里了——没有征求您的意见,不介意吧?
http://tieba.baidu.com/p/3394265041
作者: xklppp    时间: 2014-11-6 17:39

57# lnszdzg
很好啊!说明这个帖子的讨论还是有点价值的,讨论的过程中,我们并没有纠结在编程语言本身上,其目的就是希望大家不要被语言束缚,设计模式才是最重要的。
作者: xklppp    时间: 2014-11-6 17:44

很多的迭代模型需要用到 z,c 以外的参数,所以,窗体中新加了 A,B 相应的输入框,后面的newton,nova 要用到 Q,R,这里预先一并加上。
    迭代模型数组形如:
    var mjModels=[{
    para:[],
    default:"",
    func:function(){}
    }},}
    ......
    }},{
    para:[],
    default:"",
    func:function(){}
    }}];
    较之前面的 mjColoring 和 mjTransForm,这里每个元素多设了一个 default 属性,用来记载那些刁钻的参数值,程序没有给出相应的处理代码(大家可以自己试着开发),只是显示在界面中以作提示之用。
    另外,如果把:
    var iterator=function(x,y,a,b)
    {
        return mjModels[mdx].func(x,y,a,b);
    }
    改成:
    iterator=mjModels[mdx].func
    程序的运行速度要快一些,画布越大效果越明显。由于加入了三十几个迭代模型,代码量急剧增加,不过,核心代码就那么几十行。
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
htm0401.rar (6.49 KB)

图片附件: 1.jpg (2014-11-8 14:53, 13.6 KB) / 下载次数 2444
http://forums.netpad.net.cn/attachment.php?aid=22723&k=f30d57ced2e2dc82143fa4dc1467b21e&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-8 14:53, 20.14 KB) / 下载次数 2393
http://forums.netpad.net.cn/attachment.php?aid=22724&k=2c10cfee34c3c9c8c2d4daff1795a2c1&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-8 14:53, 13.26 KB) / 下载次数 2446
http://forums.netpad.net.cn/attachment.php?aid=22725&k=d8e28df7abb313049a8a18c749f0a8fa&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-8 14:53, 15.85 KB) / 下载次数 2427
http://forums.netpad.net.cn/attachment.php?aid=22726&k=e1288ffd2b07041c1dcbd1d20b3f03fa&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-8 14:53, 15.29 KB) / 下载次数 2404
http://forums.netpad.net.cn/attachment.php?aid=22727&k=c1444bbf116386f7428ba0bf9a109d6b&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-8 14:53, 30.48 KB) / 下载次数 2398
http://forums.netpad.net.cn/attachment.php?aid=22728&k=73d5abdf949fbbf8c5f1975d1f287d8c&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-8 14:53, 13.46 KB) / 下载次数 2427
http://forums.netpad.net.cn/attachment.php?aid=22729&k=687601770ead08b26365146c733a8dde&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-8 14:53, 19.83 KB) / 下载次数 2409
http://forums.netpad.net.cn/attachment.php?aid=22730&k=87c8ee8e080e6181fe21034ecd678ab0&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-8 14:53, 14.36 KB) / 下载次数 2474
http://forums.netpad.net.cn/attachment.php?aid=22731&k=b1edbe3c2b418b23118f137cb9da36f5&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-8 14:53, 27.83 KB) / 下载次数 2430
http://forums.netpad.net.cn/attachment.php?aid=22732&k=6a7c3c85915b7318bd79006c68a07ad4&t=1765167857&sid=yYLc25



附件: htm0401.rar (2014-11-6 17:44, 6.49 KB) / 下载次数 3837
http://forums.netpad.net.cn/attachment.php?aid=22733&k=842c7cb0b710773d42aab6c95ce4b68b&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-8 12:27

基于下面的算法,程序给出了六个 newton 迭代模型:
newton: z=z-R[f(z)+c]/f'(z)
   nova: z=z-R[f(z)/f'(z)]+c
    窗体中增加了一个 newton/nova 切换开关 nt 复选框,迭代模型中的实现代码为:
nTa=nT*a,nTb=nT*b
nVa=(1-nT)*a,nVb=(1-nT)*b
    其中:
nT=1 或 0
    也就是:
z=z-R{[f(z)+(nTa,nTb)]/f'(z)}+(nVa,nVb)
     当 R=(1,0) 时,上式便在标准的 newton 和 nova 之间切换。
     就我本人所知道的有关复变分形的知识,程序已接近尾声,在不影响原结构的基础上对程序代码作了较大幅度的调整。
b.jpg
c.jpg
d.jpg
e.jpg
f.jpg
g.jpg
h.jpg
i.jpg
j.jpg
k.jpg
htm0402.rar (7.29 KB)

图片附件: b.jpg (2014-11-8 14:58, 13.72 KB) / 下载次数 2447
http://forums.netpad.net.cn/attachment.php?aid=22734&k=2f724ef99d4983853b348950780bb478&t=1765167857&sid=yYLc25



图片附件: c.jpg (2014-11-8 14:58, 18.02 KB) / 下载次数 2431
http://forums.netpad.net.cn/attachment.php?aid=22735&k=f5bf2d791cf499003d2ab63a49fd0063&t=1765167857&sid=yYLc25



图片附件: d.jpg (2014-11-8 14:58, 17.19 KB) / 下载次数 2409
http://forums.netpad.net.cn/attachment.php?aid=22736&k=46192b04f8035f40a3b93ef7c014a329&t=1765167857&sid=yYLc25



图片附件: e.jpg (2014-11-8 14:58, 16.09 KB) / 下载次数 2423
http://forums.netpad.net.cn/attachment.php?aid=22737&k=710a3f283a68e8977a2116f046afbace&t=1765167857&sid=yYLc25



图片附件: f.jpg (2014-11-8 14:58, 14.88 KB) / 下载次数 2397
http://forums.netpad.net.cn/attachment.php?aid=22738&k=1c4132df7eb9b4cdc1de865ce229a1bb&t=1765167857&sid=yYLc25



图片附件: g.jpg (2014-11-8 14:58, 22.8 KB) / 下载次数 2448
http://forums.netpad.net.cn/attachment.php?aid=22739&k=554cc0b7abb3217d15570164ca381902&t=1765167857&sid=yYLc25



图片附件: h.jpg (2014-11-8 14:58, 19.46 KB) / 下载次数 2418
http://forums.netpad.net.cn/attachment.php?aid=22740&k=4352a5bce1ae2fdb53083b1ebf9db126&t=1765167857&sid=yYLc25



图片附件: i.jpg (2014-11-8 14:58, 17.19 KB) / 下载次数 2427
http://forums.netpad.net.cn/attachment.php?aid=22741&k=534389b5f3088c2e967b464fbdd234a3&t=1765167857&sid=yYLc25



图片附件: j.jpg (2014-11-8 14:58, 16.97 KB) / 下载次数 2402
http://forums.netpad.net.cn/attachment.php?aid=22742&k=480c1b65c61acdfa8cb31711a81ffa6b&t=1765167857&sid=yYLc25



图片附件: k.jpg (2014-11-8 14:58, 22.84 KB) / 下载次数 2451
http://forums.netpad.net.cn/attachment.php?aid=22743&k=cd835c5e54ae0d3cfcc73b6f82da9845&t=1765167857&sid=yYLc25



附件: htm0402.rar (2014-11-8 12:27, 7.29 KB) / 下载次数 3737
http://forums.netpad.net.cn/attachment.php?aid=22744&k=c7c8f30b14a95477489ca2675fc7ae2a&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-8 23:33

如果算法改成:
newton: z=R{z-[f(z)+c]/f'(z)}
   nova: z=R{z-[f(z)/f'(z)]}+c
M 集变得疯狂起来,J 集则更加繁复:
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
接下来就是在程序中增加 julia 粒子模块,代码稍为艰难一点,所以,我们的讨论将暂告一段落,稍停一会,祝大家学习愉快!
htm0403.rar (7.31 KB)

图片附件: 1.jpg (2014-11-13 13:32, 29.95 KB) / 下载次数 1949
http://forums.netpad.net.cn/attachment.php?aid=22746&k=8160fd6d4b8e008cfb05ee09425879f0&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-13 13:32, 23.53 KB) / 下载次数 1967
http://forums.netpad.net.cn/attachment.php?aid=22747&k=04a5213747ddbddcb591a51c985c4359&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-13 13:32, 27.76 KB) / 下载次数 1935
http://forums.netpad.net.cn/attachment.php?aid=22748&k=8034e022eb2ac39adc0c7281fe370462&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-13 13:32, 22.89 KB) / 下载次数 1940
http://forums.netpad.net.cn/attachment.php?aid=22749&k=f96bd4220919a54245475c35b597cd41&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-13 13:32, 25.8 KB) / 下载次数 1940
http://forums.netpad.net.cn/attachment.php?aid=22750&k=aba58a76b4c1aef1ea9dc36cca61d7fe&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-13 13:32, 26.35 KB) / 下载次数 1914
http://forums.netpad.net.cn/attachment.php?aid=22751&k=e62e13010e28c1d1cc1596ee041ccfc0&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-13 13:32, 32.68 KB) / 下载次数 1903
http://forums.netpad.net.cn/attachment.php?aid=22752&k=2ed4bcb48a599863f50ad96662e3ac44&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-13 13:32, 25.45 KB) / 下载次数 1925
http://forums.netpad.net.cn/attachment.php?aid=22753&k=8aed40bd654b013334789f7022a3b0cf&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-13 13:32, 23.19 KB) / 下载次数 1997
http://forums.netpad.net.cn/attachment.php?aid=22754&k=0d063c1286a68bb1b22352b6a0d31051&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-13 13:32, 36.14 KB) / 下载次数 1977
http://forums.netpad.net.cn/attachment.php?aid=22755&k=de6322a12982766fe9ed62fffa183441&t=1765167857&sid=yYLc25



附件: htm0403.rar (2014-11-8 23:33, 7.31 KB) / 下载次数 3715
http://forums.netpad.net.cn/attachment.php?aid=22756&k=4e05113003305be783a143d98191f7bc&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-13 13:14

前面发过一个题为“逝去的美丽_朱丽娅粒子”的帖子,之所以说是“逝去的美丽”,是因为人们通常是在给定阈值的前提下,欣赏其临界点整个参数平面内 Mandbrot 集和 Julia 集的最终结构,然而,在形成这种最终结构之前,迭代模型的迭代轨迹却被人们忽视,这种迭代轨迹,就像流星的轨迹一样,消失在过去的时光里,如果换个角度去观察它,我们会发现,它是非常绚丽多姿的。
    这里所说的轨迹并非横向的而是纵向的:迭代模型中,e 数组记录下了某一特定点经过迭代而产生的一组数据,这一组数据所表示的轨迹,是为横向轨迹,暂且把它叫做 julia 粒子,而平面内某一路径上所有点的 julia 粒子的集合,我们称之为纵向轨迹,或者说是 julia 粒子系统。(我不懂专业,这里的用辞纯属杜撰,能说明白就好)
    为简单见,特归纳如下:

    Mandbrot 集:c 变 z 不变,扫描二维平面
       Julia 集:z 变 c 不变,扫描二维平面
     Julia 粒子:z,c 同时变,扫描一维路径

    程序中所使用的路径是两点间的线段,如果用曲线路径,代码会更加复杂。
    依上所述,程序在窗体中加入了一个用来输入两点坐标和显示路径的画布 lCanvas,一个用来显示 julia 粒子的画布 pCanvas,以及 Pt(Et倍数)、Lw(线宽)、Ps(路径上的扫描点数)等参数输入框。
    路径参数的输入与 29 楼的万花曲线规相同,至于算法,代码并不复杂,只是多了一个动画效果,相信大家花点时间是不会有什么困难的。
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
    为什么叫“julia 粒子”而不叫“mandbrot 粒子”呢?我们将在接下来的也是最后的一节中讨论“julia 图谱”时再详细说明。
htm0502.rar (8.47 KB)

图片附件: 1.jpg (2014-11-13 13:38, 18.98 KB) / 下载次数 1940
http://forums.netpad.net.cn/attachment.php?aid=22760&k=56165a94cd4cb25e47b09a16c159989d&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-13 13:38, 19.39 KB) / 下载次数 1940
http://forums.netpad.net.cn/attachment.php?aid=22761&k=79143debecd9ce620e9560352bd0ca81&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-13 13:38, 19 KB) / 下载次数 1937
http://forums.netpad.net.cn/attachment.php?aid=22762&k=2b864ad9c1fd32b5d4e1074cac656f8f&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-13 13:38, 18.97 KB) / 下载次数 1959
http://forums.netpad.net.cn/attachment.php?aid=22763&k=476861f649e84740d246eb01462bcb95&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-13 13:38, 19.49 KB) / 下载次数 1940
http://forums.netpad.net.cn/attachment.php?aid=22764&k=7ef832e8cdc21c6cede08951e0cca14b&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-13 13:38, 20.59 KB) / 下载次数 1969
http://forums.netpad.net.cn/attachment.php?aid=22765&k=c927b7f0357b8ba4ed38da4808ce0f79&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-13 13:38, 19.93 KB) / 下载次数 1901
http://forums.netpad.net.cn/attachment.php?aid=22766&k=e5d107ab9ae8645e726f52c85244509b&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-13 13:38, 19.37 KB) / 下载次数 1919
http://forums.netpad.net.cn/attachment.php?aid=22767&k=10170606c2223070ac68596734d71689&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-13 13:38, 18.95 KB) / 下载次数 1915
http://forums.netpad.net.cn/attachment.php?aid=22768&k=c8bc92c3df83862b58e65acf315cfdd7&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-13 13:38, 20.16 KB) / 下载次数 1918
http://forums.netpad.net.cn/attachment.php?aid=22769&k=a6ab18af70efaf0997930ae6fbd2b1eb&t=1765167857&sid=yYLc25



附件: htm0502.rar (2014-11-13 13:14, 8.47 KB) / 下载次数 3710
http://forums.netpad.net.cn/attachment.php?aid=22770&k=d47acc69c12bac132d4f280b70c8dd60&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-14 00:11

很多文章都有讨论 julia 集和 mandbrot 集的关系,如:
    mandbrot 集是 julia 集字典;
    mandbrot 集是 julia 集缩略图;
    mandbrot 集是 julia 集特征集;
    mandbrot 集是宏观布局,julia 集是微观结构;
    基于上术理由,我们就把形成结构前迭代轨迹中的所有点称之为 julia 粒子。
    既然 mandbrot 集中的每一个点都是 julia 集,那么,我们可以这样理解:mandbrot 集是 c 平面的分辨率达到极限时 julia 集的集合,而每一个 julia 集则是在点平面 z 上的扫描图像。程序中,c 平面被映射到 720*480 的画布,被分成 720*480 个点,这时 c 平面的分辨率达到极限,我们看到的每一个 julia 集就是一个点了。
    如果 c 平面的概念分辨率为 10*10,我们反过来将画布映射到 c 平面,那么,画布便被分割成 10*10 个小平面,尽管小,但每个平面包含有 72*48 个像素,比点平面大多了,当然,相应的 julia 集也就能显示其结构了。这样我们便得到了特定分辨率下的 julia 集图谱!
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
好了,程序写到这里,基本的功能模块都有了,由于 html5 还在开发完善中,.hta 格式的应用程序暂时还未能支持 canvas 画布。剩下的就是图像的渲染,如:陷阱、场线、光照、山水……等等,老师们都是高手,我可是江郎才尽了。真心的祝愿各位老师早日开发出自己的分形软件。
htm0503.rar (8.81 KB)

图片附件: 1.jpg (2014-11-14 11:51, 29.57 KB) / 下载次数 1951
http://forums.netpad.net.cn/attachment.php?aid=22772&k=c814ed982e23f8cb4f262ca98a3d222f&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-14 11:51, 31.62 KB) / 下载次数 1953
http://forums.netpad.net.cn/attachment.php?aid=22773&k=548eaf2971d2fed6ef629b9fcca5d6ce&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-14 11:51, 31.7 KB) / 下载次数 1927
http://forums.netpad.net.cn/attachment.php?aid=22774&k=57d9823e43e7e2296a47c6e0481d01f9&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-14 11:51, 30.7 KB) / 下载次数 1974
http://forums.netpad.net.cn/attachment.php?aid=22775&k=e6d4f7b263cd5329795c205d02a8e6a7&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-14 11:51, 29.8 KB) / 下载次数 1928
http://forums.netpad.net.cn/attachment.php?aid=22776&k=40fc5a6073217c9bb58b297ba539e37d&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-14 11:51, 28.69 KB) / 下载次数 1927
http://forums.netpad.net.cn/attachment.php?aid=22777&k=50ae3e88cb1af356a5ebfd2e75979350&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-14 11:51, 29.76 KB) / 下载次数 1952
http://forums.netpad.net.cn/attachment.php?aid=22778&k=7fbdfcdb0f806fd1fbb2525411671e38&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-14 11:51, 25.67 KB) / 下载次数 1938
http://forums.netpad.net.cn/attachment.php?aid=22779&k=3820fea17ba98bb1630dd06b0ba08900&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-14 11:51, 25.16 KB) / 下载次数 1951
http://forums.netpad.net.cn/attachment.php?aid=22780&k=4a81f60d57682c9b8e7ff42a208e13fd&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-14 11:51, 21.67 KB) / 下载次数 1948
http://forums.netpad.net.cn/attachment.php?aid=22781&k=47a909aab2e4197bb5df8092327dc761&t=1765167857&sid=yYLc25



附件: htm0503.rar (2014-11-14 00:11, 8.81 KB) / 下载次数 3677
http://forums.netpad.net.cn/attachment.php?aid=22782&k=a950367a24e8f81acb1682d950ddfe7e&t=1765167857&sid=yYLc25
作者: lnszdzg    时间: 2014-11-14 21:14

xklppp老师:感谢您的精彩!
julia 集图谱的问题我们在
http://tieba.baidu.com/p/3403532327
讨论过,月城已经做得很好了。我也弄了一个,献丑!
捕获201.PNG

图片附件: 捕获201.PNG (2014-11-14 21:14, 49.24 KB) / 下载次数 1569
http://forums.netpad.net.cn/attachment.php?aid=22784&k=326b8ab677d80fb513bf323f609f32b1&t=1765167857&sid=yYLc25


作者: lnszdzg    时间: 2014-11-14 21:16

另外,受您的启发,对于模块化的思路,进行了探索!
http://tieba.baidu.com/p/3394265041
http://tieba.baidu.com/p/3407246514
作者: xklppp    时间: 2014-11-14 23:50

谢谢推荐那么精彩的帖子,拜读了,以杜老师现在的水平,作个分形软件是没问题的。因我对分形知识的了解非常有限,所以,这个帖子只能就编程谈些粗浅的看法,虽不能在软件开发方面作更广和更深的展开,如能给大家带来一星半点的帮助,也就非常满足了。学习是相互的,一齐努力吧!!!
作者: dtt    时间: 2014-11-15 11:41

http://pan.baidu.com/s/1pJI6NOJ

加入本论坛后一直在默默地向诸位老师学习。十分敬佩各位老师的无私奉献和诲人不倦的品德,十分感谢各位老师。
xklppp老师,做人、做事都值得我学习。拿出这样高水平的文章飨后学者,使后来者不至于再在黑暗中摸索,十分感谢。我一定会好好钻研的。
我的画板尚在上不了台面的水平,还不能有像样的东西交流。
现把我随本帖的进展积集的关于本专题的Word2003的doc文件上传,方便学习。算是对本论坛做点有益的事情。同时,以此表达我对xklppp老师和本论坛诸位老师的敬意。
作者: xiaongxp    时间: 2014-11-15 12:30

精彩!深受启发

      感谢分享,要完全吃透,容我慢慢消化。
      得益于xklppp老师在本贴63#的精彩阐述,对http://www.inrm3d.cn/viewthread.php?tid=1386&page=73#pid41923发表的gsp文件进行了关键修改,使功能得到了完善,分享于下:
Julius Ruis Set.jpg

图片附件: Julius Ruis Set.jpg (2014-11-15 20:19, 91.32 KB) / 下载次数 1541
http://forums.netpad.net.cn/attachment.php?aid=22785&k=ef63fa7581f3f9496fe30983b596450f&t=1765167857&sid=yYLc25



附件: [1.拖动红三角形框选要放大的J集,并呈现于附窗 2.当“J集密度k”足够大时,可在附窗呈现任意位置的J集 ...] Julius Ruis Set.gsp (2014-11-15 20:19, 26.91 KB) / 下载次数 2213
http://forums.netpad.net.cn/attachment.php?aid=22786&k=a80a1ddba2e9f2faa32b91bb7d6292f2&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-15 17:25

老港老师的画板技术已是登峰造极,别说是我们,就是画板的作者,都应该向您致敬!再次谢谢老师们对本贴的支持!!!
    从上面的讨论可以看出:就 julia 集和 mandbrot 集的关系来说,mandbrot 集承载的是宏观体系,而 julia 集则蕴涵的是微观结构,这就好像现实世界的整个宇宙天体和物质粒子一样,所以,当我们在缩放 mandbrot 集时,实际上是用天文望远镜或宇宙飞船在观察广袤的宏观宇宙,而缩放 julia 集就好像是用电子显微镜或纳米机器人在探索深邃的微观粒子。
    然而,大家知道,宇宙中是存在着黑洞的。对于 mandbrot 集来说,如果是在标准的 c 平面上,虽然多有黑黑的大块,也还不至于有什么特别的感觉,但是,c 平面一经扭曲变形,情形就不同了。比方说:1/c 平面,所有的图像都被黑色包围。如果宇宙中的某个黑洞也这样翻转过来,不知道是个什么样的场景,应该是很恐怖的。
    于是,我们在常规的迭代模型中加入一个类似于 newton 迭代算法中的收敛性监察代码,当迭代轨迹中的前后两点的变化小于给定的阈值,则停止迭代,使得那些令人迷茫的黑洞变得光亮起来:
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
htm0504.rar (9.16 KB)

图片附件: 1.jpg (2014-11-15 19:54, 15.07 KB) / 下载次数 1926
http://forums.netpad.net.cn/attachment.php?aid=22787&k=b7e779eca10629493448f7051ce79d9f&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-15 19:54, 20.53 KB) / 下载次数 1943
http://forums.netpad.net.cn/attachment.php?aid=22788&k=4d5e43723cf3ac8691f14da08c358add&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-15 19:54, 22.38 KB) / 下载次数 1951
http://forums.netpad.net.cn/attachment.php?aid=22789&k=fdbe315f1bfbd496ea7159036a473af7&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-15 19:54, 22.37 KB) / 下载次数 1955
http://forums.netpad.net.cn/attachment.php?aid=22790&k=e6a272974bad471e9b9a1bce816b711f&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-15 19:54, 18.42 KB) / 下载次数 1986
http://forums.netpad.net.cn/attachment.php?aid=22791&k=bff31eaeea4961615b78cc8fcb65d08b&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-15 19:54, 27.24 KB) / 下载次数 1992
http://forums.netpad.net.cn/attachment.php?aid=22792&k=0746be02b6cdf8966af65ea28fe67aec&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-15 19:54, 23.32 KB) / 下载次数 1943
http://forums.netpad.net.cn/attachment.php?aid=22793&k=79027a76d4b4d77838930c3f773ba265&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-15 19:54, 14.29 KB) / 下载次数 1966
http://forums.netpad.net.cn/attachment.php?aid=22794&k=8f12b0eb7e3f9a247061cff73740e132&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-15 19:54, 13.32 KB) / 下载次数 1936
http://forums.netpad.net.cn/attachment.php?aid=22795&k=54a6f322b8680cb14d7ce7dec59bfe3b&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-15 19:54, 15.06 KB) / 下载次数 1940
http://forums.netpad.net.cn/attachment.php?aid=22796&k=bccd71a6dfe22861ef5006b347d5868e&t=1765167857&sid=yYLc25



附件: htm0504.rar (2014-11-15 17:25, 9.16 KB) / 下载次数 3781
http://forums.netpad.net.cn/attachment.php?aid=22797&k=add6cbdce017419b52070e64de068ba1&t=1765167857&sid=yYLc25
作者: lnszdzg    时间: 2014-11-15 21:03

69# xklppp

收获不小啊!
向老师也来了,希望肖老师继续,一定会有更大的成果的!
作者: lnszdzg    时间: 2014-11-15 21:06

68# xiaongxp

向老师,好久不见了哈
作者: xklppp    时间: 2014-11-15 21:41

70# lnszdzg


    多谢鼓励,老师们的垂青令我汗颜,特别是月城老师,真是个有心人,不胜惶恐。程序写到 julia 图谱,我真的是黔驴技穷了。
    下午在网上看到老外的两个分形:
    lemon:cz^2(z^2+1)/(z^2-1)^2.....http://paulbourke.net/fractals/lemon/
    Guitar:(z^2+z)/(2z^2+c)..........http://paulbourke.net/fractals/guitar/
    摸索了半天,才意识到了 mandbrot 集里面的“黑洞”问题。
作者: xiaongxp    时间: 2014-11-15 23:23

71# lnszdzg
杜老师好。其实我天天都在关注本贴的进展和您及月城在MC贴吧的讨论,只不过我常用手机上网学习而已,每天登录画板论坛和MC吧已成为我的生活习惯。您们的精彩努力常常让我心动,让我不止一次地开始动手学习javascript和MC,可是刚一下手又望而却步了,不知为什么我的大脑总是那么排斥新知,学不进去。不得不承认,自己的思维老化了,人也懒惰起来了。不过在此当个看官,静静地欣赏大家的聪明才智,也是相当过瘾的。
作者: 柳烟    时间: 2014-11-16 00:19

我和向老师差不多,新东西不太装得进去了,佩服二位老师的钻研精神与精湛技术,将分形不断推向高峰。学习了,问好各位。
作者: lnszdzg    时间: 2014-11-16 22:26

向老师、柳老师:
其实MC学起来比较容易,它的语法很像UF,我想二位老师如果学的话应该比较快。
最近一直关注xklppp老师的文章,虽然javascript学起来很难(我的感觉哈),但是xklppp老师的思想和方法却使我受益匪浅啊!
作者: xiaongxp    时间: 2014-11-17 18:47

用仿射变换在正十二面体的各面贴上不同的J集
正十二面体与J集.jpg
正十二面体与J集.gsp (28.03 KB)

图片附件: 正十二面体与J集.jpg (2014-11-17 18:49, 29.34 KB) / 下载次数 2150
http://forums.netpad.net.cn/attachment.php?aid=22801&k=bed387066650d8ab01413a2f2554e42a&t=1765167857&sid=yYLc25



附件: 正十二面体与J集.gsp (2014-11-17 18:47, 28.03 KB) / 下载次数 3108
http://forums.netpad.net.cn/attachment.php?aid=22802&k=947ccc73fe249050a493c052c1012632&t=1765167857&sid=yYLc25
作者: xiaongxp    时间: 2014-11-17 22:28

正十二面体与M&J集.jpg
正十二面体与M&J集.gsp (28.14 KB)

图片附件: 正十二面体与M&J集.jpg (2014-11-17 22:28, 29.28 KB) / 下载次数 2145
http://forums.netpad.net.cn/attachment.php?aid=22803&k=c73aad5bb3fad199fcb377eb7707e60d&t=1765167857&sid=yYLc25



附件: 正十二面体与M&J集.gsp (2014-11-17 22:28, 28.14 KB) / 下载次数 3222
http://forums.netpad.net.cn/attachment.php?aid=22804&k=b4323639845b8015d4bf57bc1c52923f&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-19 22:40

复变分形的着色算法对于我来说是个新的课题,前面的程序虽给出了一些代码,是因为编程的需要,都不成熟,甚至有点乱,老师们的那些高端算法,我暂时还不能企及,只能从最基本的开始学习,考虑到还有很多和我一样的初学者,所以,在学习过程中,一有心得,便与大家交流,还望各位老师不吝赐教!
    下面是“逃逸角度”着色算法:(不知道专业上怎么说,只能杜撰了)
    func:function(e)
    {
        var et=e.length-1,ex=e[et].x,ey=e[et].y;
        var co=color[fc].concat(255);
        if(et%eT)
        {
            var sa=sqrt(abs(arct(ey,ex)/pi));
            var ca=sqrt(abs(arct(ex,ey)/pi));
            co[0]=255*sin(sa);            //r 通道
            co[1]=255*sin(ca);            //g 通道
            co[2]=255*sin(sa)*sin(ca);    //b 通道
            co[3]=255*sqrt(et/eT);    //逃逸时间映射 alpha 通道
        }
        return co;
    }
    改变 r、g、b 三个通道的函数模型便得到很多的着色效果:
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg

图片附件: 1.jpg (2014-11-19 23:12, 11.66 KB) / 下载次数 2669
http://forums.netpad.net.cn/attachment.php?aid=22808&k=a666d5617cdccac2e40a4098cb7fc084&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-19 23:12, 12.29 KB) / 下载次数 2635
http://forums.netpad.net.cn/attachment.php?aid=22809&k=4ff9d6b52bd13e41d863b30bfccf9723&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-19 23:12, 10.04 KB) / 下载次数 2640
http://forums.netpad.net.cn/attachment.php?aid=22810&k=79355276b0278ed855f4efa342d7c366&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-19 23:12, 9.79 KB) / 下载次数 2643
http://forums.netpad.net.cn/attachment.php?aid=22811&k=fad73a094c76270bbb3d0d79cf15fc6a&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-19 23:12, 12 KB) / 下载次数 2617
http://forums.netpad.net.cn/attachment.php?aid=22812&k=3f2b345214f7c942fc6468ef1e831010&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-19 23:12, 11.91 KB) / 下载次数 2676
http://forums.netpad.net.cn/attachment.php?aid=22813&k=8aa54df4bc2893b457bd38dc16aba25c&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-19 23:12, 9.78 KB) / 下载次数 2657
http://forums.netpad.net.cn/attachment.php?aid=22814&k=be992b0812ab35fc94b6e7a97ccea4ba&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-19 23:12, 9.86 KB) / 下载次数 2697
http://forums.netpad.net.cn/attachment.php?aid=22815&k=ba9bd9716169b69b8a57ed2fef5d2540&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-19 23:12, 10.51 KB) / 下载次数 2621
http://forums.netpad.net.cn/attachment.php?aid=22816&k=baf9b1f79c6eaee04b1962be36a4e9a9&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-19 23:12, 10.75 KB) / 下载次数 2608
http://forums.netpad.net.cn/attachment.php?aid=22817&k=eda33b4ecc58b694edc93f08b11c2fd4&t=1765167857&sid=yYLc25


作者: xiaongxp    时间: 2014-11-19 23:25

复变分形的着色算法对于我来说是个新的课题,前面的程序虽给出了一些代码,是因为编程的需要,都不成熟,甚至有点乱,老师们的那些高端算法,我暂时还不能企及,必须从最基本的开始学习,考虑到还有很多和我一样的初 ...
xklppp 发表于 2014-11-19 22:40
此文曾使我很受益,xklppp老师去访访吧:
http://blog.csdn.net/housisong/article/details/6159317
作者: xklppp    时间: 2014-11-19 23:30

79# xiaongxp
谢了!!!
作者: xklppp    时间: 2014-11-23 16:25

尽管这里的着色算法很幼稚,但从编程的角度来看,对于初学者而言,却是有着很多的问题需要思考:
    1.复分形的着色可以从逃逸时间、逃逸方向、逃逸距离等几方面来考虑。
    2.最简单的可以使用指定的调色板或三角函数来描述色彩的变化。
    3.可以使用插值的方法(例如:势函数 potential function)来平滑较大的色差。
    4.可以考虑内部着不着色。
    如是,我们把前面的着色模块整合成 5 个,并在窗体中增加相应的参数控制,这样,可以产生很多的着色效果:
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
html0602.rar (9.37 KB)

图片附件: 1.jpg (2014-11-23 16:52, 17.45 KB) / 下载次数 4883
http://forums.netpad.net.cn/attachment.php?aid=22826&k=b9e1bb5ca8f78b9674625a8dfa1f798e&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-23 16:52, 16.1 KB) / 下载次数 4837
http://forums.netpad.net.cn/attachment.php?aid=22827&k=6e18062176e5f994225297a17f3cf96a&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-23 16:52, 18.42 KB) / 下载次数 4849
http://forums.netpad.net.cn/attachment.php?aid=22828&k=a7cd4408843ba1f52a88c4135483b254&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-23 16:52, 18.55 KB) / 下载次数 4886
http://forums.netpad.net.cn/attachment.php?aid=22829&k=ff0c32eed44ab38aed1045c13ec48b89&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-23 16:52, 14.62 KB) / 下载次数 4925
http://forums.netpad.net.cn/attachment.php?aid=22830&k=824507e52ff3396bf43ce7a8d3a0e885&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-23 16:52, 18.67 KB) / 下载次数 4896
http://forums.netpad.net.cn/attachment.php?aid=22831&k=1a3125336dd8369e7ee943f2ffb4d879&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-11-23 16:52, 18.52 KB) / 下载次数 4937
http://forums.netpad.net.cn/attachment.php?aid=22832&k=9f62597d76f7670188cb02f80813386a&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-11-23 16:52, 18.71 KB) / 下载次数 4848
http://forums.netpad.net.cn/attachment.php?aid=22833&k=ddb4511d335bfe4a035e65b89e76247c&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-11-23 16:52, 19.21 KB) / 下载次数 4889
http://forums.netpad.net.cn/attachment.php?aid=22834&k=7f0971e0a3bb3a743a90c217fefca065&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-11-23 16:52, 18.42 KB) / 下载次数 4910
http://forums.netpad.net.cn/attachment.php?aid=22835&k=41ee7acf71d49ad667df0ccd40f0f8b3&t=1765167857&sid=yYLc25



附件: html0602.rar (2014-11-23 16:25, 9.37 KB) / 下载次数 6563
http://forums.netpad.net.cn/attachment.php?aid=22836&k=7b0f1fb4029a10689f9490cfdf8dd573&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-26 00:01

轨迹陷阱虽然在一定程度上模糊了迭代模型的微观结构,但这种渲染手法产生的视觉效果颇具审美价值。接下来便试着跟各位老师学习,下面是学着杜老师的
http://tieba.baidu.com/p/3421300726
因暂时还吃不透,所以,算法的解析度较高,代码还不便于一般化,窗体的控制面板有点乱。请老师们指正:
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
html0603.rar (9.65 KB)

图片附件: 1.jpg (2014-11-26 08:26, 15.25 KB) / 下载次数 4862
http://forums.netpad.net.cn/attachment.php?aid=22844&k=d78bc327f3222c8841ec2f65a0765e1b&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-26 08:26, 23.22 KB) / 下载次数 4965
http://forums.netpad.net.cn/attachment.php?aid=22845&k=f30bd029719e2a7c2d42023254e1ca0f&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-26 08:26, 22.2 KB) / 下载次数 4915
http://forums.netpad.net.cn/attachment.php?aid=22846&k=7db8491208a8dff86e6b2c7f42869160&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-26 08:26, 24.24 KB) / 下载次数 4919
http://forums.netpad.net.cn/attachment.php?aid=22847&k=a7dc9b68a31ab9e6f3e02bea7ec838a9&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-11-26 08:26, 30.22 KB) / 下载次数 4945
http://forums.netpad.net.cn/attachment.php?aid=22852&k=cced810b1a7ef07db025aa66fc262da0&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-11-26 08:26, 29.42 KB) / 下载次数 4857
http://forums.netpad.net.cn/attachment.php?aid=22853&k=fb89ff136fd78059665a5fd901f1af7e&t=1765167857&sid=yYLc25



附件: html0603.rar (2014-11-26 01:26, 9.65 KB) / 下载次数 6945
http://forums.netpad.net.cn/attachment.php?aid=22854&k=d6c7bca40df9314919a2158f91e6f3c4&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-11-26 09:32

如果从上到下只扫描复平面的一半,将图像反射到另一半,加上一张合适的背景,便可制作倒影了,但由于这种轨迹陷阱的渲染色彩缺少质感,所以效果不太好。不过,这却给我们提供了一个方向,如果能有较好的材质算法,当能制作出相当不错的渲染图。
1.jpg
2.jpg
3.jpg
4.jpg
html0604.rar (9.73 KB)

图片附件: 1.jpg (2014-11-26 11:34, 14.82 KB) / 下载次数 4874
http://forums.netpad.net.cn/attachment.php?aid=22855&k=1d5da2910e4601d78a50b7e5c19127d2&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-11-26 11:34, 18.36 KB) / 下载次数 4902
http://forums.netpad.net.cn/attachment.php?aid=22856&k=46bf0fbbb6e7178f99d941cdf28346d9&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-11-26 11:34, 21.34 KB) / 下载次数 4878
http://forums.netpad.net.cn/attachment.php?aid=22857&k=3373bb761864fce183d0d05eb3390435&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-11-26 11:34, 20.13 KB) / 下载次数 4892
http://forums.netpad.net.cn/attachment.php?aid=22858&k=7f828ab5264d06c8070e42168d05a6f7&t=1765167857&sid=yYLc25



附件: html0604.rar (2014-11-26 09:32, 9.73 KB) / 下载次数 6840
http://forums.netpad.net.cn/attachment.php?aid=22859&k=0127425876e882a62d4fad277426b201&t=1765167857&sid=yYLc25
作者: inRm    时间: 2014-11-26 11:35

衬一幅图片反而难看了
作者: xklppp    时间: 2014-11-26 12:27

84# inRm
是啊!作法还不成熟,谢谢!!!
作者: lnszdzg    时间: 2014-11-26 16:21

捕获203.PNG

图片附件: 捕获203.PNG (2014-11-26 16:21, 25.23 KB) / 下载次数 4544
http://forums.netpad.net.cn/attachment.php?aid=22861&k=4185a281ae7a00741dc8bd080cb58685&t=1765167857&sid=yYLc25


作者: lnszdzg    时间: 2014-11-26 16:24

xklppp老师:感谢您精彩的文章。
对于陷阱,我也是跟着论坛中的老师学的,原理我还讲不好,这个是Mathcad中的一个陷阱模块,您看看,也许有用。
作者: lnszdzg    时间: 2014-11-26 16:28

捕获204.PNG

图片附件: 捕获204.PNG (2014-11-26 16:28, 40.78 KB) / 下载次数 4549
http://forums.netpad.net.cn/attachment.php?aid=22862&k=502f3a242b156bed63408700ddc03229&t=1765167857&sid=yYLc25


作者: lnszdzg    时间: 2014-11-26 16:33

无标题205.png
这是绘图模块
http://tieba.baidu.com/p/3407246514

图片附件: 无标题205.png (2014-11-26 16:33, 80.67 KB) / 下载次数 4964
http://forums.netpad.net.cn/attachment.php?aid=22863&k=72b3bad388803b0523ff71943fe4915e&t=1765167857&sid=yYLc25


作者: xklppp    时间: 2014-11-26 16:36

88# lnszdzg
太感谢了,但愿能成,谢谢杜老师!!!
作者: lnszdzg    时间: 2014-11-26 16:42

http://tieba.baidu.com/p/3018062730?pn=4
作者: xklppp    时间: 2014-11-26 17:03

91# lnszdzg
太利害了,现在哪敢想那么远啊,我得慢慢来,很庆幸认识各位老师,谢谢!!!
作者: xklppp    时间: 2014-11-30 01:17

想弄玉石效果,但还没找到解决方案。
1.jpg
2.jpg
3.jpg
4.jpg

图片附件: 1.jpg (2014-12-2 15:51, 54.88 KB) / 下载次数 2238
http://forums.netpad.net.cn/attachment.php?aid=22873&k=b834dee7a55c71c0f28c92aaffbea9d1&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-12-2 15:51, 53.47 KB) / 下载次数 2196
http://forums.netpad.net.cn/attachment.php?aid=22874&k=d0b27216407573c0ba02024a82e14e47&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-12-2 15:51, 58.27 KB) / 下载次数 2245
http://forums.netpad.net.cn/attachment.php?aid=22875&k=96237faf6801d01327e027d7c37eaa08&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-12-2 15:51, 53.68 KB) / 下载次数 2212
http://forums.netpad.net.cn/attachment.php?aid=22876&k=eb69bbd9f8f8d6da127e31eafba684fd&t=1765167857&sid=yYLc25


作者: changxde    时间: 2014-12-1 08:33

还是JS功能强大,上面第三幅图画板是不敢想的,但HTML应该是很简单的。
作者: xklppp    时间: 2014-12-1 23:51

谢谢杜老师!杜老师在86楼给出了10个简单陷阱的算法和数据,我们直接将其移植到程序中,如是,代码中便可以增加一个陷阱模块,相应的着色模块中根据各自的喜好可以加入不同的着色算法。程序写到现在,窗体中的参数面板已是拥挤不堪,再往下走的话,需要重新设计。对于陷阱,我现在还没有概念,所以,这里只给出了四个:
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg
b.jpg
c.jpg
d.jpg
e.jpg
html0606.rar (10.08 KB)

图片附件: 5.jpg (2014-12-2 15:55, 19.66 KB) / 下载次数 2000
http://forums.netpad.net.cn/attachment.php?aid=22887&k=921adb7c25444fca9d91a63351f8af05&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-12-2 15:55, 23.07 KB) / 下载次数 2021
http://forums.netpad.net.cn/attachment.php?aid=22888&k=ec619b2f239c8f24a5a746b726801097&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-12-2 15:55, 24.1 KB) / 下载次数 2031
http://forums.netpad.net.cn/attachment.php?aid=22889&k=f3005965b1827faca98f4bf91f89079d&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-12-2 15:55, 22.85 KB) / 下载次数 2014
http://forums.netpad.net.cn/attachment.php?aid=22890&k=aa2850f7cc721b644ca64901a3d6e3ac&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-12-2 15:55, 24.23 KB) / 下载次数 66
http://forums.netpad.net.cn/attachment.php?aid=22891&k=83ca47efa7c152639503cb6f5e414f5d&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-12-2 15:55, 24.32 KB) / 下载次数 2029
http://forums.netpad.net.cn/attachment.php?aid=22892&k=1ec7970e3beaf537b80b7807ef8b8c28&t=1765167857&sid=yYLc25



图片附件: b.jpg (2014-12-2 15:55, 22.29 KB) / 下载次数 2030
http://forums.netpad.net.cn/attachment.php?aid=22893&k=66d0bd8233e0ec00a9e6321280735679&t=1765167857&sid=yYLc25



图片附件: c.jpg (2014-12-2 15:55, 21.98 KB) / 下载次数 2003
http://forums.netpad.net.cn/attachment.php?aid=22894&k=157af46d7de0525213c5521a8d173bc5&t=1765167857&sid=yYLc25



图片附件: d.jpg (2014-12-2 15:55, 24.23 KB) / 下载次数 1991
http://forums.netpad.net.cn/attachment.php?aid=22895&k=82bf475c5e187c3c9a3be31c3c8482d4&t=1765167857&sid=yYLc25



图片附件: e.jpg (2014-12-2 15:55, 26.44 KB) / 下载次数 2024
http://forums.netpad.net.cn/attachment.php?aid=22896&k=324f1d7b3a1f8685effb0249b6921127&t=1765167857&sid=yYLc25



附件: html0606.rar (2014-12-2 01:26, 10.08 KB) / 下载次数 3679
http://forums.netpad.net.cn/attachment.php?aid=22899&k=f66452a5f96fd82d8095dbcdbaba47db&t=1765167857&sid=yYLc25
作者: xiaongxp    时间: 2014-12-2 00:27

95# xklppp
陷阱颜色过渡如此圆润,背景色与陷阱色又如此泾渭分明,几何画板是难以作到的。为肖老师取得的成就喝彩!
作者: xklppp    时间: 2014-12-2 10:40

96# xiaongxp
过奖了,谢谢老港老师,我只是把杜老师的代码移植成 javascript ,html 的所有对象都有个 alpha 通道,着色空间也就大了许多。html 中的 canvas 画布真正的精彩应用是作动画,特别是 3D 动画,那些算法吓死人,没有数理功底简直就不敢想。
复分形的陷阱技术能产生一定程度的 3D 效果,如果能加上光照渲染和材质贴图,那就更好了,老师们的画板作品中就有贴图效果,用算法语言描述恐怕不是件容易的事情。
作者: xklppp    时间: 2014-12-3 09:43

1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
7.jpg
8.jpg
9.jpg
a.jpg

图片附件: 1.jpg (2014-12-3 18:48, 14.58 KB) / 下载次数 1830
http://forums.netpad.net.cn/attachment.php?aid=22900&k=c9034c3ff04281e38fd928f7d32a93ab&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-12-3 18:48, 14.95 KB) / 下载次数 1916
http://forums.netpad.net.cn/attachment.php?aid=22901&k=8c403857c49c1b920fcab3cfc68e28d2&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-12-3 18:48, 19.39 KB) / 下载次数 1808
http://forums.netpad.net.cn/attachment.php?aid=22902&k=bf581771a2e0fc98e7ed0d602d1c70ae&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-12-3 18:48, 19.9 KB) / 下载次数 1826
http://forums.netpad.net.cn/attachment.php?aid=22903&k=6ee14bc35d48933be47d6480f980b0fc&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-12-3 18:48, 21.87 KB) / 下载次数 1833
http://forums.netpad.net.cn/attachment.php?aid=22904&k=5f1e4c6bcfa35508ea1f09c800ec69ac&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-12-3 18:48, 31.94 KB) / 下载次数 1855
http://forums.netpad.net.cn/attachment.php?aid=22905&k=42d7432e6720d943fe6e1300944ff88d&t=1765167857&sid=yYLc25



图片附件: 7.jpg (2014-12-3 18:48, 27.15 KB) / 下载次数 1834
http://forums.netpad.net.cn/attachment.php?aid=22906&k=92daa59a398c431bd7e5386b3fbdc4e2&t=1765167857&sid=yYLc25



图片附件: 8.jpg (2014-12-3 18:48, 31.03 KB) / 下载次数 1851
http://forums.netpad.net.cn/attachment.php?aid=22907&k=287fd68d22bcb30ef3ff4046eb3df839&t=1765167857&sid=yYLc25



图片附件: 9.jpg (2014-12-3 18:48, 35.54 KB) / 下载次数 1828
http://forums.netpad.net.cn/attachment.php?aid=22908&k=5d1bf4c8ecced19987b361c7946198fd&t=1765167857&sid=yYLc25



图片附件: a.jpg (2014-12-3 18:48, 35.94 KB) / 下载次数 1871
http://forums.netpad.net.cn/attachment.php?aid=22909&k=10bb6c89b072c29b5c668def38158a20&t=1765167857&sid=yYLc25


作者: xklppp    时间: 2014-12-3 20:21

前面程序中有两处算法错误,纠正后并在陷阱模块中加入了几条曲线。
下面的曲线为:r=|t/4|-k.......t(幅角)、k(形状大小)
1.jpg
2.jpg
3.jpg
4.jpg
5.jpg
6.jpg
html0608.rar (10.25 KB)

图片附件: 1.jpg (2014-12-4 10:05, 6.45 KB) / 下载次数 1836
http://forums.netpad.net.cn/attachment.php?aid=22911&k=0b6e37bb1dfaad050c3f19b740396aa1&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-12-4 10:05, 13.96 KB) / 下载次数 1821
http://forums.netpad.net.cn/attachment.php?aid=22912&k=dc2489804eb3f5003ef1403d11e3d0aa&t=1765167857&sid=yYLc25



图片附件: 3.jpg (2014-12-4 10:05, 15.85 KB) / 下载次数 1857
http://forums.netpad.net.cn/attachment.php?aid=22913&k=54f6dba43d7da0df463fe64e89adc802&t=1765167857&sid=yYLc25



图片附件: 4.jpg (2014-12-4 10:05, 24.32 KB) / 下载次数 1844
http://forums.netpad.net.cn/attachment.php?aid=22914&k=14a7e3242b9304c86a73432c937618d8&t=1765167857&sid=yYLc25



图片附件: 5.jpg (2014-12-4 10:05, 27.22 KB) / 下载次数 1830
http://forums.netpad.net.cn/attachment.php?aid=22915&k=a8728828a49c54bf77ace8eb38cfc871&t=1765167857&sid=yYLc25



图片附件: 6.jpg (2014-12-4 10:05, 31.1 KB) / 下载次数 1883
http://forums.netpad.net.cn/attachment.php?aid=22916&k=5ba1f23926089e426b83f4ff81b161b3&t=1765167857&sid=yYLc25



附件: html0608.rar (2014-12-3 20:21, 10.25 KB) / 下载次数 3787
http://forums.netpad.net.cn/attachment.php?aid=22917&k=0ea81c6963eeaa04879c4adbb12a0405&t=1765167857&sid=yYLc25
作者: xklppp    时间: 2014-12-4 11:29

作花边图案蛮好的:
r=k*ln(|Zr|+|Zi|)
1.jpg
r=k*ln|z|
2.jpg

图片附件: 1.jpg (2014-12-4 21:55, 13.95 KB) / 下载次数 1814
http://forums.netpad.net.cn/attachment.php?aid=22918&k=37606b0353ca1e0a28a83a55b91f9f4b&t=1765167857&sid=yYLc25



图片附件: 2.jpg (2014-12-4 21:55, 15.96 KB) / 下载次数 1846
http://forums.netpad.net.cn/attachment.php?aid=22919&k=e78bf51c59f2c199978628c9987cb7c5&t=1765167857&sid=yYLc25






欢迎光临 inRm3D: 画板论坛 (http://forums.netpad.net.cn/) Powered by Discuz! 7.0.0