在oschina上看到了用c写的红玫瑰, 以前只见过用js写的, 就随手用delphi翻译了c的代码, 效果还不错哈....

原c作者jokeym贴子 http://www.oschina.net/code/snippet_2373787_48760

我的改版贴子 http://www.oschina.net/code/snippet_212659_48907

以下为代码:

  1. unit Unit1;
  2. interface
  3. uses
  4. Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes,
  5. Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.ExtCtrls, Vcl.StdCtrls;
  6. type
  7. TForm1 = class(TForm)
  8. btn1: TButton;
  9. procedure btn1Click(Sender: TObject);
  10. private
  11. public
  12. { Public declarations }
  13. end;
  14. var
  15. Form1: TForm1;
  16. implementation
  17. {$R *.dfm}
  18. uses
  19. System.Math;
  20. // 原作者贴子,
  21. // http://www.oschina.net/code/snippet_2373787_48760
  22. // delphi版本
  23. // ying32
  24. const
  25. RAND_MAX = $7FFF;
  26. urosesize: Integer = 500;
  27. uh: Integer = -250;
  28. type
  29. // 定义结构体
  30. TDOT = record
  31. x: Double;
  32. y: Double;
  33. z: Double;
  34. r: Double;  // 红色
  35. g: double;  // 绿色
  36. // b(蓝色) 通过 r 计算
  37. end;
  38. function calc(a, b, c: Double; var d: TDOT): Boolean;
  39. var
  40. j, n, o, w, z: Double;
  41. _A, _B: Double;
  42. begin
  43. Result := False;
  44. if c > 60 then // 花柄
  45. begin
  46. d.x := sin(a * 7) * (13 + 5 / (0.2 + power(b * 4, 4))) - sin(b) * 50;
  47. d.y := b * urosesize + 50;
  48. d.z := 625 + cos(a * 7) * (13 + 5 / (0.2 + power(b * 4, 4))) + b * 400;
  49. d.r := a * 1 - b / 2;
  50. d.g := a;
  51. Exit(True);
  52. end;
  53. _A := a * 2 - 1;
  54. _B := b * 2 - 1;
  55. if _A * _A + _B * _B < 1 then
  56. begin
  57. if c > 37 then           // 叶
  58. begin
  59. j := Trunc(c) and 1;
  60. n := IfThen(j <> 0, 6, 4);
  61. o := 0.5 / (a + 0.01) + cos(b * 125) * 3 - a * 300;
  62. w := b * uh;
  63. d.x := o * cos(n) + w * sin(n) + j * 610 - 390;
  64. d.y := o * sin(n) - w * cos(n) + 550 - j * 350;
  65. d.z := 1180 + cos(_B + _A) * 99 - j * 300;
  66. d.r := 0.4 - a * 0.1 + power(1 - _B * _B, -uh * 6) * 0.15 - a * b * 0.4 + cos(a + b) / 5 + power(cos((o * (a + 1) + IfThen(_B > 0, w, -w)) / 25), 30) * 0.1 * (1 - _B * _B);
  67. d.g := o / 1000 + 0.7 - o * w * 0.000003;
  68. Exit(True);
  69. end;
  70. if c > 32 then           // 花萼
  71. begin
  72. c := c * 1.16 - 0.15;
  73. o := a * 45 - 20;
  74. w := b * b * uh;
  75. z := o * sin(c) + w * cos(c) + 620;
  76. d.x := o * cos(c) - w * sin(c);
  77. d.y := 28 + cos(_B * 0.5) * 99 - b * b * b * 60 - z / 2 - uh;
  78. d.z := z;
  79. d.r := (b * b * 0.3 + power((1 - (_A * _A)), 7) * 0.15 + 0.3) * b;
  80. d.g := b * 0.7;
  81. Exit(True);
  82. end;
  83. // 花
  84. o := _A * (2 - b) * (80 - c * 2);
  85. w := 99 - cos(_A) * 120 - cos(b) * (-uh - c * 4.9) + cos(power(1 - b, 7)) * 50 + c * 2;
  86. z := o * sin(c) + w * cos(c) + 700;
  87. d.x := o * cos(c) - w * sin(c);
  88. d.y := _B * 99 - cos(power(b, 7)) * 50 - c / 3 - z / 1.35 + 450;
  89. d.z := z;
  90. d.r := (1 - b / 1.2) * 0.9 + a * 0.1;
  91. d.g := power((1 - b), 20) / 4 + 0.05;
  92. Exit(True);
  93. end;
  94. end;
  95. procedure TForm1.btn1Click(Sender: TObject);
  96. var
  97. zBuffer: array of Smallint;
  98. i, j: Integer;
  99. x, y, z, zBufferIndex: Integer;
  100. dot: TDOT;
  101. r, g, b: Integer;
  102. begin
  103. SetLength(zBuffer, urosesize * urosesize);
  104. Canvas.Brush.Color := clWhite;
  105. Canvas.FillRect(Rect(0, 0, Width, Height));
  106. Randomize;
  107. for j := 0 to 1999 do
  108. begin
  109. for i := 0 to 9999 do
  110. begin
  111. if calc(Random(RAND_MAX) / RAND_MAX, Random(RAND_MAX) / RAND_MAX, (Random(RAND_MAX) mod 46) / 0.74, dot) then
  112. begin
  113. z := Trunc(dot.z + 0.5);
  114. x := Trunc(dot.x * urosesize / z - uh + 0.5);
  115. y := Trunc(dot.y * urosesize / z - uh + 0.5);
  116. if y >= urosesize then
  117. Continue;
  118. zBufferIndex := y * urosesize + x;
  119. if (not (zBuffer[zBufferIndex] <> 0)) or (zBuffer[zBufferIndex] > z) then
  120. begin
  121. zBuffer[zBufferIndex] := z;
  122. // 画点
  123. r := not Trunc(dot.r * uh);
  124. if r < 0 then
  125. r := 0;
  126. if r > 255 then
  127. r := 255;
  128. g := not Trunc(dot.g * uh);
  129. if g < 0 then
  130. g := 0;
  131. if g > 255 then
  132. g := 255;
  133. b := not Trunc(dot.r * dot.r *  - 80);
  134. if b < 0 then
  135. b := 0;
  136. if b > 255 then
  137. b := 255;
  138. Canvas.Pixels[x + 50, y - 20] := RGB(r, g, b);
  139. end;
  140. end;
  141. Application.ProcessMessages;
  142. end;
  143. Sleep(1);
  144. end;
  145. end;
  146. end.

http://blog.csdn.net/zyjying520/article/details/46592831

情人节红攻瑰--Delphi版本的更多相关文章

  1. "如何用70行Java代码实现深度神经网络算法" 的delphi版本

     http://blog.csdn.net/hustjoyboy/article/details/50721535 "如何用70行Java代码实现深度神经网络算法" 的delphi ...

  2. 我所改造的JSocket适用于任何DELPHI版本

    JSOCKET是异步选择模式的通信控件,简单而强大,传奇的早期版本就是使用它作通信. { ******************************************************* ...

  3. delphi版本修改PE头源码

    //VC++6外衣 1 OEPCODEFIVE: THEAD = ($55, $8B, $EC, $6A, $FF, $68, $00, $00, $00, $00, $68, $00, $00, $ ...

  4. Delphi 版本信息获取函数 GetFileVersionInfo、GetFileVersionInfoSize、VerFindFile、VerInstallFile和VerQueryValue

    一.版本信息获取函数简介和作用 获取文件版本信息的作用: 1. 避免在新版本的组件上安装旧版本的相同组件: 2. 在多语言系统环境中,操作系统根据文件版本信息里提供的语言信息在启动程序时决定使用的正确 ...

  5. Delphi版本顺序

    1.02.03.04.05.06.07.08.0200520062007 现在应该又出新的版本了

  6. 以前的 Delphi版本

                    Delphi 1 Delphi 2 Delphi 3 Delphi 4 Delphi 5 Delphi 6 Delphi 7 Delphi 8 Delphi 2005

  7. delphi版本对应

    delphi 7 delphi 8delphi 2005 ----- 9delphi 2006 ----- 10 delphi 2007 ----- 11delphi 2009 ----- 12 de ...

  8. 很幽默的讲解六种Socket IO模型 Delphi版本(自己Select查看,WM_SOCKET消息通知,WSAEventSelect自动收取,Overlapped I/O 事件通知模型,Overlapped I/O 完成例程模型,IOCP模型机器人)

    很幽默的讲解六种Socket IO模型(转)本文简单介绍了当前Windows支持的各种Socket I/O模型,如果你发现其中存在什么错误请务必赐教. 一:select模型 二:WSAAsyncSel ...

  9. Delphi Xe2 后的版本如何让Delphi程序启动自动“以管理员身份运行"

    由于Vista以后win中加入的UAC安全机制,采用Delphi开发的程序如果不右键点击“以管理员身份运行”,则会报错. 在XE2以上的Delphi版本处理这个问题已经非常简单了. 右建点击工程,选择 ...

随机推荐

  1. 免费的HTML5连载来了《HTML5网页开发实例详解》连载(五)图解通过Fiddler加速开发

    Fiddler是Windows底下最强大的请求代理调试工具,监控任何浏览器的HTTP/HTTPS流量,窜改客户端请求和服务器响应,解密HTTPS Web会话,图4.44为Fiddler原理示意图. 图 ...

  2. poj 2220 Sumsets

                                                                                                     Sum ...

  3. 在 Java 中将 Unicode 编码的汉字转码

    今天在做一个新浪微博的抓取测试,发现抓取后的内容是Unicode编码的,完全找不到熟悉的汉字了,下面搜索出来的一种方法,完全可行,只是不知到Java内部是否提供了相关的类库. 实现方法如下: publ ...

  4. Android - 代码片段

    转载说明 本篇文章可能已经更新,最新文章请转:http://www.sollyu.com/android-code-snippets/ 说明 此篇文章为个人日常使用所整理的一此代码片段,此篇文正将会不 ...

  5. 小黑的镇魂曲(HDU2155:贪心+dfs+奇葩解法)

    题目:点这里 题目的意思跟所谓的是英雄就下100层一个意思……在T秒内能够下到地面,就可以了(还有一个板与板之间不能超过H高). 接触这题目是在昨晚的训练赛,当时拍拍地打了个贪心+dfs,果断跟我想的 ...

  6. 实现android支持多线程断点续传下载器功能

    多线程断点下载流程图: 多线程断点续传下载原理介绍: 在下载的时候多个线程并发可以占用服务器端更多资源,从而加快下载速度手机端下载数据时难免会出现无信号断线.电量不足等情况,所以需要断点续传功能根据下 ...

  7. WinForms 小型HTML服务器

    最近教学,使用到了Apache和IIS,闲着无聊,有种想自己写个小服务器的冲动. 在网上找了半天的资料,最后终于搞定了,测试可以访问.效果图如下: 因为只是处理简单的请求,然后返回请求的页面,所以没有 ...

  8. PHPNow升级PHP版本的方法

    在WIN上有时候需要测试一些PHP程序,又不会自行独立配置环境,那么PHPNow是非常好的选择. PHPNow自带的PHP版本为5.2.14,而最后一次更新在于2010-9-22,PHP5.2对于现在 ...

  9. jQuery(function($){...})与(function($){...})(jQuery)知识点分享

    写jQuery插件时一些经验分享一下. 一.推荐写法 jQuery(function($){ //coding }); 全写为 jQuery(document).ready(function($){ ...

  10. 【C++】GacLib——ListView.ViewSwitching

    http://www.gaclib.net/Demos/Controls.ListView.ViewSwitching/Demo.html#FILESYSTEMINFORMATION_H