Commit 54397f15 authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

gdi32: Add support for patterned pens.

parent 572e0f01
...@@ -544,6 +544,19 @@ static BOOL solid_pen_line(dibdrv_physdev *pdev, POINT *start, POINT *end) ...@@ -544,6 +544,19 @@ static BOOL solid_pen_line(dibdrv_physdev *pdev, POINT *start, POINT *end)
return TRUE; return TRUE;
} }
static BOOL dashed_pen_line(dibdrv_physdev *pdev, POINT *start, POINT *end)
{
return FALSE;
}
static const dash_pattern dash_patterns[4] =
{
{2, {18, 6}, 24}, /* PS_DASH */
{2, {3, 3}, 6}, /* PS_DOT */
{4, {9, 6, 3, 6}, 24}, /* PS_DASHDOT */
{6, {9, 3, 3, 3, 3, 3}, 24} /* PS_DASHDOTDOT */
};
/*********************************************************************** /***********************************************************************
* dibdrv_SelectPen * dibdrv_SelectPen
*/ */
...@@ -552,6 +565,7 @@ HPEN CDECL dibdrv_SelectPen( PHYSDEV dev, HPEN hpen ) ...@@ -552,6 +565,7 @@ HPEN CDECL dibdrv_SelectPen( PHYSDEV dev, HPEN hpen )
PHYSDEV next = GET_NEXT_PHYSDEV( dev, pSelectPen ); PHYSDEV next = GET_NEXT_PHYSDEV( dev, pSelectPen );
dibdrv_physdev *pdev = get_dibdrv_pdev(dev); dibdrv_physdev *pdev = get_dibdrv_pdev(dev);
LOGPEN logpen; LOGPEN logpen;
DWORD style;
TRACE("(%p, %p)\n", dev, hpen); TRACE("(%p, %p)\n", dev, hpen);
...@@ -583,14 +597,29 @@ HPEN CDECL dibdrv_SelectPen( PHYSDEV dev, HPEN hpen ) ...@@ -583,14 +597,29 @@ HPEN CDECL dibdrv_SelectPen( PHYSDEV dev, HPEN hpen )
pdev->defer |= DEFER_PEN; pdev->defer |= DEFER_PEN;
switch(logpen.lopnStyle & PS_STYLE_MASK) style = logpen.lopnStyle & PS_STYLE_MASK;
switch(style)
{ {
case PS_SOLID: case PS_SOLID:
if(logpen.lopnStyle & PS_GEOMETRIC) break; if(logpen.lopnStyle & PS_GEOMETRIC) break;
if(logpen.lopnWidth.x > 1) break; if(logpen.lopnWidth.x > 1) break;
pdev->pen_line = solid_pen_line; pdev->pen_line = solid_pen_line;
pdev->pen_pattern.count = 0;
pdev->defer &= ~DEFER_PEN; pdev->defer &= ~DEFER_PEN;
break; break;
case PS_DASH:
case PS_DOT:
case PS_DASHDOT:
case PS_DASHDOTDOT:
if(logpen.lopnStyle & PS_GEOMETRIC) break;
if(logpen.lopnWidth.x > 1) break;
pdev->pen_line = dashed_pen_line;
pdev->pen_pattern = dash_patterns[style - PS_DASH];
pdev->defer &= ~DEFER_PEN;
break;
default: default:
break; break;
} }
......
...@@ -92,6 +92,13 @@ typedef struct ...@@ -92,6 +92,13 @@ typedef struct
const struct primitive_funcs *funcs; const struct primitive_funcs *funcs;
} dib_info; } dib_info;
typedef struct
{
DWORD count;
DWORD dashes[16]; /* 16 is the maximium number for a PS_USERSTYLE pen */
DWORD total_len; /* total length of the dashes, should be multiplied by 2 if there are an odd number of dash lengths */
} dash_pattern;
typedef struct dibdrv_physdev typedef struct dibdrv_physdev
{ {
struct gdi_physdev dev; struct gdi_physdev dev;
...@@ -103,6 +110,7 @@ typedef struct dibdrv_physdev ...@@ -103,6 +110,7 @@ typedef struct dibdrv_physdev
/* pen */ /* pen */
DWORD pen_color, pen_and, pen_xor; DWORD pen_color, pen_and, pen_xor;
BOOL (* pen_line)(struct dibdrv_physdev *pdev, POINT *start, POINT *end); BOOL (* pen_line)(struct dibdrv_physdev *pdev, POINT *start, POINT *end);
dash_pattern pen_pattern;
/* brush */ /* brush */
UINT brush_style; UINT brush_style;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment