如何在ListBoxDrawItem上绘制消除锯齿的三角形?
ListBox.Canvas.Polygon
用jags画画。
感谢!!!
答案 0 :(得分:4)
内置任何内容都不会产生抗锯齿功能。你可以使用GDI +,但我会建议graphics32,它会愉快地绘制anti-aliased polygons。
答案 1 :(得分:4)
使用GDI实现抗锯齿绘制的最简单方法是绘制到更大的表面,然后缩放到具有半色调启用拉伸模式的原始尺寸。
下面的代码示例使用比列表框的客户区域大16倍的位图(这是一个相当大的位图,这将花费很多时间来完成绘图,但效果应该更容易看到。)
procedure TForm1.Button1Click(Sender: TObject);
const
ZOOM = 16;
var
Bmp: TBitmap;
StretchMode: Integer;
begin
// for comparison
ListBox2.Canvas.Polygon([Point(20, 10), Point(10, 50), Point(80, 30)]);
Bmp := TBitmap.Create;
// create a large bitmap and set coordinate extents accordingly
Bmp.SetSize(ListBox1.ClientWidth * ZOOM, ListBox1.ClientHeight * ZOOM);
SetMapMode(Bmp.Canvas.Handle, MM_ISOTROPIC);
SetWindowExtEx(Bmp.Canvas.Handle, 100, 100, nil);
SetViewportExtEx(Bmp.Canvas.Handle, 100 * ZOOM, 100 * ZOOM, nil);
// without halftone we won't gain anything
SetStretchBltMode(Bmp.Canvas.Handle, HALFTONE);
// transfer what's on the list box to bitmap canvas
BitBlt(Bmp.Canvas.Handle, 0, 0, Bmp.Width, Bmp.Height,
ListBox1.Canvas.Handle, 0, 0, SRCCOPY);
Bmp.Canvas.Polygon([Point(20, 10), Point(10, 50), Point(80, 30)]);
// transfer bitmap contents
StretchMode := SetStretchBltMode(ListBox1.Canvas.Handle, HALFTONE);
StretchBlt(ListBox1.Canvas.Handle, 0, 0,
ListBox1.ClientWidth * ZOOM, ListBox1.ClientHeight * ZOOM,
Bmp.Canvas.Handle, 0, 0, Bmp.Width, Bmp.Height, SRCCOPY);
SetStretchBltMode(ListBox1.Canvas.Handle, StretchMode);
Bmp.Free;
end;
在下图中,左边是ListBox1 - 使用消除锯齿绘制的ListBox1。请注意文本也获得了一些效果:
我当然会建议你考虑一下David的建议。这段代码相当实验性:)。