看了网上好多都是js写的,感觉碉堡了!js用的不熟,前端不好,java,Python写起来一定很顺手吧,但是还是决定用c写一下,简单的界面,大神路过不喜勿喷。下面和大家一起分享一下!
代码如下:
顺便所以下:如果在windows上运行该代码,需要pthread库,我用的Dev c++写的,自己装上了这个库!
运行程序下载:n459.com/file/25127180-479368639
该程序主要包含windows编程,以及简单的线程,数学逻辑处理(弱弱的说一句,数学不好,动态心形图案借鉴的哦)。 简单介绍一下一些函数的功能。
1.GetStdHandle(STD_OUTPUT_HANDLE);//获取控制台输出句柄
2.SetConsoleScreenBufferSize(o, size); // 重新设置缓冲区大小
3.SMALL_RECT rc = {0, 0, 100-1, 40-1}; // 重置窗口位置和大小
SetConsoleWindowInfo(o, true, &rc);
4.SetConsoleTitle(“LOVE”);//设置控制台标题
5.system(“color ec”); // 设置为红色,显得浪漫温馨点
6.SetConsoleTextAttribute(o, hjzgg_color[color_index]);//设置下个即将输出字体的前景色和背景色
7.SetConsoleCursorPosition(o, coord);//设置控制台光标的位置
8.WriteConsole(o, one_word, 2, NULL, 0);//在控制台光标的位置处连续输出一定长度的字符串
9.pthread_mutex_lock(&mutex);//给线程上锁,利用互斥变量
10.pthread_mutex_unlock(&mutex);给线程解锁
11.pthread_create(&tid[1], NULL, first_init_down, NULL); //创建线程
12.pthread_join(tid[0], NULL);//用来等待一个线程的结束
13.pthread_cond_timedwait(&cond, &mutex, &outtime);//线程进入等待,一定时间后自行苏醒
#include
#include
#include
#include
#include
#include
#include
#include
pthread_mutex_t mutex;//互斥信号量
pthread_cond_t cond;//条件变量
HANDLE o = GetStdHandle(STD_OUTPUT_HANDLE);
_TCHAR buffer[25][80] = { _T(’ ') };
_TCHAR ramp[] = _T(".:-=+*#%@");
WORD hjzgg_color[7]={
BACKGROUND_INTENSITY|FOREGROUND_INTENSITY|FOREGROUND_RED | BACKGROUND_RED|BACKGROUND_GREEN, //red on yellow
BACKGROUND_INTENSITY|FOREGROUND_INTENSITY|FOREGROUND_GREEN | BACKGROUND_RED|BACKGROUND_GREEN,
BACKGROUND_INTENSITY|FOREGROUND_INTENSITY|FOREGROUND_BLUE | BACKGROUND_RED|BACKGROUND_GREEN,
BACKGROUND_INTENSITY|FOREGROUND_INTENSITY|FOREGROUND_RED|FOREGROUND_GREEN|FOREGROUND_BLUE | BACKGROUND_RED|BACKGROUND_GREEN,
BACKGROUND_INTENSITY|FOREGROUND_INTENSITY|FOREGROUND_RED|FOREGROUND_GREEN | BACKGROUND_RED|BACKGROUND_GREEN,
BACKGROUND_INTENSITY|FOREGROUND_INTENSITY|FOREGROUND_GREEN|FOREGROUND_BLUE | BACKGROUND_RED|BACKGROUND_GREEN,
BACKGROUND_INTENSITY|FOREGROUND_INTENSITY|FOREGROUND_RED|FOREGROUND_BLUE | BACKGROUND_RED|BACKGROUND_GREEN
};
float f(float x, float y, float z) {
float a = x * x + 9.0f / 4.0f * y * y + z * z - 1;
return a * a * a - x * x * z * z * z - 9.0f / 80.0f * y * y * z * z * z;
}
float h(float x, float z) {
for (float y = 1.0f; y >= 0.0f; y -= 0.001f)
if (f(x, y, z) <= 0.0f)
return y;
return 0.0f;
}
char flower1[11][22]={//一行20个字符
" {@} ",
" {@} * {@} ",
" {@} * {@} * {@} “,
“{@}* {@} * {@} * {@}”,
" \ {@} * {@} * {@} /”,
" \ \ \ L / / / ",
" \\ \ O / // ",
" \\ V // ",
" \\E// ",
" >=< ",
" //*\\ "
};
char flower2[9][28]={//一行27个字符
“…@---------------@…”,
“-- @ @ @ --------- @ @ @ --”,
“.@ @\@/@ @-------@ @\@/@ @.”,
“.\@|@|@|@/-…–\@|@|@|@/.”,
“. \\\|/// --…— \\\|/// -”,
" - \\|// --…----- \\|//.–",
" – \|/–…—.---- \|/—.",
" – =&= —…------ =&= —",
" – /|\ --------.—/|\ -.-"
} ;
char piercing_arrow[][34]={//一行33个字符
" ☆☆ ☆☆ ☆☆ ☆☆ ",
" ★★ ★ ★★ ",
" ☆☆ 快乐每一天 ☆☆ ",
" ★★ ★★ ",
“>>>---------I LOVE YOU --------->”,
" ★★ ★★ ",
" ☆☆ ☆☆ ",
" ★★ ★★ ",
" ☆☆ "
};
char love_word[][6][60]={//一共5个部分, 三行情书
{
“你 如 水 的 眸 光 笼 着 江 南 的 烟 雨”,
“映 入 我 那 一 寸 一 寸 消 融 的 心”,
“从 那 一 刻 我 不 在 属 于 自 己”
},
{
“我 默 默 收 集 你 的 所 有”,
“不 知 还 要 多 久”,
“却 不 曾 厌 倦”
},
{
"当 初 ,初 见 只 道 是 寻 常",
"寻 觅 ,何 枝 可 化 深 千 亿",
"犹 道 ,碧 桃 影 里 碧 三 声"
} ,
{
"在 这 个 年 纪 远 远 地 看 着 你",
"日 光 美 好 的 一 泻 千 里",
"温 暖 着 一 个 卑 微 而 简 单 的 心"
} ,
{
"你 的 一 纸 信 笺",
"压 在 书 底",
"压 过 了 青 春 的 夏 季",
"从 爱 你 的 花 季",
"一 直 等 到",
"爱 你 的 暮 年"
}
} ;
void init_screen(){
COORD size = {100, 40};
SetConsoleScreenBufferSize(o, size); // 重新设置缓冲区大小
SMALL_RECT rc = {0, 0, 100-1, 40-1}; // 重置窗口位置和大小
SetConsoleWindowInfo(o, true, &rc);
SetConsoleTitle(“LOVE”);
system(“color ec”); // 设置为红色,显得浪漫温馨点
}
void* show_love_word(void* arg){
srand((unsigned)time(NULL));//随机每束花是否显示
while(true) {
int word_index = rand()%5;
int col = 70;
int row_index = 3;
if(word_index == 4)
row_index = 6;
//显示word
int color_index = rand()%4;
for(int i=0; i
for(int j=0; love_word[word_index][i][j]; j+=2){
char one_word[2];//得到一个汉字
sprintf(one_word, “%c%c”, love_word[word_index][i][j], love_word[word_index][i][j+1]);
COORD coord = {col, row};
pthread_mutex_lock(&mutex);
SetConsoleTextAttribute(o, hjzgg_color[color_index]);
SetConsoleCursorPosition(o, coord);
WriteConsole(o, one_word, 2, NULL, 0);
coord.Y += 1;
if(love_word[word_index][i][j+2]){
SetConsoleCursorPosition(o, coord);
WriteConsole(o, “__”, 2, NULL, 0);
}
SetConsoleTextAttribute(o, hjzgg_color[0]);
pthread_mutex_unlock(&mutex);
++row;
Sleep(100);
}
col+=4;
}
Sleep(2000);
//擦除Word
col-=4;
for(int i=row_index-1; i>=0; --i) {
char hjzgg_word[60];
memcpy(hjzgg_word, love_word[word_index][i], sizeof(love_word[word_index][i]));
int len_hjzgg_word = strlen(hjzgg_word);
int len_word = len_hjzgg_word;
bool is_first = true;
while(len_word >= 0) {
int row = 1;
for(int j=0; j
}
void* first_init_top(void* arg){
char tmp[80];
for(int ld=0; ld < 12; ++ld){
COORD coord_top = { 0, ld};
memset(tmp, ’ ‘, sizeof(tmp));
int cc = 0;
while(cc < 60){
while(buffer[ld][cc]==’ ') ++cc;
tmp[cc] = buffer[ld][cc];
++cc;
pthread_mutex_lock(&mutex);
SetConsoleCursorPosition(o, coord_top);
WriteConsole(o, tmp, 60, NULL, 0);
pthread_mutex_unlock(&mutex);
Sleep(15);
}
}
}
void* screen_down_flower(void* arg){//从第26行开始打印
srand((unsigned)time(NULL));//随机每束花是否显示
int flower_row[3] = {11, 9, 11};
int flower_col[3] = {20, 27, 20};
int flower_begin_col[3] = {5, 33, 70};
int flower_begin_row[3] = {26, 28, 26};
struct timeval now;
struct timespec outtime;
pthread_mutex_lock(&mutex);
while(true){
int k = 0;
while(k < 3){
char flower[50][50] = {’ '};
int color_index = rand()%7;
SetConsoleTextAttribute(o, hjzgg_color[color_index]);
if(k0 || k2){
for(int i=0; i
} else {
for(int i=0; i
}
for(int i=flower_begin_row[k], j=0; j
SetConsoleCursorPosition(o, coord);
WriteConsole(o, flower[j], flower_col[k], NULL, 0);
}
++k;
SetConsoleTextAttribute(o, hjzgg_color[0]);//重新设置为原来的原色
gettimeofday(&now, NULL);
outtime.tv_sec = now.tv_sec;
outtime.tv_nsec = now.tv_usec * 100000;
pthread_cond_timedwait(&cond, &mutex, &outtime);
}
}
pthread_mutex_unlock(&mutex);
}
void* first_init_down(void* arg){
char tmp[80];
for(int rd=24; 12 <= rd; --rd){
COORD coord_down = { 0, rd };
SetConsoleCursorPosition(o, coord_down);
memset(tmp, ’ ‘, sizeof(tmp));
int cc = 60;
while(cc >= 0){
while(buffer[rd][cc]==’ ') --cc;
tmp[cc] = buffer[rd][cc];
–cc;
pthread_mutex_lock(&mutex);
SetConsoleCursorPosition(o, coord_down);
WriteConsole(o, tmp, 60, NULL, 0);
pthread_mutex_unlock(&mutex);
Sleep(15);
}
}
}
//一箭穿心图案
void show_piercing_arrow(){
for(int i=0; i<9; ++i) {
pthread_mutex_lock(&mutex);
COORD coord_down = { 13, i+7 };
SetConsoleCursorPosition(o, coord_down);
WriteConsole(o, piercing_arrow[i], 33, NULL, 0);
pthread_mutex_unlock(&mutex);
}
}
void first_init(){
show_piercing_arrow();
pthread_t tid[4];
// screen_down_flower
pthread_create(&tid[2], NULL, screen_down_flower, NULL);
// show_love_word
pthread_create(&tid[3], NULL, show_love_word, NULL);
// 心型 init_first
pthread_mutex_init(&mutex, NULL);
pthread_cond_init(&cond, NULL);
pthread_create(&tid[0], NULL, first_init_top, NULL);
pthread_create(&tid[1], NULL, first_init_down, NULL);
pthread_join(tid[0], NULL);
pthread_join(tid[1], NULL);
}
int main() {
init_screen();
bool first = true;
for (float t = 0.0f;; t += 0.1f) {
int sy = 0;
float s = sinf(t);
float a = s * s * s * s * 0.2f;
for (float z = 1.3f; z > -1.2f; z -= 0.1f) {
_TCHAR* p = &buffer[sy++][0];
float tz = z * (1.2f - a);
for (float x = -1.5f; x < 1.5f; x += 0.05f) {
float tx = x * (1.2f + a);
float v = f(tx, 0.0f, tz);
if (v <= 0.0f) {
float y0 = h(tx, tz);
float ny = 0.01f;
float nx = h(tx + ny, tz) - y0;
float nz = h(tx, tz + ny) - y0;
float nd = 1.0f / sqrtf(nx * nx + ny * ny + nz * nz);
float d = (nx + ny - nz) * nd * 0.5f + 0.5f;
*p++ = ramp[(int)(d * 5.0f)];
}
else
*p++ = ’ ';
}
}
if(first){
first = false;
first_init();
}
else {
pthread_mutex_lock(&mutex);
for (sy = 0; sy < 25; sy++) {
COORD coord = { 0, sy };
SetConsoleCursorPosition(o, coord);
WriteConsole(o, buffer[sy], 60, NULL, 0);
}
pthread_mutex_unlock(&mutex);
}
Sleep(33);
}
return 0;
}