Use service thread for "true" multimedia timers.
[wine/wine-kai.git] / objects / pen.c
blob18e722fca9aa36413f8863e2209fe6756ea521b1
1 /*
2 * GDI pen objects
4 * Copyright 1993 Alexandre Julliard
5 */
7 #include <string.h>
8 #include "pen.h"
9 #include "debug.h"
11 DEFAULT_DEBUG_CHANNEL(gdi)
15 /***********************************************************************
16 * CreatePen16 (GDI.61)
18 HPEN16 WINAPI CreatePen16( INT16 style, INT16 width, COLORREF color )
20 LOGPEN logpen;
22 TRACE(gdi, "%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 * CreatePen32 (GDI32.55)
36 HPEN WINAPI CreatePen( INT style, INT width, COLORREF color )
38 LOGPEN logpen;
40 TRACE(gdi, "%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 )
56 PENOBJ * penPtr;
57 HPEN16 hpen;
59 if (pen->lopnStyle > PS_INSIDEFRAME) return 0;
60 hpen = GDI_AllocObject( sizeof(PENOBJ), PEN_MAGIC );
61 if (!hpen) return 0;
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 );
67 return hpen;
71 /***********************************************************************
72 * CreatePenIndirect32 (GDI32.56)
74 HPEN WINAPI CreatePenIndirect( const LOGPEN * pen )
76 PENOBJ * penPtr;
77 HPEN hpen;
79 if (pen->lopnStyle > PS_INSIDEFRAME) return 0;
80 hpen = GDI_AllocObject( sizeof(PENOBJ), PEN_MAGIC );
81 if (!hpen) return 0;
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 );
87 return hpen;
90 /***********************************************************************
91 * ExtCreatePen32 (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 )
100 LOGPEN logpen;
102 if ((style & PS_STYLE_MASK) == PS_USERSTYLE)
103 FIXME(gdi, "PS_USERSTYLE not handled\n");
104 if ((style & PS_TYPE_MASK) == PS_GEOMETRIC)
105 if (brush->lbHatch)
106 FIXME(gdi, "Hatches not implemented\n");
108 logpen.lopnStyle = style & ~PS_TYPE_MASK;
109 logpen.lopnWidth.x = (style & PS_GEOMETRIC) ? width : 1;
110 logpen.lopnWidth.y = 0;
111 logpen.lopnColor = brush->lbColor;
112 return CreatePenIndirect( &logpen );
115 /***********************************************************************
116 * PEN_GetObject16
118 INT16 PEN_GetObject16( PENOBJ * pen, INT16 count, LPSTR buffer )
120 LOGPEN16 logpen;
121 logpen.lopnStyle = pen->logpen.lopnStyle;
122 logpen.lopnColor = pen->logpen.lopnColor;
123 CONV_POINT32TO16( &pen->logpen.lopnWidth, &logpen.lopnWidth );
124 if (count > sizeof(logpen)) count = sizeof(logpen);
125 memcpy( buffer, &logpen, count );
126 return count;
130 /***********************************************************************
131 * PEN_GetObject32
133 INT PEN_GetObject( PENOBJ * pen, INT count, LPSTR buffer )
135 if (count > sizeof(pen->logpen)) count = sizeof(pen->logpen);
136 memcpy( buffer, &pen->logpen, count );
137 return count;