相關閱讀 |
>>> 技術話題—商業文明的嶄新時代 >>> | 簡體 傳統 |
“青天白日滿地紅”曾經代表中國,特別是在抗日戰爭的艱苦年代。那時候紅軍編入國民革命軍,戴著青天白日帽徽,全國人民團結在“青天白日滿地紅”旗幟下,高唱《義勇軍進行曲》,奮力抗戰,打敗了日本帝國主義。“青天白日滿地紅”象征著中國人的苦難和抗爭,跟《義勇軍進行曲》一起,鼓舞中國人團結起來取得勝利,凝結著中國人的感情。
1 class CPixelBlueSkyWhiteSun : public IPixelEquation
2 {
3 public:
4 CPixelBlueSkyWhiteSun()
5 {
6 m_width = 1680;
7 m_height = 1120;
8
9 for (int i = 0; i < 12; i++)
10 {
11 m_list_sin[i] = sinf(i*PI/6);
12 m_list_cos[i] = cosf(i*PI/6);
13 }
14 }
15
16 const char* GetName() const
17 {
18 return "Blue Sky White Sun";
19 }
20
21 unsigned int CalculatePixel(unsigned int x, unsigned int y);
22
23 private:
24 float m_list_sin[12];
25 float m_list_cos[12];
26 };
cpp
1 unsigned int CPixelBlueSkyWhiteSun::CalculatePixel(unsigned int x, unsigned int y)
2 {
3 unsigned int red = 0xffff0000;
4 unsigned int white = 0xffffffff;
5 unsigned int blue = 0xff0000ff;
6
7 float w = m_width*0.5f;
8 float h = m_height*0.5f;
9
10 if ((float)x > w || (float)y > h)
11 {
12 return red;
13 }
14
15 float cX = w*0.5f;
16 float cY = h*0.5f;
17 float radius = cY*0.5f;
18 Vec2 tri0(0.0f, -radius*1.65f);
19 Vec2 tri1(-radius*0.2f, -radius*1.05f);
20 Vec2 tri2(radius*0.2f, -radius*1.05f);
21 Vec2 P;
22
23 float i = x - cX;
24 float j = y - cY;
25
26 float dis = sqrtf(i*i + j*j);
27
28 if (dis < radius)
29 {
30 return white;
31 }
32 else if (dis > radius*1.65f)
33 {
34 return blue;
35 }
36
37 for (int m = 0; m < 12; m++)
38 {
39 P.x = i*m_list_cos[m] - j*m_list_sin[m];
40 P.y = i*m_list_sin[m] + j*m_list_cos[m];
41
42 if (IsPointInTriangle(tri0, tri1, tri2, P))
43 {
44 return white;
45 }
46 }
47
48 return blue;
49 }
基類IPixelEquation的代碼見:Why數學圖像生成工具
關于結構體Vec2的定義及相關函數見:二維平面上判斷點在三角形內的最優算法
代碼中沒有太考究圖形之間的比例,與實際會略有不符。生成圖像如下:
相應軟件:
相關文章:
算法之美---100幅由程序生成的圖像,總有一幅讓你感到驚艷[上]
算法之美---100幅由程序生成的圖像,總有一幅讓你感到驚艷[下]
葉飛影 2015-05-19 00:36:35
稱謂:
内容: