C++ 布雷森厄姆';s线算法。是否存在文件的ncurses输出?

C++ 布雷森厄姆';s线算法。是否存在文件的ncurses输出?,c++,algorithm,bresenham,C++,Algorithm,Bresenham,我有作业,ASCII线图抽屉。我必须把图表打印成文件。Bresenham直线算法的所有算法都有函数SetPixel(x,y);在循环中。此功能必须按x和y打印像素。NCurses库是在windows控制台上打印的理想解决方案,但我必须打印到file.txt。我认为Ncurses只在窗口控制台上打印。我的问题:在这段代码中如何实现SetPixel打印到文件的功能 void Line( const float x1, const float y1, const float x2, const flo

我有作业,ASCII线图抽屉。我必须把图表打印成文件。Bresenham直线算法的所有算法都有函数SetPixel(x,y);在循环中。此功能必须按x和y打印像素。NCurses库是在windows控制台上打印的理想解决方案,但我必须打印到file.txt。我认为Ncurses只在窗口控制台上打印。我的问题:在这段代码中如何实现SetPixel打印到文件的功能

void Line( const float x1, const float y1, const float x2, const float y2, const Color& color )
{
        // Bresenham's line algorithm
    const bool steep = (fabs(y2 - y1) > fabs(x2 - x1));
    if(steep)
    {
        std::swap(x1, y1);
        std::swap(x2, y2);
    }

    if(x1 > x2)
    {
        std::swap(x1, x2);
        std::swap(y1, y2);
    }

    const float dx = x2 - x1;
    const float dy = fabs(y2 - y1);

    float error = dx / 2.0f;
    const int ystep = (y1 < y2) ? 1 : -1;
    int y = (int)y1;

    const int maxX = (int)x2;

    for(int x=(int)x1; x<maxX; x++)
    {
        if(steep)
                {
                        SetPixel(y,x, color);
                }
        else
                {
                        SetPixel(x,y, color);
                }

                error -= dy;
            if(error < 0)
            {
                y += ystep;
                error += dx;
            }
    }
}
void行(常量浮点x1、常量浮点y1、常量浮点x2、常量浮点y2、常量颜色和颜色)
{
//Bresenham直线算法
常数布尔陡峭=(晶圆厂(y2-y1)>晶圆厂(x2-x1));
如果(陡峭)
{
标准:交换(x1,y1);
标准:交换(x2,y2);
}
如果(x1>x2)
{
标准:交换(x1,x2);
标准:互换(y1,y2);
}
常量浮点dx=x2-x1;
常数浮点dy=fabs(y2-y1);
浮动误差=dx/2.0f;
常数int ystep=(y1对于(int x=(int)x1;x要将其保存到文件中,您需要在将数据写入文件之前进行一些初始计算。我建议您创建一个数据结构(可能是一个数组)来跟踪每个“像素”。例如,您可以声明

char graph[100][100];

graph
的每个元素要么是一个空格,要么是一个
'X'
。使用Bresenham的line算法计算
graph
中的元素,这些元素应设置为
'X'
,然后将数组写入文件。

要将其保存到文件中,您需要在将数据写入文件之前进行一些初始计算。我建议创建一个数据结构(可能是一个数组)来跟踪每个“像素”

char graph[100][100];

graph
的每个元素要么是一个空格,要么是一个
'X'
。使用Bresenham的line算法计算
graph
中的元素,这些元素应设置为
'X'
,然后将数组写入文件。

您不需要NCurses来保存ASCII,只需创建一个纯文本文件并保存Bresenham的alg的输出算法在那里。我建议你也使用一个。你不需要NCurses来保存ASCII,只需创建一个纯文本文件并将Bresenham算法的输出保存在那里。我建议你也使用一个。首先创建一个动态结构的实例,最好是
std::vector
。我建议将x和y分开,以方便使用,例如
std::向量x_点,y_点
。然后,从循环体的
记录所有坐标,即(x,y)。然后创建一个函数。

首先创建一个动态结构的实例,最好是
std::vector
。为了方便起见,我建议将x和y分开,例如
std::vector x_点,y_点
。然后,从
for loop
主体中,记录所有坐标,即(x,y)。然后创建一个函数