【计算机图形学】三维图形投影和消隐(三视图构造)

模块4-1 三维图形投影和消隐

一 实验目的

  1. 编写三维图形各种变换的投影算法

二 实验内容

1:自行选择三维物体(不能选长方体),建立坐标系,给定点的三维坐标值,建立边表结构。完成三视图。


实验结果如下图所示:

左上显示为主视图,右上显示为侧视图,右下显示为俯视图。

 

三 程序说明

最终的实验代码如下表所示:

1

//

// 程序名称:实验4-1

// 功    能:实现预设图像的三视图显示

// 编译环境:VS2019,EasyX_20220116

// 最后修改:2022-4-8

#include <graphics.h>

#include <conio.h>

#include <iostream>

#include <math.h>

using namespace std;

//和分割线之间的距离

const int gap = 50;

//预设三维体的点坐标

int X[33] = { 0,0,0,0,0,0,0,0,100,100,0,100,100,100,100,100,100,100,100,0,0,0,0,100,100,100,100,0,0,0,0,100,100 };

int Y[33] = { 0,0,250,250,200,150,0,0,0,0,0,0,150,200,250,250,0,0,150,150,0,150,200,200,150,200,250,250,200,250,250,250,250 };

int Z[33]= { 100,0,0,50,50,100,100,0,0,100,100,100,100,50,50,0,0,100,100,100,100,100,50,50,100,50,50,50,50,50,0,0,50 };

//顶点总数

const int num = 33;

//三视图实现函数

void fun() {

    //正视图

    POINT* front = new POINT[num];

    for (int i = 0; i < num; i++) {

         front[i].x = X[i] + 500 + gap;

         front[i].y = 350 - Z[i] - gap;

    }

    //侧视图

    POINT* side = new POINT[num];

    for (int i = 0; i < num; i++) {

         side[i].x = Y[i] + 250 - gap;

         side[i].y = 350 - Z[i] - gap;

    }

    //俯视图

    POINT* up = new POINT[num];

    for (int i = 0; i < num; i++) {

         up[i].x = X[i] + 500 + gap;

         up[i].y = 600 - Y[i] + gap;

    }

    setcolor(YELLOW);

    for (int i = 0; i < num - 1; i++) {

         line(front[i].x, front[i].y, front[i + 1].x, front[i + 1].y);

         line(side[i].x, side[i].y, side[i + 1].x, side[i + 1].y);

         line(up[i].x, up[i].y, up[i + 1].x, up[i + 1].y);

    }

    free(front);

    free(side);

    free(up);

}

int main() {

    initgraph(1000, 700);

    line(0, 350, 1000, 350);

    line(500, 0, 500, 700);

    fun();

    _getch();

    closegraph();

    return 0;

}

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

MorleyOlsen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值