1

我在运行 OpenGL 代码时遇到错误“0xC000041D:在用户回调期间遇到未处理的异常”。调试器表明错误发生在这里:

调试器屏幕

下面给出了发生错误的函数和调用函数。

你能帮我找出这个错误的原因吗?

double maxDistance(Point_2D* bez, int deg)
{
int i;
double maxheight;
double height[30];

// Computing baseline vector and its magnitude
Point_2D baselineVector;
baselineVector.x = bez[deg].x - bez[0].x;
baselineVector.y = bez[deg].y - bez[0].y;
double baselineMag = sqrt((baselineVector.x*baselineVector.x) + (baselineVector.y*baselineVector.y));

double crossprod[3];

double crossprodMag;

// Computing height of a intermediate control points from baseline
Point_2D cpVector; // Vector from first control point to intermediate control point
for (i = 1; i < deg; i++)
{
    cpVector.x = bez[i].x - bez[0].x;
    cpVector.y = bez[i].y - bez[0].y;

    // Computing cross product of baseline vector and control point vector
    //z coordinates of baseline and control point vectors are 0
    crossprod[0] = ((baselineVector.y * 0) - (0 * cpVector.y));
    crossprod[1] = -((baselineVector.x * 0) - (0 * cpVector.x));
    crossprod[2] = ((baselineVector.x * cpVector.y) - (baselineVector.y * cpVector.x));
    crossprodMag = sqrt((crossprod[0] * crossprod[0]) + (crossprod[1] * crossprod[1]) + (crossprod[2] * crossprod[2]));
    height[i] = crossprodMag / baselineMag;
}

// Finding maximum height of a control point from baseline
maxheight = height[0];
for (i = 0; i < deg; i++)
{
    if (maxheight < height[i])
        maxheight = height[i];
}


return maxheight;
}
void plotBezier(Point_2D* bez, int deg)
{
Point_2D* leftBez= (Point_2D*)malloc((deg + 1)*sizeof(Point_2D));
Point_2D* rightBez=(Point_2D*)malloc((deg + 1)*sizeof(Point_2D));;
double height = maxDistance(bez, deg);
if (height < flat_thresh)
{
    drawLine(bez[0], bez[deg]);
    return;
}
else
{
    midSubdivideBezier(bez, deg, leftBez, rightBez);
    plotBezier(leftBez, deg);
    plotBezier(rightBez, deg);
}
free(leftBez);
free(rightBez);
 }



//============================================================
void adaptiveRender()
 {
Point_2D*  bez =(Point_2D*) malloc(30 * sizeof(Point_2D)); // assume the degree is not greater than 29.
int      i;

for (i = bcr.degree; i< bcr.deBoor_count; i++) // Determining segments between the kth knot and the (n+1)th knot
{
    if (!(fabs(bcr.knots[i] - bcr.knots[i + 1]) < 0.00001)) // No segment when adjacent knots are equal
    {
        extractBezier(bez, i);        // Extract the i-th Bezier curve
        plotBezier(bez, bcr.degree);   // Adaptively plot a Bezier curve 
    }
}
free(bez);
}
4

0 回答 0