NEFU计算机图形学实验四

2024-04-28 01:04

本文主要是介绍NEFU计算机图形学实验四,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

编写二次插值样条曲线生成函数,然后利用该函数根据自己设计的型值点绘制出相应的曲线图形。

// erView.cpp : implementation of the CErView class
//#include "stdafx.h"
#include "er.h"#include "erDoc.h"
#include "erView.h"#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif/
// CErView
void er(POINT *p,int n,CDC* pDC)
{int x,y,i,j,k=10;double t1,t2,t3,t,a,b,c,d;p[0].x=p[1].x;p[0].y=p[1].y;p[n+1].x=p[n].x;p[n+1].y=p[n].y;t=0.5/k;pDC->MoveTo(p[1].x,p[1].y);for(i=1;i<n;i++){for(j=1;j<k;j++){t1=j*t;t2=t1*t1;t3=t1*t2;a=4.0*t2-t1-4.0*t3;		b=1.0-10.0*t2+12.0*t3;	c=t1+8.0*t2-12.0*t3;	d=4.0*t3-2.0*t2;		x=(int)(a*p[i-1].x+b*p[i].x+c*p[i+1].x+d*p[i+2].x);y=(int)(a*p[i-1].y+b*p[i].y+c*p[i+1].y+d*p[i+2].y);pDC->LineTo(x,y);}pDC->LineTo(p[i+1].x,p[i+1].y);}
}IMPLEMENT_DYNCREATE(CErView, CView)BEGIN_MESSAGE_MAP(CErView, CView)//{{AFX_MSG_MAP(CErView)// NOTE - the ClassWizard will add and remove mapping macros here.//    DO NOT EDIT what you see in these blocks of generated code!//}}AFX_MSG_MAP// Standard printing commandsON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()/
// CErView construction/destructionCErView::CErView()
{// TODO: add construction code here}CErView::~CErView()
{
}BOOL CErView::PreCreateWindow(CREATESTRUCT& cs)
{// TODO: Modify the Window class or styles here by modifying//  the CREATESTRUCT csreturn CView::PreCreateWindow(cs);
}/
// CErView drawingvoid CErView::OnDraw(CDC* pDC)
{CErDoc* pDoc = GetDocument();ASSERT_VALID(pDoc);// TODO: add draw code for native data hereint n=4;POINT ps[6];ps[1].x=25;ps[1].y=400;ps[2].x=100;ps[2].y=100;ps[3].x=175;ps[3].y=400;ps[4].x=250;ps[4].y=100;er(ps,n,pDC);}/
// CErView printingBOOL CErView::OnPreparePrinting(CPrintInfo* pInfo)
{// default preparationreturn DoPreparePrinting(pInfo);
}void CErView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{// TODO: add extra initialization before printing
}void CErView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{// TODO: add cleanup after printing
}/
// CErView diagnostics#ifdef _DEBUG
void CErView::AssertValid() const
{CView::AssertValid();
}void CErView::Dump(CDumpContext& dc) const
{CView::Dump(dc);
}CErDoc* CErView::GetDocument() // non-debug version is inline
{ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CErDoc)));return (CErDoc*)m_pDocument;
}
#endif //_DEBUG/
// CErView message handlers

编写任意阶次的Bezier曲线生成函数,然后利用该函数根据自己设计的控制点绘制出相应的曲线图形。

// renView.cpp : implementation of the CRenView class
//#include "stdafx.h"
#include "ren.h"#include "renDoc.h"
#include "renView.h"#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif/
// CRenView
double powi(double v,int k){double temp=1.0;if(k==0||v==0)return 1;else {for(int i=1;i<=k;i++)temp=temp*v;}return temp;}long fac(int m){int i;long temp=1;if(m==1)return 1;else {for(i=2;i<=m;i++)temp=temp*i;}return temp;}void Bezier(POINT *p,int n,CDC *pDC){int x,y,i,j,k=100;double t=1.0/k,t1,u,v;double temp,temp1,temp2,bi;pDC->MoveTo(p[0].x,p[0].y);for(j=1;j<k;j++){t1=j*t;u=t1;v=1-u;x=0;y=0;for(i=0;i<=n;i++){temp=double(fac(n)/fac(i)/fac(n-i));temp1=powi(u,i);temp2=powi(v,n-i);bi=temp*temp1*temp2;x=x+bi*p[i].x;y=y+bi*p[i].y;}pDC->LineTo(x,y);}pDC->LineTo(p[n].x,p[n].y);}IMPLEMENT_DYNCREATE(CRenView, CView)BEGIN_MESSAGE_MAP(CRenView, CView)//{{AFX_MSG_MAP(CRenView)// NOTE - the ClassWizard will add and remove mapping macros here.//    DO NOT EDIT what you see in these blocks of generated code!//}}AFX_MSG_MAP// Standard printing commandsON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()/
// CRenView construction/destructionCRenView::CRenView()
{// TODO: add construction code here}CRenView::~CRenView()
{
}BOOL CRenView::PreCreateWindow(CREATESTRUCT& cs)
{// TODO: Modify the Window class or styles here by modifying//  the CREATESTRUCT csreturn CView::PreCreateWindow(cs);
}/
// CRenView drawingvoid CRenView::OnDraw(CDC* pDC)
{CRenDoc* pDoc = GetDocument();ASSERT_VALID(pDoc);int n=5;CPoint ps[6]={CPoint(25,400),CPoint(100,100),CPoint(170,400),CPoint(250,20),CPoint(450,300),CPoint(350,400)};CPen pen1(PS_DASHDOT,1,RGB(28,28,28));pDC->SelectObject(&pen1);pDC->Polyline(ps,6);CPen pen2(PS_DASHDOT,2,RGB(255,0,0));pDC->SelectObject(&pen2);Bezier(ps,n,pDC);
} /
// CRenView printingBOOL CRenView::OnPreparePrinting(CPrintInfo* pInfo)
{// default preparationreturn DoPreparePrinting(pInfo);
}void CRenView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{// TODO: add extra initialization before printing
}void CRenView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{// TODO: add cleanup after printing
}/
// CRenView diagnostics#ifdef _DEBUG
void CRenView::AssertValid() const
{CView::AssertValid();
}void CRenView::Dump(CDumpContext& dc) const
{CView::Dump(dc);
}CRenDoc* CRenView::GetDocument() // non-debug version is inline
{ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CRenDoc)));return (CRenDoc*)m_pDocument;
}
#endif //_DEBUG/
// CRenView message handlers

编写三次B样条曲线生成函数,然后利用该函数根据自己设计的控制点绘制出相应的曲线图形。

// sanView.cpp : implementation of the CSanView class
//#include "stdafx.h"
#include "san.h"#include "sanDoc.h"
#include "sanView.h"#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif/
// CSanView
void BSpLine(POINT *p,int n,CDC* pDC)
{int x,y,i,j,k=1000;double t,t1,t2,t3,a,b,c,d;t=1.0/k;p[0].x=2*p[1].x-p[2].x;p[0].y=2*p[1].y-p[2].y;p[n].x=2*p[n-1].x-p[n-2].x;p[n].y=2*p[n-1].y-p[n-2].y;pDC->MoveTo(p[1].x,p[1].y);for(i=1;i<n-1;i++)for(j=1;j<=k;j++){t1=j*t;t2=t1*t1;t3=t2*t1;a=(3*t2-t3-3*t1+1)/6;b=(3*t3-6*t2+4)/6;c=(3*t2-3*t3+3*t1+1)/6;d=t3/6;x=int(a*p[i-1].x+b*p[i].x+c*p[i+1].x+d*p[i+2].x);y=int(a*p[i-1].y+b*p[i].y+c*p[i+1].y+d*p[i+2].y);pDC->LineTo(x,y);}
}IMPLEMENT_DYNCREATE(CSanView, CView)BEGIN_MESSAGE_MAP(CSanView, CView)//{{AFX_MSG_MAP(CSanView)// NOTE - the ClassWizard will add and remove mapping macros here.//    DO NOT EDIT what you see in these blocks of generated code!//}}AFX_MSG_MAP// Standard printing commandsON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()/
// CSanView construction/destructionCSanView::CSanView()
{// TODO: add construction code here}CSanView::~CSanView()
{
}BOOL CSanView::PreCreateWindow(CREATESTRUCT& cs)
{// TODO: Modify the Window class or styles here by modifying//  the CREATESTRUCT csreturn CView::PreCreateWindow(cs);
}/
// CSanView drawingvoid CSanView::OnDraw(CDC* pDC)
{CSanDoc* pDoc = GetDocument();ASSERT_VALID(pDoc);// TODO: add draw code for native data hereint n=5;POINT ps[6];ps[1].x=350;ps[1].y=250;ps[2].x=500;ps[2].y=20;ps[3].x=600;ps[3].y=250;ps[4].x=750;ps[4].y=30;CPen pen1(PS_DASHDOT,2,RGB(0,0,255));pDC->SelectObject(&pen1);BSpLine(ps,n,pDC);CPen pen2(PS_DASHDOT,1,RGB(28,28,28));pDC->SelectObject(&pen2);pDC->Polyline(ps,6);} /
// CSanView printingBOOL CSanView::OnPreparePrinting(CPrintInfo* pInfo)
{// default preparationreturn DoPreparePrinting(pInfo);
}void CSanView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{// TODO: add extra initialization before printing
}void CSanView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{// TODO: add cleanup after printing
}/
// CSanView diagnostics#ifdef _DEBUG
void CSanView::AssertValid() const
{CView::AssertValid();
}void CSanView::Dump(CDumpContext& dc) const
{CView::Dump(dc);
}CSanDoc* CSanView::GetDocument() // non-debug version is inline
{ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CSanDoc)));return (CSanDoc*)m_pDocument;
}
#endif //_DEBUG/
// CSanView message handlers

这篇关于NEFU计算机图形学实验四的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/941967

相关文章

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

STM32(十一):ADC数模转换器实验

AD单通道: 1.RCC开启GPIO和ADC时钟。配置ADCCLK分频器。 2.配置GPIO,把GPIO配置成模拟输入的模式。 3.配置多路开关,把左面通道接入到右面规则组列表里。 4.配置ADC转换器, 包括AD转换器和AD数据寄存器。单次转换,连续转换;扫描、非扫描;有几个通道,触发源是什么,数据对齐是左对齐还是右对齐。 5.ADC_CMD 开启ADC。 void RCC_AD

计算机视觉工程师所需的基本技能

一、编程技能 熟练掌握编程语言 Python:在计算机视觉领域广泛应用,有丰富的库如 OpenCV、TensorFlow、PyTorch 等,方便进行算法实现和模型开发。 C++:运行效率高,适用于对性能要求严格的计算机视觉应用。 数据结构与算法 掌握常见的数据结构(如数组、链表、栈、队列、树、图等)和算法(如排序、搜索、动态规划等),能够优化代码性能,提高算法效率。 二、数学基础

HNU-2023电路与电子学-实验3

写在前面: 一、实验目的 1.了解简易模型机的内部结构和工作原理。 2.分析模型机的功能,设计 8 重 3-1 多路复用器。 3.分析模型机的功能,设计 8 重 2-1 多路复用器。 4.分析模型机的工作原理,设计模型机控制信号产生逻辑。 二、实验内容 1.用 VERILOG 语言设计模型机的 8 重 3-1 多路复用器; 2.用 VERILOG 语言设计模型机的 8 重 2-1 多

java计算机毕设课设—停车管理信息系统(附源码、文章、相关截图、部署视频)

这是什么系统? 资源获取方式在最下方 java计算机毕设课设—停车管理信息系统(附源码、文章、相关截图、部署视频) 停车管理信息系统是为了提升停车场的运营效率和管理水平而设计的综合性平台。系统涵盖用户信息管理、车位管理、收费管理、违规车辆处理等多个功能模块,旨在实现对停车场资源的高效配置和实时监控。此外,系统还提供了资讯管理和统计查询功能,帮助管理者及时发布信息并进行数据分析,为停车场的科学

《计算机视觉工程师养成计划》 ·数字图像处理·数字图像处理特征·概述~

1 定义         从哲学角度看:特征是从事物当中抽象出来用于区别其他类别事物的属性集合,图像特征则是从图像中抽取出来用于区别其他类别图像的属性集合。         从获取方式看:图像特征是通过对图像进行测量或借助算法计算得到的一组表达特性集合的向量。 2 认识         有些特征是视觉直观感受到的自然特征,例如亮度、边缘轮廓、纹理、色彩等。         有些特征需要通

【python计算机视觉编程——7.图像搜索】

python计算机视觉编程——7.图像搜索 7.图像搜索7.1 基于内容的图像检索(CBIR)从文本挖掘中获取灵感——矢量空间模型(BOW表示模型)7.2 视觉单词**思想****特征提取**: 创建词汇7.3 图像索引7.3.1 建立数据库7.3.2 添加图像 7.4 在数据库中搜索图像7.4.1 利用索引获取获选图像7.4.2 用一幅图像进行查询7.4.3 确定对比基准并绘制结果 7.

【python计算机视觉编程——8.图像内容分类】

python计算机视觉编程——8.图像内容分类 8.图像内容分类8.1 K邻近分类法(KNN)8.1.1 一个简单的二维示例8.1.2 用稠密SIFT作为图像特征8.1.3 图像分类:手势识别 8.2贝叶斯分类器用PCA降维 8.3 支持向量机8.3.2 再论手势识别 8.4 光学字符识别8.4.2 选取特征8.4.3 多类支持向量机8.4.4 提取单元格并识别字符8.4.5 图像校正

Python计算机视觉编程 第十章

目录 一、OpenCv基础知识 1.读取和写入图像 2.颜色空间 3.显示图像和结果 二、处理视频 1.输入视频 2.将视频读取到NumPy数组中 三、跟踪 1.光流 2.Lucas-Kanade算法 一、OpenCv基础知识 OpenCV 自带读取、写入图像函数以及矩阵操作和数学库。 1.读取和写入图像 import cv2# 读取图像im = c

2025届计算机毕业设计:如何构建Java SpringBoot+Vue个人健康档案管理系统?

✍✍计算机编程指导师 ⭐⭐个人介绍:自己非常喜欢研究技术问题!专业做Java、Python、微信小程序、安卓、大数据、爬虫、Golang、大屏等实战项目。 ⛽⛽实战项目:有源码或者技术上的问题欢迎在评论区一起讨论交流! ⚡⚡ Java实战 | SpringBoot/SSM Python实战项目 | Django 微信小程序/安卓实战项目 大数据实战项目 ⚡⚡文末获取源码 文章目录