DDA画线算法例题

1.题目(计算机图形图像技术【中国矿业大学】)


使用DDA画线算法绘制端点为(5,6)和(13,12)的线段。

2.原理


计算机图形学(一)--DDA画线算法 - 哔哩哔哩 (bilibili.com)

3.答案


cpp 复制代码
#include <iostream>
#include <cmath>
using namespace std;

// DDA算法函数
void DDA(double x1, double y1, double x2, double y2) {
    // 计算x和y的增量
    double Increment = (y2 - y1) / (x2 - x1);
    printf("m=%f\n",Increment);
    double BeginY=y1;
    // 绘制点
    for (int i = x1,n=0; i <= x2; i++,n++) {
        if (n!=0)
        printf("x%d=%d,y%d=y%d+m=%.2f,Draw(%d,%d)\n",
                        n,  i,  n, n,   BeginY, i ,(int)round(BeginY));
        else
        printf("x%d=%d,y%d=%.2f,Draw(%d,%d)\n",
               n,  i,  n,   BeginY, i ,(int)round(BeginY));
        BeginY+=Increment;
    }
}

int main() {
    // 调用DDA算法函数
    DDA(5, 6, 13, 12);
   //DDA(20, 10, 28, 16);
    return 0;
}

4.结果


  1. m=0.750000
  2. x0=5,y0=6.00,Draw(5,6)
  3. x1=6,y1=y1+m=6.75,Draw(6,7)
  4. x2=7,y2=y2+m=7.50,Draw(7,8)
  5. x3=8,y3=y3+m=8.25,Draw(8,8)
  6. x4=9,y4=y4+m=9.00,Draw(9,9)
  7. x5=10,y5=y5+m=9.75,Draw(10,10)
  8. x6=11,y6=y6+m=10.50,Draw(11,11)
  9. x7=12,y7=y7+m=11.25,Draw(12,11)
  10. x8=13,y8=y8+m=12.00,Draw(13,12)
相关推荐
笙笙_8 分钟前
斯坦福UE4 C++课学习补充25:AI感知组件
c++·ue4·虚幻引擎
音视频牛哥10 分钟前
计算机视觉之YOLO算法基本原理和应用场景
算法·yolo·计算机视觉·yolo11·yolo10·yolo目标检测
Gabriel Drop Out10 分钟前
22年408数据结构
算法
通信仿真实验室19 分钟前
(20)MATLAB使用卡方(chi-square)分布生成Nakagami-m分布
开发语言·算法·matlab·概率论
GISer_Jing29 分钟前
前端Javascript常见算法题(一)【待学】
算法
白葵新33 分钟前
PCL 3D-SIFT关键点检测(Z方向梯度约束
c++·人工智能·深度学习·算法·计算机视觉·3d
为为-180-3121-145536 分钟前
R语言生物群落(生态)数据统计分析与绘图实践技术应用
开发语言·r语言
茗~56938 分钟前
【Python】程序开发环境构建与数据输入输出
开发语言·python
好奇的菜鸟39 分钟前
Python中的with关键字和文件操作
开发语言·python
爱吃饭团的饭桶1 小时前
【附源码】Python :打家劫舍
开发语言·python·代理模式