gpt4 book ai didi

python - 开罗剪辑创建不需要的边缘

转载 作者:太空宇宙 更新时间:2023-11-04 03:44:11 28 4
gpt4 key购买 nike

我正在使用 pyCairo 在表面上绘制移动元素。为了获得更好的性能,我尝试使用“剪辑”功能来仅重绘更大图像的更改部分。不幸的是,它会在图像上产生不需要的边缘。可以看到剪裁的边缘。是否有可能避免这种行为?

enter image description here

import math
import cairo


def draw_stuff(ctx):
""" clears background with solid black and then draws a circle"""
ctx.set_source_rgb (0, 0, 0) # Solid color
ctx.paint()

ctx.arc (0.5, 0.5, 0.5, 0, 2*math.pi)
ctx.set_source_rgb (0, 123, 0)
ctx.fill()

WIDTH, HEIGHT = 256, 256

surface = cairo.ImageSurface (cairo.FORMAT_ARGB32, WIDTH, HEIGHT)
ctx = cairo.Context (surface)

ctx.scale (WIDTH, HEIGHT) # Normalizing the canvas

draw_stuff(ctx)

#Let's draw stuff again, this time only redrawing a small part of the image
ctx.save()
ctx.rectangle(0.2,0.2,0.2,0.2)
ctx.clip()
draw_stuff(ctx)
ctx.restore()

surface.write_to_png ("example.png") # Output to PNG

最佳答案

您应该将裁剪坐标四舍五入为整数(在设备空间中)。参见 http://cairographics.org/FAQ/#clipping_performance

我不知道 Python API,我只是猜测它在 C API 中的工作方式,但它是这样的:

def snap_to_pixels(ctx, x, y):
x, y = ctx.user_to_device(x, y)
# No idea how to round an integer in python,
# this would be round() in C
# (Oh and perhaps you don't want this rounding, but
# instead want to round the top-left corner of your
# rectangle towards negative infinity and the bottom-right
# corner towards positive infinity. That way the rectangle
# would never become smaller to the rounding. But hopefully
# this example is enough to get the idea.
x = int(x + 0.5)
y = int(x + 0.5)
return ctx.device_to_user(x, y)

# Calculate the top-left and bottom-right corners of our rectangle
x1, y1 = 0.2, 0.2
x2, y2 = x1 + 0.2, y1 + 0.2
x1, y1 = snap_to_pixels(ctx, x1, y1)
x2, y2 = snap_to_pixels(ctx, x2, y2)
# Clip for this rectangle
ctx.rectangle(x1, y1, x2 - x1, y2 - y1)
ctx.clip()

关于python - 开罗剪辑创建不需要的边缘,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24633763/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com