用C语言实现一个圣诞树!

嵌入式技术

1368人已加入

描述

 

2022年12月25号就是圣诞节了!圣诞节当然要有个圣诞树了,今天给你们用C语言编写一个雪夜圣诞树!

 

如果本人的代码能够帮到你的话,还请在文章下方点个赞支持一下哟~ 这个就是用单纯的C语言代码实现的,需要一点点数学知识

那么我们话不多说,先来看看具体的效果吧~上面是我预想中的效果图(不是忽悠大家点进来哦)

后面我会更新更加酷炫的圣诞树,大家可以期待哦~

效果展示:

代码

别人都手绘圣诞树,身为程序猿的我们可以用C语言编写一个圣诞树出来,可能C语言的效果没那么炫酷,后面我在看看弄个带音乐或者带雪花的版本出来,大家先用这个小小的准备一些吧~

代码如下:

 

#include 
#include 
#include 
#define PI 3.14159265359
float sx, sy;
float sdCircle(float px, float py, float r) {
  float dx = px - sx, dy = py - sy;
  return sqrtf(dx * dx + dy * dy) - r;
}
float opUnion(float d1, float d2) {
  return d1 < d2 ? d1 : d2;
}
#define T px + scale * r* cosf(theta), py + scale * r * sin(theta)
int ribbon() {
  float x = (fmodf(sy, 0.1f) / 0.1f - 0.5f) * 0.5f;
  return sx >= x - 0.05f && sx <= x + 0.05f;
}
float f(float px, float py, float theta, float scale, int n) {
  float d = 0.0f;
  for (float r = 0.0f; r < 0.8f; r += 0.02f)
    d = opUnion(d, sdCircle(T, 0.05f * scale * (0.95f - r)));
  if (n > 0)
    for (int t = -1; t <= 1; t += 2) {
      float tt = theta + t * 1.8f;
      float ss = scale * 0.9f;
      for (float r = 0.2f; r < 0.8f; r += 0.1f) {
        d = opUnion(d, f(T, tt, ss * 0.5f, n - 1));
        ss *= 0.8f;
      }
    }
  return d;
}
int main(int argc, char* argv[]) {
  int n = argc > 1 ? atoi(argv[1]) : 3;
  float zoom = argc > 2 ? atof(argv[2]) : 1.0f;
  for (sy = 0.8f; sy > 0.0f; sy -= 0.02f / zoom, putchar('
'))
    for (sx = -0.35f; sx < 0.35f; sx += 0.01f / zoom) {
      if (f(0, 0, PI * 0.5f, 1.0f, n) < 0.0f) {
        if (sy < 0.1f)
          putchar('.');
        else {
          if (ribbon())
            putchar('=');
          else
            putchar("...................................#j&o"[rand() % 32]);
        }
      }
      else
        putchar(' ');
    }
}

 

  审核编辑:汤梓红

打开APP阅读更多精彩内容
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉

全部0条评论

快来发表一下你的评论吧 !

×
20
完善资料,
赚取积分