到程序員,就會(huì)出現(xiàn)許多關(guān)鍵詞,諸如“直男,宅,不懂浪漫,枯燥,憨厚老實(shí),有邏輯,人傻錢多…………”
說(shuō)程序猿是直男,不可否認(rèn),大多數(shù)程序猿都挺直,因?yàn)槲覀儧]有那么多彎彎繞繞,有心思兜圈子,不如回去寫幾行代碼………
雷軍曾經(jīng)說(shuō)“我喜歡寫代碼,代碼的世界很簡(jiǎn)單”
程序猿的大多數(shù)時(shí)間都是面對(duì)電腦,所以對(duì)待一份感情也會(huì)非常的認(rèn)真。程序猿也許在生活中會(huì)比較宅,就比如本人,但是千萬(wàn)不要說(shuō)程序猿不懂浪漫。當(dāng)你不開心了,他可以分分鐘做出一個(gè)玫瑰花、心形等告白小程序給你制造小驚喜…………
程序員一旦浪漫起來(lái),就真沒其他人啥事了!接下來(lái)就給大家介紹一下程序猿是如何表白收獲愛情的………
源碼如下:
1 import turtle as t
2
3 def Curve_Draw(n,r,d=1):
4 for i in range(n):
5 t.left(d)
6 t.circle(r,abs(d))
7
8 s = 0.2
9 t.setup(450*5*s,750*5*s)
10 t.pencolor('black')
11 t.fillcolor('purple')
12 t.speed(100)
13 t.penup()
14 t.goto(0,900*s)
15 t.pendown()
16
17 t.begin_fill()
18 t.circle(200*s,30)
19 Curve_Draw(60,50*s)
20 t.circle(200*s,30)
21 Curve_Draw(4,100*s)
22 t.circle(200*s,50)
23 Curve_Draw(50,50*s)
24 t.circle(350*s,65)
25 Curve_Draw(40,70*s)
26 t.circle(150*s,50)
27 Curve_Draw(20,50*s,-1)
28 t.circle(400*s,60)
29 Curve_Draw(18,50*s)
30 t.fd(250*s)
31 t.right(150)
32 t.circle(-500*s,12)
33 t.left(140)
34 t.circle(550*s,110)
35 t.left(27)
36 t.circle(650*s,100)
37 t.left(130)
38 t.circle(-300*s,20)
39 t.right(123)
40 t.circle(220*s,57)
41 t.end_fill()
42
43 t.left(120)
44 t.fd(280*s)
45 t.left(115)
46 t.circle(300*s,33)
47 t.left(180)
48 t.circle(-300*s,33)
49 Curve_Draw(70,225*s,-1)
50 t.circle(350*s,104)
51 t.left(90)
52 t.circle(200*s,105)
53 t.circle(-500*s,63)
54 t.penup()
55 t.goto(170*s,-30*s)
56 t.pendown()
57 t.left(160)
58 Curve_Draw(20,2500*s)
59 Curve_Draw(220,250*s,-1)
60
61 t.fillcolor('green')
62 t.penup()
63 t.goto(670*s,-180*s)
64 t.pendown()
65 t.right(140)
66 t.begin_fill()
67 t.circle(300*s,120)
68 t.left(60)
69 t.circle(300*s,120)
70 t.end_fill()
71 t.penup()
72 t.goto(180*s,-550*s)
73 t.pendown()
74 t.right(85)
75 t.circle(600*s,40)
76
77 t.penup()
78 t.goto(-150*s,-1000*s)
79 t.pendown()
80 t.begin_fill()
81 t.rt(120)
82 t.circle(300*s,115)
83 t.left(75)
84 t.circle(300*s,100)
85 t.end_fill()
86 t.penup()
87 t.goto(430*s,-1070*s)
88 t.pendown()
89 t.right(30)
90 t.circle(-600*s,35)
91 t.done()
源碼如下:
1 import turtle as t
2
3 t.penup()
4 t.seth(-90)
5 t.fd(160)
6 t.pendown()
7 t.pensize(20)
8 t.colormode(255)
9 for j in range(10):
10 t.speed(1000)
11 t.pencolor(25*j,5*j,15*j)
12 t.seth(130)
13 t.fd(220)
14 for i in range(23):
15 t.circle(-80,10)
16 t.seth(100)
17 for i in range(23):
18 t.circle(-80,10)
19 t.fd(220)
20 t.done()
1.3 網(wǎng)頁(yè)愛心樹表白
代碼過(guò)長(zhǎng),僅展示部分代碼:
1 <body>
2
3 <audio autoplay="autopaly">
4
5 <source src="renxi.mp3" type="audio/mp3" />
6
7 </audio>
8
9 <div id="main">
10
11 <div id="wrap">
12
13 <div id="text">
14
15 <div id="code"> <font color="#FF0000"> <span class="say">浮世三千 吾愛有三 日月與卿</span><br>
16
17 <span class="say"> </span><br>
18
19 <span class="say">日為朝 月為暮 卿為朝朝暮暮</span><br>
20
21 <span class="say"> </span><br>
22
23 <span class="say">在這浮浮沉沉的大千世界里 我愛的只有三樣</span><br>
24
25 <span class="say"></span><br>
26
27 <span class="say">太陽(yáng) 月亮和我愛的你</span><br>
28
29 <span class="say"> </span><br>
30
31 <span class="say">太陽(yáng)帶給我們白晝和希望 月亮帶給我們夜幕和寧?kù)o </span><br>
32
33 <span class="say"> </span><br>
34
35 <span class="say"> 你與我的朝夕相伴 于我而言即是永恒 你是我一生摯愛</span><br>
36
37 <span class="say"></span><br>
38
39 <span class="say">一生愛一人很難,也不丟人</span><br>
40
41 <span class="say"> </span><br>
42
43 <span class="say"> 最美的愛情愿景不就是"愿得一心人 白首不相離"嘛</span><br>
44
45 <span class="say"> </span><br>
46
47 <span class="say"> 如果可以請(qǐng)牢記當(dāng)初的愛情承諾 記住最初的美好</span><br>
48
49 <span class="say"> </span><br>
50
51 <span class="say">愿歲月靜好 淺笑安然 一切美好如約而至</span><br>
52
53 <span class="say"> </span><br>
54
55 </font>
56
57
58
59 </div>
60
61 </div>
62
63 <div id="clock-box"> <span class="STYLE1"></span><font color="#33CC00">愿得一心人,白首不相離</font> <span class="STYLE1">這簡(jiǎn)單的話語(yǔ)……</span>
64
65 <div id="clock"></div>
66
67 </div>
68
69 <canvas id="canvas" width="1100" height="680"></canvas>
70
71 </div>
72
73 </div>
1.4 煙花表白
1.5 網(wǎng)頁(yè)愛心表白
源碼如下:
1 <!DOCTYPE html>
2 <html lang="en">
3 <head>
4 <meta charset="UTF-8">
5 <title>愛心</title>
6 <style>
7 *{margin:0; padding:0;}
8 body{ background-color: #1E1E1E; }
9 </style>
10 </head>
11 <body>
12
13 <canvas id="drawHeart"></canvas>
14
15 <script>
16 var hearts = [];
17 var canvas = document.getElementById('drawHeart');
18 var wW = window.innerWidth;
19 var wH = window.innerHeight;
20 // 創(chuàng)建畫布
21 var ctx = canvas.getContext('2d');
22 // 創(chuàng)建圖片對(duì)象
23 var heartImage = new Image();
24 heartImage.src = 'img/heart.svg';
25 var num = 100;
26
27 init();
28
29 window.addEventListener('resize', function(){
30 wW = window.innerWidth;
31 wH = window.innerHeight;
32 });
33 // 初始化畫布大小
34 function init(){
35 canvas.width = wW;
36 canvas.height = wH;
37 for(var i = 0; i < num; i++){
38 hearts.push(new Heart(i%5));
39 }
40 requestAnimationFrame(render);
41 }
42
43 function getColor(){
44 var val = Math.random() * 10;
45 if(val > 0 && val <= 1){
46 return '#00f';
47 } else if(val > 1 && val <= 2){
48 return '#f00';
49 } else if(val > 2 && val <= 3){
50 return '#0f0';
51 } else if(val > 3 && val <= 4){
52 return '#368';
53 } else if(val > 4 && val <= 5){
54 return '#666';
55 } else if(val > 5 && val <= 6){
56 return '#333';
57 } else if(val > 6 && val <= 7){
58 return '#f50';
59 } else if(val > 7 && val <= 8){
60 return '#e96d5b';
61 } else if(val > 8 && val <= 9){
62 return '#5be9e9';
63 } else {
64 return '#d41d50';
65 }
66 }
67
68 function getText(){
69 var val = Math.random() * 10;
70 if(val > 1 && val <= 3){
71 return '愛你一輩子';
72 } else if(val > 3 && val <= 5){
73 return '感謝你';
74 } else if(val > 5 && val <= 8){
75 return '喜歡你';
76 } else{
77 return 'I Love You';
78 }
79 }
80
81 function Heart(type){
82 this.type = type;
83 // 初始化生成范圍
84 this.x = Math.random() * wW;
85 this.y = Math.random() * wH;
86
87 this.opacity = Math.random() * .5 + .5;
88
89 // 偏移量
90 this.vel = {
91 x: (Math.random() - .5) * 5,
92 y: (Math.random() - .5) * 5
93 }
94
95 this.initialW = wW * .5;
96 this.initialH = wH * .5;
97 // 縮放比例
98 this.targetScale = Math.random() * .15 + .02; // 最小0.02
99 this.scale = Math.random() * this.targetScale;
100
101 // 文字位置
102 this.fx = Math.random() * wW;
103 this.fy = Math.random() * wH;
104 this.fs = Math.random() * 10;
105 this.text = getText();
106
107 this.fvel = {
108 x: (Math.random() - .5) * 5,
109 y: (Math.random() - .5) * 5,
110 f: (Math.random() - .5) * 2
111 }
112 }
113
114 Heart.prototype.draw = function(){
115 ctx.save();
116 ctx.globalAlpha = this.opacity;
117 ctx.drawImage(heartImage, this.x, this.y, this.width, this.height);
118 ctx.scale(this.scale + 1, this.scale + 1);
119 if(!this.type){
120 // 設(shè)置文字屬性
121 ctx.fillStyle = getColor();
122 ctx.font = 'italic ' + this.fs + 'px sans-serif';
123 // 填充字符串
124 ctx.fillText(this.text, this.fx, this.fy);
125 }
126 ctx.restore();
127 }
128 Heart.prototype.update = function(){
129 this.x += this.vel.x;
130 this.y += this.vel.y;
131
132 if(this.x - this.width > wW || this.x + this.width < 0){
133 // 重新初始化位置
134 this.scale = 0;
135 this.x = Math.random() * wW;
136 this.y = Math.random() * wH;
137 }
138 if(this.y - this.height > wH || this.y + this.height < 0){
139 // 重新初始化位置
140 this.scale = 0;
141 this.x = Math.random() * wW;
142 this.y = Math.random() * wH;
143 }
144
145 // 放大
146 this.scale += (this.targetScale - this.scale) * .1;
147 this.height = this.scale * this.initialH;
148 this.width = this.height * 1.4;
149
150 // -----文字-----
151 this.fx += this.fvel.x;
152 this.fy += this.fvel.y;
153 this.fs += this.fvel.f;
154
155 if(this.fs > 50){
156 this.fs = 2;
157 }
158
159 if(this.fx - this.fs > wW || this.fx + this.fs < 0){
160 // 重新初始化位置
161 this.fx = Math.random() * wW;
162 this.fy = Math.random() * wH;
163 }
164 if(this.fy - this.fs > wH || this.fy + this.fs < 0){
165 // 重新初始化位置
166 this.fx = Math.random() * wW;
167 this.fy = Math.random() * wH;
168 }
169 }
170
171 function render(){
172 ctx.clearRect(0, 0, wW, wH);
173 for(var i = 0; i < hearts.length; i++){
174 hearts[i].draw();
175 hearts[i].update();
176 }
177 requestAnimationFrame(render);
178 }
179 </script>
180 </body>
181 </html>
天七夕情人節(jié),說(shuō)愛你一萬(wàn)年,一萬(wàn)句都不夠。
阿樂(lè)一上班就被隔壁工位的菜頭逮住了,說(shuō),今天情人節(jié),有什么好的R包發(fā)送郵件嗎?
阿樂(lè)扭頭一笑,這小伙子動(dòng)凡心了,但是回頭就懟他,你加她微信呀。
菜頭馬上答道:今天是浪漫的日子,要干點(diǎn)浪費(fèi)的事情,古代都是鴻雁傳書,今天咱來(lái)個(gè)郵件傳情,而且以后工作中也用的到嘞。
菜頭提了兩個(gè)要求:優(yōu)雅好看 、自動(dòng)可控。阿樂(lè)是助人為樂(lè)的好孩子,好吧,今天就把自己收藏的一段代碼送給菜頭了,希望菜頭過(guò)上愛情的甜蜜生活。
阿樂(lè)電子郵件(E-mail)本質(zhì)是一個(gè)電子文件,也是一個(gè)HTML文件。好的,開動(dòng),使用R語(yǔ)言的blastula包,只需三步搞掂這封信。
01 一睹為快
開始很重要,但是結(jié)果也很重要。我們先看這段代碼的效果如何,老規(guī)矩,上圖說(shuō)話。
「PC端」
「移動(dòng)端」
看了圖片,效果還是很不錯(cuò)的,菜頭樂(lè)的一批,離女神又近一步了。
02 代碼連連看
實(shí)際用到的代碼不到20行,非常簡(jiǎn)潔。本文的代碼案例為了排版美觀使用了圖片,需要代碼的直接關(guān)注公眾號(hào)獲取。這個(gè)R包的功能還有很多,說(shuō)不如做,有興趣的可以去安裝試用。案例的注釋把整個(gè)流程已經(jīng)寫清楚,只需要修改賬戶和內(nèi)容就可以使用了。
03 對(duì)工作有用嗎?
工作中還是很有用的,配合其他功能,可以實(shí)現(xiàn)按時(shí)按次發(fā)信息的自動(dòng)化腳本,做為信息推送的一個(gè)渠道,具體看需求而定。
隔壁的菜頭滿意而去,這時(shí)隔壁的菜尾來(lái)了,阿樂(lè),菜頭學(xué)R的有了腳本,我搞Python的你也個(gè)給我來(lái)段唄。
不聊了不聊了,要上班了咯,希望這篇文章對(duì)你有一點(diǎn)點(diǎn)用。下期再拿出python的82年代碼。
祝大家七夕快樂(lè),有TA的幸福,沒TA的馬上就有。
感謝您的閱讀,請(qǐng)順手點(diǎn)個(gè)「在看」,謝謝。
起程序員,外行的人對(duì)程序員古板的印象是格子衫、雙肩包、黑眼睛框、不懂浪漫的指南。但實(shí)際上,程序員也是很浪費(fèi)的!
七夕馬上到了,我整理了一些程序員七夕表白代碼,總共有40款。計(jì)劃告別的同學(xué)收藏起來(lái)了(文末下載)。
我們一起看下其中幾個(gè),更多請(qǐng)下載查看。
01 滿滿愛心
02 相冊(cè)動(dòng)畫
03 戀愛日志
04 戀愛PPT
05 表白書信
05 煙花特效
表白的套路很多,但都少不了送花送禮物,作為一個(gè)程序員,搞不懂現(xiàn)在流行的泡泡機(jī)、小豬、重力感應(yīng)車等玩具,也不想去讓朋友們?nèi)ニ湾X炫耀,畢竟真情才重要,錢就物質(zhì)了。我能給各位單身粉絲們做的可能就只有分享幾個(gè)表白代碼了,在電腦上敲上幾行代碼,讓她在郁悶的周一得到一個(gè)大大的驚喜,很簡(jiǎn)單,一看就會(huì),如果現(xiàn)在用不到也不要緊,先收藏起來(lái),反正這樣的節(jié)日很多,以后用的時(shí)候能找到。
私信回復(fù):1022
*請(qǐng)認(rèn)真填寫需求信息,我們會(huì)在24小時(shí)內(nèi)與您取得聯(lián)系。