正弦波图形
ZXB.C
/* 正弦波图形 ZXB.C 程序设计:谢春 2000.1.1.*/
/* a, b : 背景颜色 a=0--15 画笔颜色 b=15--0 */
/* x, y : 水平移动图形 x=0--639 垂直移动图形 y=0--479 */
/* r1,r2: 水平方向半径 r1=0--320 垂直方向半径 r2=0--240 */
/* i, j : 心形曲线叶片 i=1--24 心形曲线弧度 j=0--2*PI */
#include"graphics.h" /*调用图形库函数 */
#include"math.h" /*调用数学函数 */
#include"stdio.h" /*调用标准I/O函数*/
#define PI 3.141596 /*宏定义PI字符串 */
main() /*主函数*/
{
int a=1,b,h=40,n,x,y;
float j; /*定义单精度浮点型变量*/
int gdriver=DETECT,gmode; /*定义整型变量gdriver,gmode*/
initgraph(&gdriver,&gmode," "); /*定义变量后,初始化图形系统*/
cleardevice();
setbkcolor(a); /*背景颜色*/
printf("\n");
printf("\n");
printf(" 正弦波函数曲线\n");
printf(" C 语言图形程序设计\n");
printf("\n");
printf(" 背景颜色\n");
printf(" setbkcolor(int color);\n");
printf(" 画笔颜色\n");
printf(" setcolor(int color);\n");
printf(" 画像素点函数\n");
printf(" putpexel(x,y,color);\n");
printf("\n");
printf(" 绘制图形语句\n");
printf(" 正弦波函数曲线\n");
printf(" for (j=0;j<=2*PI;j+=PI/9999) \n");
printf(" { \n");
printf(" b=13-a,x=5+j*50,y=120*a; \n");
printf(" putpixel(x,y-h*sin(2*a*j),b);\n");
printf(" } \n");
printf("\n");
printf(" 按任意键继续 !\n");
setcolor(3);
setlinestyle(0,0,3); /*实线线宽3*/
rectangle(2,2,637,477); /*绘制图纸边框*/
setcolor(2);
setlinestyle(0,0,1); /*实线线宽1*/
rectangle(6,6,318,473); /*绘制左窗口框*/
rectangle(322,6,633,473); /*绘制右窗口框*/
getch();
/*画一幅,擦一幅*/
for (n=1;n<4;n++) /*设置循环演示次数*/
{
setviewport(323,7,632,472,1); /*设置右窗口*/
for (a=1;a<4;a++)
{
for (j=0;j<=2*PI;j+=PI/99999) /*绘制正弦波*/
{
b=13-a,x=5+j*50,y=120*a;
putpixel(x,y-h*sin(2*a*j),b);
putpixel(x,y-h*sin(2*a*j)+2,b);
}
getch();
}
clearviewport();
getch();
}
closegraph(); /*关闭图形系统,返回文本模式*/
}