2 Copyright © 1995-2005, The AROS Development Team. All rights reserved.
5 Desc: AROS specific cycle class implementation.
9 /***********************************************************************************/
11 #define USE_BOOPSI_STUBS
12 #include <exec/libraries.h>
13 #include <proto/dos.h>
14 #include <proto/intuition.h>
15 #include <intuition/classes.h>
16 #include <intuition/classusr.h>
17 #include <intuition/imageclass.h>
18 #include <intuition/intuition.h>
19 #include <intuition/screens.h>
20 #include <proto/graphics.h>
21 #include <graphics/rastport.h>
22 #include <graphics/text.h>
23 #include <proto/utility.h>
24 #include <utility/tagitem.h>
25 #include <devices/inputevent.h>
26 #include <gadgets/aroscycle.h>
27 #include <proto/alib.h>
32 #include <aros/debug.h>
34 #include "aroscycle_intern.h"
36 /***********************************************************************************/
38 #define IM(o) ((struct Image *)(o))
39 #define EG(o) ((struct Gadget *)(o))
41 #include <clib/boopsistubs.h>
43 /***********************************************************************************/
45 Object
*AROSCycle__OM_NEW(Class
*cl
, Class
*rootcl
, struct opSet
*msg
)
47 struct CycleData
*data
;
48 struct TextAttr
*tattr
;
49 struct TagItem imgtags
[] = {
52 { IA_EdgesOnly
, FALSE
},
53 { IA_FrameType
, FRAME_BUTTON
},
59 o
= (Object
*)DoSuperMethodA(cl
, (Object
*)rootcl
, (Msg
)msg
);
63 data
= INST_DATA(cl
, o
);
64 data
->active
= GetTagData(AROSCYCLE_Active
, 0, msg
->ops_AttrList
);
65 data
->labels
= (STRPTR
*)GetTagData(AROSCYCLE_Labels
, (IPTR
) NULL
, msg
->ops_AttrList
);
68 labels
= data
->labels
;
78 tattr
= (struct TextAttr
*)GetTagData(GA_TextAttr
, (IPTR
) NULL
, msg
->ops_AttrList
);
79 if (tattr
) data
->font
= OpenFont(tattr
);
81 imgtags
[0].ti_Data
= (IPTR
)EG(o
)->Width
;
82 imgtags
[1].ti_Data
= (IPTR
)EG(o
)->Height
;
84 EG(o
)->GadgetRender
= NewObjectA(NULL
, FRAMEICLASS
, imgtags
);
85 if (!EG(o
)->GadgetRender
)
87 IPTR methodid
= OM_DISPOSE
;
88 CoerceMethodA(cl
, o
, (Msg
)&methodid
);
95 /***********************************************************************************/
97 VOID
AROSCycle__OM_DISPOSE(Class
*cl
, Object
*o
, Msg msg
)
99 struct CycleData
*data
= INST_DATA(cl
, o
);
101 if (EG(o
)->GadgetRender
)
102 DisposeObject(EG(o
)->GadgetRender
);
104 if (data
->font
) CloseFont(data
->font
);
106 DoSuperMethodA(cl
,o
,msg
);
109 /***********************************************************************************/
111 IPTR
AROSCycle__OM_GET(Class
*cl
, Object
*o
, struct opGet
*msg
)
113 struct CycleData
*data
= INST_DATA(cl
, o
);
116 switch(msg
->opg_AttrID
)
118 case AROSCYCLE_Active
:
119 *(msg
->opg_Storage
) = (IPTR
)data
->active
;
122 case AROSCYCLE_Labels
:
123 *(msg
->opg_Storage
) = (IPTR
)data
->labels
;
127 retval
= DoSuperMethodA(cl
, o
, (Msg
)msg
);
134 /***********************************************************************************/
136 IPTR
AROSCycle__OM_SET(Class
*cl
, Object
*o
, struct opSet
*msg
)
138 struct CycleData
*data
= INST_DATA(cl
, o
);
139 const struct TagItem
*tag
, *taglist
= msg
->ops_AttrList
;
141 BOOL rerender
= FALSE
;
144 result
= DoSuperMethodA(cl
, o
, (Msg
)msg
);
146 while((tag
= NextTagItem(&taglist
)))
150 case AROSCYCLE_Labels
:
151 data
->labels
= (STRPTR
*)tag
->ti_Data
;
154 mylabels
= data
->labels
;
166 case AROSCYCLE_Active
:
167 data
->active
= tag
->ti_Data
;
177 /* SDuvan: Removed test (cl == OCLASS(o)) */
181 struct RastPort
*rport
;
183 if(data
->active
> data
->numlabels
-1)
186 //kprintf("Rerendering\n");
188 rport
= ObtainGIRPort(msg
->ops_GInfo
);
191 DoMethod(o
, GM_RENDER
, (IPTR
)msg
->ops_GInfo
, (IPTR
)rport
, GREDRAW_UPDATE
);
192 ReleaseGIRPort(rport
);
200 /***********************************************************************************/
202 IPTR
cycle_hittest(Class
*cl
, Object
*o
, struct gpHitTest
*msg
)
204 return pointingadget((struct Gadget
*)o
,
207 msg
->gpht_Mouse
.Y
) ? GMR_GADGETHIT
: 0;
210 /***********************************************************************************/
212 VOID
AROSCycle__GM_RENDER(Class
*cl
, Object
*o
, struct gpRender
*msg
)
214 struct CycleData
*data
= INST_DATA(cl
, o
);
216 /* Full redraw: clear and draw border */
217 DrawImageState(msg
->gpr_RPort
,IM(EG(o
)->GadgetRender
),
218 EG(o
)->LeftEdge
, EG(o
)->TopEdge
,
219 EG(o
)->Flags
&GFLG_SELECTED
?IDS_SELECTED
:IDS_NORMAL
,
220 msg
->gpr_GInfo
->gi_DrInfo
);
223 SetFont(msg
->gpr_RPort
, data
->font
);
225 SetFont(msg
->gpr_RPort
, msg
->gpr_GInfo
->gi_DrInfo
->dri_Font
);
228 renderlabel(EG(o
), data
->labels
[data
->active
],
229 msg
->gpr_RPort
, msg
->gpr_GInfo
);
231 /* Draw disabled pattern */
232 if (G(o
)->Flags
& GFLG_DISABLED
)
233 drawdisabledpattern(msg
->gpr_RPort
,
234 msg
->gpr_GInfo
->gi_DrInfo
->dri_Pens
[SHADOWPEN
],
235 G(o
)->LeftEdge
, G(o
)->TopEdge
,
236 G(o
)->Width
, G(o
)->Height
);
240 /***********************************************************************************/
242 IPTR
AROSCycle__GM_GOACTIVE(Class
*cl
, Object
*o
, struct gpInput
*msg
)
244 struct CycleData
*data
;
245 struct RastPort
*rport
;
248 data
= INST_DATA(cl
, o
);
250 EG(o
)->Flags
|= GFLG_SELECTED
;
252 rport
= ObtainGIRPort(msg
->gpi_GInfo
);
255 struct gpRender rmsg
=
256 { GM_RENDER
, msg
->gpi_GInfo
, rport
, GREDRAW_UPDATE
}, *p_rmsg
= &rmsg
;
257 DoMethodA(o
, (Msg
)p_rmsg
);
258 ReleaseGIRPort(rport
);
259 retval
= GMR_MEACTIVE
;
261 retval
= GMR_NOREUSE
;
266 /***********************************************************************************/
268 IPTR
AROSCycle__GM_HANDLEINPUT(Class
*cl
, Object
*o
, struct gpInput
*msg
)
270 struct RastPort
*rport
;
271 struct CycleData
*data
;
272 IPTR retval
= GMR_MEACTIVE
;
274 data
= INST_DATA(cl
, o
);
276 if (msg
->gpi_IEvent
->ie_Class
== IECLASS_RAWMOUSE
)
278 if (msg
->gpi_IEvent
->ie_Code
== SELECTUP
)
280 if (G(o
)->Flags
& GFLG_SELECTED
)
282 /* mouse is over gadget */
285 if (data
->active
== data
->numlabels
)
289 *msg
->gpi_Termination
= data
->active
;
290 retval
= GMR_NOREUSE
| GMR_VERIFY
;
292 /* mouse is not over gadget */
293 retval
= GMR_NOREUSE
;
296 G(o)->Flags &= ~GFLG_SELECTED;
298 rport = ObtainGIRPort(msg->gpi_GInfo);
301 struct gpRender rmsg =
302 { GM_RENDER, msg->gpi_GInfo, rport, GREDRAW_UPDATE };
303 DoMethodA(o, (Msg)&rmsg);
304 ReleaseGIRPort(rport);
307 } else if (msg
->gpi_IEvent
->ie_Code
== IECODE_NOBUTTON
)
309 struct gpHitTest htmsg
=
310 { GM_HITTEST
, msg
->gpi_GInfo
,
311 { msg
->gpi_Mouse
.X
, msg
->gpi_Mouse
.Y
},
312 }, *p_htmsg
= &htmsg
;
313 if (DoMethodA(o
, (Msg
)p_htmsg
) != GMR_GADGETHIT
)
315 if (EG(o
)->Flags
& GFLG_SELECTED
)
317 G(o
)->Flags
&= ~GFLG_SELECTED
;
318 rport
= ObtainGIRPort(msg
->gpi_GInfo
);
321 struct gpRender rmsg
=
322 { GM_RENDER
, msg
->gpi_GInfo
, rport
, GREDRAW_UPDATE
}, *p_rmsg
= &rmsg
;
323 DoMethodA(o
, (Msg
)p_rmsg
);
324 ReleaseGIRPort(rport
);
329 if (!(EG(o
)->Flags
& GFLG_SELECTED
))
331 EG(o
)->Flags
|= GFLG_SELECTED
;
332 rport
= ObtainGIRPort(msg
->gpi_GInfo
);
335 struct gpRender rmsg
=
336 { GM_RENDER
, msg
->gpi_GInfo
, rport
, GREDRAW_UPDATE
}, *p_rmsg
= &rmsg
;
337 DoMethodA(o
, (Msg
)p_rmsg
);
338 ReleaseGIRPort(rport
);
342 } else if (msg
->gpi_IEvent
->ie_Code
== MENUDOWN
)
348 /***********************************************************************************/
350 IPTR
AROSCycle__GM_GOINACTIVE(Class
*cl
, Object
*o
, struct gpGoInactive
*msg
)
352 struct RastPort
*rport
;
354 EG(o
)->Flags
&= ~GFLG_SELECTED
;
356 rport
= ObtainGIRPort(msg
->gpgi_GInfo
);
359 struct gpRender rmsg
= { GM_RENDER
, msg
->gpgi_GInfo
, rport
, GREDRAW_UPDATE
}, *p_rmsg
= &rmsg
;
361 DoMethodA(o
, (Msg
)p_rmsg
);
362 ReleaseGIRPort(rport
);