123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185 |
- /*
- * Copyright (c) 2006-2018, RT-Thread Development Team
- *
- * SPDX-License-Identifier: Apache-2.0
- *
- * Change Logs:
- * Date Author Notes
- * 2012-01-03 Yi Qiu first version
- */
- #include <rtthread.h>
- #include <drivers/usb_host.h>
- #include "hid.h"
- #ifdef RT_USING_RTGUI
- #include <rtgui/event.h>
- #include <rtgui/rtgui_server.h>
- #include "drv_lcd.h"
- #endif
- #if defined(RT_USBH_HID) && defined(RT_USBH_HID_MOUSE)
- static struct uprotocal mouse_protocal;
- #ifdef RT_USING_RTGUI
- #define LKEY_PRESS 0x01
- #define RKEY_PRESS 0x02
- #define MKEY_PRESS 0x04
- #define MOUSE_SCALING 0x02
- static rt_bool_t lkey_down=RT_FALSE;
- //static rt_bool_t rkey_down=RT_FALSE;
- //static rt_bool_t mkey_down=RT_FALSE;
- static struct rtgui_event_mouse emouse;
- #endif
- static rt_err_t rt_usbh_hid_mouse_callback(void* arg)
- {
- struct uhid* hid;
- #ifdef RT_USING_RTGUI
- rt_uint16_t xoffset=0;
- rt_uint16_t yoffset=0;
- #endif
- hid = (struct uhid*)arg;
- RT_DEBUG_LOG(RT_DEBUG_USB, ("hid 0x%x 0x%x\n",
- *(rt_uint32_t*)hid->buffer,
- *(rt_uint32_t*)(&hid->buffer[4])));
- #ifdef RT_USING_RTGUI
- if(hid->buffer[1]!=0)
- {
- if(hid->buffer[1]>127)
- {
- xoffset=(256-hid->buffer[1])*MOUSE_SCALING;
- if(emouse.x>xoffset)
- {
- emouse.x-=xoffset;
- }
- else
- {
- emouse.x=0;
- }
- }
- else
- {
- xoffset=(hid->buffer[1])*MOUSE_SCALING;
- if((emouse.x+xoffset)<480)
- {
- emouse.x+=xoffset;
- }
- else
- {
- emouse.x=480;
- }
- }
- }
- if(hid->buffer[2]!=0)
- {
- if(hid->buffer[2]>127)
- {
- yoffset=(256-hid->buffer[2])*MOUSE_SCALING;
- if(emouse.y>yoffset)
- {
- emouse.y-=yoffset;
- }
- else
- {
- emouse.y=0;
- }
- }
- else
- {
- yoffset=hid->buffer[2]*MOUSE_SCALING;
- if(emouse.y+yoffset<272)
- {
- emouse.y+=yoffset;
- }
- else
- {
- emouse.y=272;
- }
- }
- }
- if(xoffset!=0||yoffset!=0)
- {
- cursor_set_position(emouse.x,emouse.y);
- }
- if(hid->buffer[0]&LKEY_PRESS)
- {
- if(lkey_down==RT_FALSE)
- {
- // rt_kprintf("mouse left key press down\n");
- emouse.button = (RTGUI_MOUSE_BUTTON_LEFT | RTGUI_MOUSE_BUTTON_DOWN);
- rtgui_server_post_event(&emouse.parent, sizeof(struct rtgui_event_mouse));
- lkey_down=RT_TRUE;
- }
- }
- else if(lkey_down==RT_TRUE)
- {
- // rt_kprintf("mouse left key press up\n");
- emouse.button = (RTGUI_MOUSE_BUTTON_LEFT | RTGUI_MOUSE_BUTTON_UP);
- rtgui_server_post_event(&emouse.parent, sizeof(struct rtgui_event_mouse));
- lkey_down=RT_FALSE;
- }
- #endif
- return RT_EOK;
- }
- rt_thread_t mouse_thread;
- void mouse_task(void* param)
- {
- struct uhintf* intf = (struct uhintf*)param;
- while (1)
- {
- if (rt_usb_hcd_pipe_xfer(intf->device->hcd, ((struct uhid*)intf->user_data)->pipe_in,
- ((struct uhid*)intf->user_data)->buffer, ((struct uhid*)intf->user_data)->pipe_in->ep.wMaxPacketSize,
- USB_TIMEOUT_BASIC) == 0)
- {
- break;
- }
- rt_usbh_hid_mouse_callback(intf->user_data);
- }
- }
- static rt_err_t rt_usbh_hid_mouse_init(void* arg)
- {
- struct uhintf* intf = (struct uhintf*)arg;
- RT_ASSERT(intf != RT_NULL);
- rt_usbh_hid_set_protocal(intf, 0);
- rt_usbh_hid_set_idle(intf, 0, 0);
- mouse_thread = rt_thread_create("mouse0", mouse_task, intf, 500, 8, 100);
- rt_thread_startup(mouse_thread);
- RT_DEBUG_LOG(RT_DEBUG_USB, ("start usb mouse\n"));
- #ifdef RT_USING_RTGUI
- RTGUI_EVENT_MOUSE_BUTTON_INIT(&emouse);
- emouse.wid = RT_NULL;
- cursor_display(RT_TRUE);
- #endif
- return RT_EOK;
- }
- /**
- * This function will define the hid mouse protocal, it will be register to the protocal list.
- *
- * @return the keyboard protocal structure.
- */
- uprotocal_t rt_usbh_hid_protocal_mouse(void)
- {
- mouse_protocal.pro_id = USB_HID_MOUSE;
- mouse_protocal.init = rt_usbh_hid_mouse_init;
- mouse_protocal.callback = rt_usbh_hid_mouse_callback;
- return &mouse_protocal;
- }
- #endif
|