4 * Copyright 1993 Alexandre Julliard
9 #include "debugtools.h"
11 DEFAULT_DEBUG_CHANNEL(gdi
)
15 /***********************************************************************
16 * CreatePen16 (GDI.61)
18 HPEN16 WINAPI
CreatePen16( INT16 style
, INT16 width
, COLORREF color
)
22 TRACE("%d %d %06lx\n", style
, width
, color
);
24 logpen
.lopnStyle
= style
;
25 logpen
.lopnWidth
.x
= width
;
26 logpen
.lopnWidth
.y
= 0;
27 logpen
.lopnColor
= color
;
29 return CreatePenIndirect( &logpen
);
33 /***********************************************************************
34 * CreatePen (GDI32.55)
36 HPEN WINAPI
CreatePen( INT style
, INT width
, COLORREF color
)
40 TRACE("%d %d %06lx\n", style
, width
, color
);
42 logpen
.lopnStyle
= style
;
43 logpen
.lopnWidth
.x
= width
;
44 logpen
.lopnWidth
.y
= 0;
45 logpen
.lopnColor
= color
;
47 return CreatePenIndirect( &logpen
);
51 /***********************************************************************
52 * CreatePenIndirect16 (GDI.62)
54 HPEN16 WINAPI
CreatePenIndirect16( const LOGPEN16
* pen
)
59 if (pen
->lopnStyle
> PS_INSIDEFRAME
) return 0;
60 hpen
= GDI_AllocObject( sizeof(PENOBJ
), PEN_MAGIC
);
62 penPtr
= (PENOBJ
*)GDI_HEAP_LOCK( hpen
);
63 penPtr
->logpen
.lopnStyle
= pen
->lopnStyle
;
64 penPtr
->logpen
.lopnColor
= pen
->lopnColor
;
65 CONV_POINT16TO32( &pen
->lopnWidth
, &penPtr
->logpen
.lopnWidth
);
66 GDI_HEAP_UNLOCK( hpen
);
71 /***********************************************************************
72 * CreatePenIndirect (GDI32.56)
74 HPEN WINAPI
CreatePenIndirect( const LOGPEN
* pen
)
79 if (pen
->lopnStyle
> PS_INSIDEFRAME
) return 0;
80 hpen
= GDI_AllocObject( sizeof(PENOBJ
), PEN_MAGIC
);
82 penPtr
= (PENOBJ
*)GDI_HEAP_LOCK( hpen
);
83 penPtr
->logpen
.lopnStyle
= pen
->lopnStyle
;
84 penPtr
->logpen
.lopnWidth
= pen
->lopnWidth
;
85 penPtr
->logpen
.lopnColor
= pen
->lopnColor
;
86 GDI_HEAP_UNLOCK( hpen
);
90 /***********************************************************************
91 * ExtCreatePen (GDI32.93)
93 * FIXME: PS_USERSTYLE not handled
96 HPEN WINAPI
ExtCreatePen( DWORD style
, DWORD width
,
97 const LOGBRUSH
* brush
, DWORD style_count
,
98 const DWORD
*style_bits
)
103 if ((style
& PS_STYLE_MASK
) == PS_USERSTYLE
)
104 FIXME("PS_USERSTYLE not handled\n");
105 if ((style
& PS_TYPE_MASK
) == PS_GEOMETRIC
)
107 FIXME("Hatches not implemented\n");
109 hpen
= GDI_AllocObject( sizeof(PENOBJ
), PEN_MAGIC
);
111 penPtr
= (PENOBJ
*)GDI_HEAP_LOCK( hpen
);
112 penPtr
->logpen
.lopnStyle
= style
& ~PS_TYPE_MASK
;
114 /* PS_USERSTYLE and PS_ALTERNATE workaround */
115 if((penPtr
->logpen
.lopnStyle
& PS_STYLE_MASK
) > PS_INSIDEFRAME
)
116 penPtr
->logpen
.lopnStyle
=
117 (penPtr
->logpen
.lopnStyle
& ~PS_STYLE_MASK
) | PS_SOLID
;
119 penPtr
->logpen
.lopnWidth
.x
= (style
& PS_GEOMETRIC
) ? width
: 1;
120 penPtr
->logpen
.lopnWidth
.y
= 0;
121 penPtr
->logpen
.lopnColor
= brush
->lbColor
;
122 GDI_HEAP_UNLOCK( hpen
);
127 /***********************************************************************
130 INT16
PEN_GetObject16( PENOBJ
* pen
, INT16 count
, LPSTR buffer
)
133 logpen
.lopnStyle
= pen
->logpen
.lopnStyle
;
134 logpen
.lopnColor
= pen
->logpen
.lopnColor
;
135 CONV_POINT32TO16( &pen
->logpen
.lopnWidth
, &logpen
.lopnWidth
);
136 if (count
> sizeof(logpen
)) count
= sizeof(logpen
);
137 memcpy( buffer
, &logpen
, count
);
142 /***********************************************************************
145 INT
PEN_GetObject( PENOBJ
* pen
, INT count
, LPSTR buffer
)
147 if (count
> sizeof(pen
->logpen
)) count
= sizeof(pen
->logpen
);
148 memcpy( buffer
, &pen
->logpen
, count
);