touch screen handler for the microchip AR1020

Revision:
4:510ea5b28a05
Parent:
1:264ad2a00fd9
--- a/AreaTouchHandler.h	Tue Feb 22 22:54:25 2011 +0000
+++ b/AreaTouchHandler.h	Thu Feb 24 14:00:17 2011 +0000
@@ -1,79 +1,84 @@
-/*
-* mbed AR1020 library
-* Copyright (c) 2010 Hendrik Lipka
-*
-* Permission is hereby granted, free of charge, to any person obtaining a copy
-* of this software and associated documentation files (the "Software"), to deal
-* in the Software without restriction, including without limitation the rights
-* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-* copies of the Software, and to permit persons to whom the Software is
-* furnished to do so, subject to the following conditions:
-*
-* The above copyright notice and this permission notice shall be included in
-* all copies or substantial portions of the Software.
-*
-* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-* THE SOFTWARE.
-*/
-
-#ifndef __AREATOUCHHANDLER_H__
-#define __AREATOUCHHANDLER_H__
-
-#include "mbed.h"
-#include "FPointer.h"
-#include "touchpanel.h"
-#include <list>
-
-class area
-{
-    public:
-    int top,bottom,left,right,command;
-    area(int top, int bottom, int left, int right, int command)
-    {
-        this->top=top;
-        this->bottom=bottom;
-        this->left=left;
-        this->right=right;
-        this->command=command;
-    }
-};
-
-class AreaTouchHandler
-{
-    public:
-        AreaTouchHandler(TouchPanel* panel)
-        {
-            panel->attachPenDown(this,&AreaTouchHandler::down);
-            panel->attachPenMove(this,&AreaTouchHandler::move);
-            panel->attachPenUp(this,&AreaTouchHandler::up);
-        }
-        class T;
-        template<class T> 
-        void attach(T* item, uint32_t (T::*method)(uint32_t)) { _callback.attach(item, method); }   
-        void attach(uint32_t (*function)(uint32_t)) { _callback.attach(function); }   
-        
-        void addArea(int top, int bottom, int left, int right, int commandCode)
-        {
-            _areas.push_back(new area(top,bottom,left,right,commandCode));
-        }
-    private:
-        FPointer      _callback;
-        std::list<area*> _areas;
-        uint32_t down(uint32_t arg);
-        uint32_t move(uint32_t arg);
-        uint32_t up(uint32_t arg);
-        
-        int findCommand();
-        
-        float _x, _y;
-        int _samples;
-        bool _called;
-};
-
-
-#endif
+/*
+* mbed AR1020 library
+* Copyright (c) 2010 Hendrik Lipka
+*
+* Permission is hereby granted, free of charge, to any person obtaining a copy
+* of this software and associated documentation files (the "Software"), to deal
+* in the Software without restriction, including without limitation the rights
+* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+* copies of the Software, and to permit persons to whom the Software is
+* furnished to do so, subject to the following conditions:
+*
+* The above copyright notice and this permission notice shall be included in
+* all copies or substantial portions of the Software.
+*
+* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
+* THE SOFTWARE.
+*/
+
+#ifndef __AREATOUCHHANDLER_H__
+#define __AREATOUCHHANDLER_H__
+
+#include "mbed.h"
+#include "FPointer.h"
+#include "touchpanel.h"
+#include <list>
+
+class area;
+
+/**
+    this class registers itself with a touch screen controller, and listens for touch events. 
+    If an event matches a prefined region, the callback function is called with the corresponding command code.
+*/
+class AreaTouchHandler
+{
+    public:
+        /**
+            creates the handler, and attaches it to the given touch panel
+            @params pane the touch panel to listen to
+        */
+        AreaTouchHandler(TouchPanel* panel);
+        /**
+            set the callback method        
+            @params item the callback object
+            @params method the callback method
+        */
+        class T;
+        template<class T> 
+        void attach(T* item, uint32_t (T::*method)(uint32_t)) { _callback.attach(item, method); }   
+        /**
+            set the callback method        
+            @params function the callback function
+        */
+        void attach(uint32_t (*function)(uint32_t)) { _callback.attach(function); }   
+
+        /**
+            defines the command for a specific region
+            @params top the top of the region (y)
+            @params bottom the bottom of the region (y)
+            @params the left side of the region (x)
+            @params the right side of the region (x)
+            @params the command code for this region
+        */        
+        void addArea(int top, int bottom, int left, int right, int commandCode);
+    private:
+        FPointer      _callback;
+        std::list<area*> _areas;
+        uint32_t down(uint32_t arg);
+        uint32_t move(uint32_t arg);
+        uint32_t up(uint32_t arg);
+        
+        int findCommand();
+        
+        float _x, _y;
+        int _samples;
+        bool _called;
+};
+
+
+#endif