继续
上一节中我教给您三角形和四边形的绘制方法。这一节将教您给三角形和四边形添加2种不同类型的着色方法。使用Flat coloring(单调着色)给四边形涂上固定的一种颜色。使用Smooth coloring(平滑着色)将三角形的三个顶点的不同颜色混合在一起,创建漂亮的色彩混合。
继续在上节的glDraw上修改。
Procedure glDraw();
Begin
glClear(GL_COLOR_BUFFER_BIT Or GL_DEPTH_BUFFER_BIT); // 清除屏幕和深度缓存
glLoadIdentity(); // 重置当前的模型观察矩阵
glTranslatef(-1.5, 0.0, -6.0); // 左移 1.5 单位,并移入屏幕 6.0
glBegin(GL_TRIANGLES); // 绘制三角形
//glColor3f(r,g,b)。括号中的三个参数依次是红、绿、蓝三色分量。
//取值范围可以从0,0到1.0。类似于以前所讲的清除屏幕背景命令。
//我们将颜色设为红色(纯红色,无绿色,无蓝色)。
//接下来的一行代码设置三角形的第一个顶点(三角形的上顶点),
//并使用当前颜色(红色)来绘制。从现在开始所有的绘制的对象的颜色都是红色,
//直到我们将红色改变成别的什么颜色。
glColor3f(1.0, 0.0, 0.0); //设置当前色为红色
glVertex3f(0.0, 1.0, 0.0); // 上顶点
//第一个红色顶点已经设置完毕。
//接下来我们设置第二个绿色顶点。三角形的左下顶点被设为绿色。
glColor3f(0.0, 1.0, 0.0); //设置当前色为绿色
glVertex3f(-1.0, -1.0, 0.0); // 左下
//三角形的右下顶点。将颜色设为蓝色
//glEnd()出现后,三角形将被填充。
//但是因为每个顶点有不同的颜色,因此看起来颜色从每个角喷出,
//并刚好在三角形的中心汇合,三种颜色相互混合。这就是平滑着色。
glColor3f(0.0, 0.0, 1.0); //设置当前色为蓝色
glVertex3f(1.0, -1.0, 0.0); // 右下
glEnd(); // 三角形绘制结束
glTranslatef(3.0, 0.0, 0.0); // 右移3单位
//现在我们绘制一个单调着色-紫色的正方形。
//最重要的是要记住,设置当前色之后绘制的所有东东都是当前色的。
//以后您所创建的每个工程都要使用颜色。
//即便是在完全采用纹理贴图的时候,
//glColor3f仍旧可以用来调节纹理的色调。
//等等....,以后再说吧。
//(呵呵,原书是蓝色,但是我喜欢紫色)
glBegin(GL_QUADS); // 绘制正方形
glColor3f(0.6, 0.2, 2.0); //设置当前色为紫色
glVertex3f(-1.0, 1.0, 0.0); // 左上
glVertex3f(1.0, 1.0, 0.0); // 右上
glVertex3f(1.0, -1.0, 0.0); // 左下
glVertex3f(-1.0, -1.0, 0.0); // 右下
glEnd(); // 正方形绘制结束
End;
运行一下看看效果