diff options
Diffstat (limited to 'externals/grill/guitest')
-rw-r--r-- | externals/grill/guitest/flgui.cpp | 46 | ||||
-rw-r--r-- | externals/grill/guitest/flgui.h | 17 | ||||
-rw-r--r-- | externals/grill/guitest/main.cpp | 12 |
3 files changed, 62 insertions, 13 deletions
diff --git a/externals/grill/guitest/flgui.cpp b/externals/grill/guitest/flgui.cpp index 1bad0851..2753d303 100644 --- a/externals/grill/guitest/flgui.cpp +++ b/externals/grill/guitest/flgui.cpp @@ -107,7 +107,8 @@ void flext_gui::setup(t_class *c) #if FLEXT_SYS == FLEXT_SYS_PD -int flext_gui::evmask = evMotion|evMouseDown|evKeyDown|evKeyUp; +// this event mask declares supported events +int flext_gui::evmask = evMotion|evMouseDown|evMouseDrag|evKeyDown|evKeyUp|evKeyRepeat; int flext_gui::curmod = 0; flext_gui::pxkey_object *flext_gui::pxkey = NULL; flext_gui::guicanv *flext_gui::gcanv = NULL; @@ -228,8 +229,25 @@ void flext_gui::pxkey_method(pxkey_object *obj,const t_symbol *s,int argc,t_atom // post("Key down=%i c=%c mod=%i",down?1:0,code,curmod); if(code || mod) { + // remember past keycodes for repetition detection + static int lastcode = 0,lastasc = 0,lastmod = 0; + // button is pressed - p.kind = down?evKeyDown:evKeyUp; + if(down) { + if(lastcode == code && lastmod == curmod) + p.kind = evKeyRepeat; + else { + p.kind = evKeyDown; + lastcode = code; + lastasc = asc; + lastmod = curmod; + } + } + else { + p.kind = evKeyUp; + lastcode = lastasc = 0; + } + p.ext = true; p.pKey.k = code; //lastkey; p.pKey.a = asc; @@ -438,7 +456,7 @@ void flext_gui::sg_vis(t_gobj *c, t_glist *, int vis) } } -int flext_gui::sg_click(t_gobj *c, t_glist *,int xpix, int ypix, int shift, int alt, int dbl, int doit) +int flext_gui::sg_click(t_gobj *c, t_glist *gl,int xpix, int ypix, int shift, int alt, int dbl, int doit) { flext_gui *g = thisObject(c); CBParams p; @@ -451,10 +469,13 @@ int flext_gui::sg_click(t_gobj *c, t_glist *,int xpix, int ypix, int shift, int if(doit) { // button is pressed p.kind = evMouseDown; - p.pMouseKey.x = x; - p.pMouseKey.y = y; + p.pMouseKey.x = g->xdrag = x; + p.pMouseKey.y = g->ydrag = y; + g->dxdrag = g->dydrag = 0; p.pMouseKey.b = 1; p.pMouseKey.mod = curmod; //mod; + + glist_grab(gl,c,(t_glistmotionfn)sg_drag,0,xpix,ypix); } else { // only mouse position change @@ -467,6 +488,20 @@ int flext_gui::sg_click(t_gobj *c, t_glist *,int xpix, int ypix, int shift, int return 1; } +void flext_gui::sg_drag(t_gobj *c,t_floatarg dx,t_floatarg dy) +{ + flext_gui *g = thisObject(c); + CBParams p; + p.kind = evMouseDrag; + p.pMouseDrag.dx = (g->dxdrag += (int)dx); + p.pMouseDrag.dy = (g->dydrag += (int)dy); + p.pMouseDrag.x = g->xdrag+g->dxdrag; + p.pMouseDrag.y = g->ydrag+g->dydrag;; + p.pMouseDrag.b = 1; + p.pMouseDrag.mod = curmod; //mod; + g->m_Method(p); +} + void flext_gui::sg_delete(t_gobj *c, t_glist *) { thisObject(c)->g_Delete(); @@ -505,6 +540,7 @@ bool flext_gui::sg_KeyUp(flext_base *c,int &keynum) #else // MAXMSP +// this declared supported events int flext_gui::evmask = evMotion|evMouseDown|evKeyDown; static void dragfun() diff --git a/externals/grill/guitest/flgui.h b/externals/grill/guitest/flgui.h index 211a4935..3ca2b399 100644 --- a/externals/grill/guitest/flgui.h +++ b/externals/grill/guitest/flgui.h @@ -1,7 +1,7 @@ #ifndef __FLEXT_GUI #define __FLEXT_GUI -#define FLEXT_VIRT +//#define FLEXT_VIRT #include <flext.h> #if FLEXT_SYS == FLEXT_SYS_PD @@ -15,9 +15,9 @@ class GuiGroup; class GuiSingle; class flext_gui: - virtual public flext_base + public flext_base { - FLEXT_HEADER_S(flext_gui,flext_base,setup) + FLEXT_HEADER_S(flext_gui,flext_dsp,setup) public: flext_gui(int xs,int ys); @@ -29,8 +29,10 @@ public: evMouseDown = 0x02, evMouseUp = 0x04, evMouseWheel = 0x08, - evKeyDown = 0x10, - evKeyUp = 0x20 + evMouseDrag = 0x10, + evKeyDown = 0x20, + evKeyUp = 0x40, + evKeyRepeat = 0x80 }; class CBParams { @@ -42,6 +44,7 @@ public: struct { int x,y,mod; } pMotion; struct { int x,y,b,mod; } pMouseKey; struct { int x,y,mod,delta; } pMouseWheel; + struct { int x,y,dx,dy,b,mod; } pMouseDrag; struct { int k,a,mod; } pKey; }; bool ext; @@ -146,6 +149,7 @@ private: #if FLEXT_SYS == FLEXT_SYS_PD bool selected; int xsize,ysize; + int xdrag,ydrag,dxdrag,dydrag; static void sg_getrect(t_gobj *c, t_glist *,int *xp1, int *yp1, int *xp2, int *yp2); static void sg_displace(t_gobj *c, t_glist *, int dx, int dy); @@ -154,6 +158,7 @@ private: static void sg_delete(t_gobj *c, t_glist *); static void sg_vis(t_gobj *c, t_glist *, int vis); static int sg_click(t_gobj *c, t_glist *,int xpix, int ypix, int shift, int alt, int dbl, int doit); + static void sg_drag(t_gobj *x, t_floatarg dx, t_floatarg dy); static void sg_properties(t_gobj *c, t_glist *); static void sg_save(t_gobj *c, t_binbuf *b); // static void sg_motion(void *c, float dx,float dy) { thisObject((t_gobj *)c)->g_Motion(dx,dy); } @@ -210,7 +215,7 @@ public: static t_class *px_class,*pxkey_class; static void sg_tk(t_canvas *c,const t_symbol *s,int argc,t_atom *argv); -#else +#else // MAXMSP int curx,cury,curmod; bool created; static t_clock clock; diff --git a/externals/grill/guitest/main.cpp b/externals/grill/guitest/main.cpp index cfedfa86..661c3ad2 100644 --- a/externals/grill/guitest/main.cpp +++ b/externals/grill/guitest/main.cpp @@ -21,7 +21,7 @@ #define UL unsigned long class guitest: -public flext_gui,virtual public flext_base +public flext_gui //,virtual public flext_base { FLEXT_HEADER(guitest,flext_gui) @@ -29,7 +29,7 @@ public: guitest(I argc,t_atom *argv); ~guitest(); - virtual void m_bang() + void m_bang() { post("%s - bang!",thisName()); } @@ -69,9 +69,11 @@ void guitest::g_Create() delete[] p; if(!BindEvent(*frame,g_Motion,evMotion)) post("Motion not supported"); + if(!BindEvent(*frame,g_Motion,evMouseDrag)) post("MouseDrag not supported"); if(!BindEvent(*wave,g_MouseKey,evMouseDown)) post("MouseDown not supported"); if(!BindEvent(*wave,g_MouseKey,evKeyDown)) post("KeyDown not supported"); if(!BindEvent(*wave,g_MouseKey,evKeyUp)) post("KeyUp not supported"); + if(!BindEvent(*wave,g_MouseKey,evKeyRepeat)) post("KeyRepeat not supported"); } void guitest::g_Properties() @@ -107,6 +109,9 @@ bool guitest::g_Motion(flext_gui &g,GuiSingle &obj,const CBParams &p) if(p.kind == evMotion) { post("Motion %s x:%i y:%i mod:%i",GetString(obj.Id()),p.pMotion.x,p.pMotion.y,p.pMotion.mod); } + else if(p.kind == evMouseDrag) { + post("Drag %s x:%i y:%i dx:%i dy:%i b:%i mod:%i",GetString(obj.Id()),p.pMouseDrag.x,p.pMouseDrag.y,p.pMouseDrag.dx,p.pMouseDrag.dy,p.pMouseDrag.b,p.pMouseDrag.mod); + } else post("Motion"); return true; @@ -123,6 +128,9 @@ bool guitest::g_MouseKey(flext_gui &g,GuiSingle &obj,const CBParams &p) else if(p.kind == evKeyUp) { post("KeyUp %s asc:%i key:%i mod:%i",GetString(obj.Id()),p.pKey.a,p.pKey.k,p.pKey.mod); } + else if(p.kind == evKeyRepeat) { + post("KeyRepeat %s asc:%i key:%i mod:%i",GetString(obj.Id()),p.pKey.a,p.pKey.k,p.pKey.mod); + } return true; } |