C和OpenGL结合生成钻石图形的解决方案
2009-09-19 08:35
274 查看
说明:程序使用了OpenGL,因此用VS编译时,就要搭建使用OpenGL的环境。具体方法如下,
1、下载http://www.opengl.org/resources/libraries/glut/glutdlls37beta.zip并解压;
2、在vs2008中,把解压文件夹里的glut.h复制到 vs2008安装目录/VC/include/文件夹中,把glut.lib和glut32.lib复制到 vs2008安装目录/VC/lib/文件夹中,把glut.dll和glut32.dll复制到 系统盘/Windows/System32/文件夹中
原代码为
#include "stdafx.h"
#include <glut.h>
#include <math.h>
#include <stdlib.h>
#include <stdio.h>
#define pi 3.14159265
int n=0;
int R=200,CX=250,CY=250;
int *point;
void initGraph(void);
void drawCircle(int cx, int cy, int r);
void display(void);
void drawLine(int x1, int y1, int x2, int y2);
void main(int argc, char **argv){
float w,wi;
glutInit(&argc,argv);
glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB) ;
glutInitWindowSize(500,500);
glutCreateWindow("n阶钻石图案");
initGraph();
printf("请输入钻石图案行数(最小值为3):");
scanf("%u",&n);
if(n>2){
point=(int*)malloc(sizeof(int)*n*2);//申请存储空间
w=2*pi/n;
wi=w/2;
for(int i=0;i<2*n;i+=2){
point[i]=(int)(CX+R*cos(wi));
point[i+1]=(int)(CY+R*sin(wi));
wi+=w;
}
}
glutDisplayFunc(display);
glutMainLoop();
if(point!=NULL)free(point);//释放存储空间
}
void initGraph (void){
glClearColor(0.0,0.0,0.0,0.0);
gluOrtho2D(0.0,500.0,0.0,500.0);//窗口坐标左下角(0,0), 右上角(500,500)
}
void display(void){
glClear(GL_COLOR_BUFFER_BIT) ;
glColor3f(1.0, 1.0, 0.0) ;
drawCircle(CX,CY,R);
for(int i=0;i<2*n-2;i+=2){
for(int j=i+2;j<2*n;j+=2){
drawLine(point[i],point[i+1],point[j],point[j+1]);
}
}
}
// 中点圆算法
void drawCircle(int cx, int cy, int r){
int x=0, y=r;
int d=1-r;
glBegin(GL_POINTS);
glVertex2i(x,y);
while(x<y){
if(d<0)
d+=2*x+3;
else{
d+=2*(x-y)+5;
y--;
}
glVertex2i(x+cx,y+cy);
glVertex2i(cx-x,y+cy);
glVertex2i(x+cx,cy-y);
glVertex2i(cx-x,cy-y);
glVertex2i(y+cx,x+cy);
glVertex2i(cx-y,x+cy);
glVertex2i(y+cx,cy-x);
glVertex2i(cx-y,cy-x);
x++;
}
glEnd();
glFlush() ;
}
void drawLine(int x1, int y1, int x2, int y2) {
glBegin(GL_LINES);
glVertex2d(x1, y1);
glVertex2d(x2, y2);
glEnd();
glFlush() ;
}
当n=9时,运行结果图
1、下载http://www.opengl.org/resources/libraries/glut/glutdlls37beta.zip并解压;
2、在vs2008中,把解压文件夹里的glut.h复制到 vs2008安装目录/VC/include/文件夹中,把glut.lib和glut32.lib复制到 vs2008安装目录/VC/lib/文件夹中,把glut.dll和glut32.dll复制到 系统盘/Windows/System32/文件夹中
原代码为
#include "stdafx.h"
#include <glut.h>
#include <math.h>
#include <stdlib.h>
#include <stdio.h>
#define pi 3.14159265
int n=0;
int R=200,CX=250,CY=250;
int *point;
void initGraph(void);
void drawCircle(int cx, int cy, int r);
void display(void);
void drawLine(int x1, int y1, int x2, int y2);
void main(int argc, char **argv){
float w,wi;
glutInit(&argc,argv);
glutInitDisplayMode(GLUT_SINGLE|GLUT_RGB) ;
glutInitWindowSize(500,500);
glutCreateWindow("n阶钻石图案");
initGraph();
printf("请输入钻石图案行数(最小值为3):");
scanf("%u",&n);
if(n>2){
point=(int*)malloc(sizeof(int)*n*2);//申请存储空间
w=2*pi/n;
wi=w/2;
for(int i=0;i<2*n;i+=2){
point[i]=(int)(CX+R*cos(wi));
point[i+1]=(int)(CY+R*sin(wi));
wi+=w;
}
}
glutDisplayFunc(display);
glutMainLoop();
if(point!=NULL)free(point);//释放存储空间
}
void initGraph (void){
glClearColor(0.0,0.0,0.0,0.0);
gluOrtho2D(0.0,500.0,0.0,500.0);//窗口坐标左下角(0,0), 右上角(500,500)
}
void display(void){
glClear(GL_COLOR_BUFFER_BIT) ;
glColor3f(1.0, 1.0, 0.0) ;
drawCircle(CX,CY,R);
for(int i=0;i<2*n-2;i+=2){
for(int j=i+2;j<2*n;j+=2){
drawLine(point[i],point[i+1],point[j],point[j+1]);
}
}
}
// 中点圆算法
void drawCircle(int cx, int cy, int r){
int x=0, y=r;
int d=1-r;
glBegin(GL_POINTS);
glVertex2i(x,y);
while(x<y){
if(d<0)
d+=2*x+3;
else{
d+=2*(x-y)+5;
y--;
}
glVertex2i(x+cx,y+cy);
glVertex2i(cx-x,y+cy);
glVertex2i(x+cx,cy-y);
glVertex2i(cx-x,cy-y);
glVertex2i(y+cx,x+cy);
glVertex2i(cx-y,x+cy);
glVertex2i(y+cx,cy-x);
glVertex2i(cx-y,cy-x);
x++;
}
glEnd();
glFlush() ;
}
void drawLine(int x1, int y1, int x2, int y2) {
glBegin(GL_LINES);
glVertex2d(x1, y1);
glVertex2d(x2, y2);
glEnd();
glFlush() ;
}
当n=9时,运行结果图
相关文章推荐
- [转]如何设置opengl结合vc开发绚丽的3D图形---操作详解
- 结合shiro 的图形验证码生成
- 结合AnyChart做报表:一个生成AnyChart图形XML数据的工具类
- 使用OpenGL和GLUT,结合双缓冲区生成动画
- 使用OpenGL和GLUT,结合双缓冲区生成动画
- 如何设置opengl结合vc开发绚丽的3D图形---操作详解
- 实现图形Qt学习:三维绘图之OpenGL和Qt的结合
- Opengl生成各种基本图形
- OpenGL绘制简单图形
- 《OpenGL超级宝典》P38“2.6使用OpenGL和GLUT生成动画”勘误
- iOS quartzCore第五章——CAShapeLayer画各种图形 结合UIBezierPath
- 【精品】图形工作站如何确保图纸等重要数据的安全——HC12远程图形工作站解决方案!~
- 生成随机图形
- python结合G2绘制精美图形
- QT中由图形生成SVG文件实现方案
- OpenGL--生成纹理 gluBuild2DMipmaps()与glTexImage2D()的使用方法及区别
- 使用Hutool生成和验证图形验证码
- 纯ASP结合VML生成完美图-柱图
- Java Web实践专题——图形验证码的生成与使用
- Visual Studio 2008 - “error PRJ0003 : 生成 cmd.exe 时出错” 完整解决方案