我正在将2000+点的图形绘制为pdf文件。 pdf的分辨率为612 x792。由于宽度为612,因此我只能将612点绘制到pdf。我将1点映射为1像素。如何将所有2000多个样本绘制到pdf。我正在使用这个lib http://www.vulcanware.com/cpp_pdf/index.html

最佳答案

选项1:使用x = (x * 612) / 2000缩放点。这意味着如果2个点彼此接近(包括“相似的y”),它们将互相覆盖。

选项2:将每个点视为一个正方形;并计算已缩放的“左侧x”和“右侧x”的浮点值(left_x = ( (x-width/2.0) * 612.0) / 2000.0; right_x = ( (x+width/2.0) * 612.0) / 2000.0;),并通过计算每个目标的“正方形重叠的目标像素区域”,使用抗锯齿功能绘制正方形与正方形重叠的像素。在这种情况下,您需要执行“dest_pixel = max(dest_pixel + area,1);”在正方形重叠时钳位像素值。

选项3:将整个 object 旋转90度,以使“x轴”垂直向下移动到页面(并在必要时可以分成多页);如果这对y造成了问题,则对y使用上述选项之一。

请注意,“选项2”可以同时在(垂直和水平)两个方向上完成。为此,首先确定正方形的边缘,例如:

    left_x = point_x / MAX_SRC_X * MAX_DEST_X;
    right_x = (point_x + 1) / MAX_SRC_X * MAX_DEST_X;
    top_y = point_y / MAX_SRC_Y * MAX_DEST_Y;
    bottom_y = (point_y + 1) / MAX_SRC_Y * MAX_DEST_Y;

然后有一个“针对受影响的每一行”循环,该循环计算受影响的每一行,例如:
    for(int y = top_y; y < bottom_y; y++) {
        row_top = fmax(y, top_y);
        row_bottom = fmin(y+1, bottom_y);
        row_weight = row_bottom - row_top;

然后有一个类似的“对于受影响的每一列”循环,例如:
        for(int x = left_x; x < right_x; x++) {
            column_left = fmax(x, left_x);
            column_right = fmin(x+1, right_x);
            column_weight = column_right - column_left;

然后计算像素的面积,设置像素并完成循环:
            dest_pixel_area = row_weight * column_weight;
            pixel[y][x].red = min(pixel[y][x].red + dest_pixel_area * red, MAX_RED);
            pixel[y][x].green = min(pixel[y][x].green + dest_pixel_area * green, MAX_GREEN);
            pixel[y][x].blue = min(pixel[y][x].blue + dest_pixel_area * blue, MAX_BLUE);
        }
    }

注意:上面所有代码均未经测试和简化。将循环分成“第一行/列;仅针对中间区域的循环;然后最后一行/列”以删除大部分fmin / fmax可能更快。

如果您只需要在一个方向上执行此操作,请删除不需要的方向的零件,并将1.0用作相应的row_weightcolumn_weight

10-05 22:58