+// avoid repetition
+#define TREE_EVENT_HANDLER(name) \
+void MyTreeCtrl::name(wxTreeEvent& event) \
+{ \
+ wxLogMessage(wxT(#name)); \
+ event.Skip(); \
+}
+
+TREE_EVENT_HANDLER(OnBeginRDrag)
+TREE_EVENT_HANDLER(OnDeleteItem)
+TREE_EVENT_HANDLER(OnGetInfo)
+TREE_EVENT_HANDLER(OnSetInfo)
+TREE_EVENT_HANDLER(OnItemExpanded)
+TREE_EVENT_HANDLER(OnItemExpanding)
+TREE_EVENT_HANDLER(OnItemCollapsed)
+TREE_EVENT_HANDLER(OnSelChanged)
+TREE_EVENT_HANDLER(OnSelChanging)
+
+#undef TREE_EVENT_HANDLER
+
+void LogKeyEvent(const wxChar *name, const wxKeyEvent& event)
+{
+ wxString key;
+ long keycode = event.KeyCode();
+ {
+ switch ( keycode )
+ {
+ case WXK_BACK: key = "BACK"; break;
+ case WXK_TAB: key = "TAB"; break;
+ case WXK_RETURN: key = "RETURN"; break;
+ case WXK_ESCAPE: key = "ESCAPE"; break;
+ case WXK_SPACE: key = "SPACE"; break;
+ case WXK_DELETE: key = "DELETE"; break;
+ case WXK_START: key = "START"; break;
+ case WXK_LBUTTON: key = "LBUTTON"; break;
+ case WXK_RBUTTON: key = "RBUTTON"; break;
+ case WXK_CANCEL: key = "CANCEL"; break;
+ case WXK_MBUTTON: key = "MBUTTON"; break;
+ case WXK_CLEAR: key = "CLEAR"; break;
+ case WXK_SHIFT: key = "SHIFT"; break;
+ case WXK_ALT: key = "ALT"; break;
+ case WXK_CONTROL: key = "CONTROL"; break;
+ case WXK_MENU: key = "MENU"; break;
+ case WXK_PAUSE: key = "PAUSE"; break;
+ case WXK_CAPITAL: key = "CAPITAL"; break;
+ case WXK_PRIOR: key = "PRIOR"; break;
+ case WXK_NEXT: key = "NEXT"; break;
+ case WXK_END: key = "END"; break;
+ case WXK_HOME: key = "HOME"; break;
+ case WXK_LEFT: key = "LEFT"; break;
+ case WXK_UP: key = "UP"; break;
+ case WXK_RIGHT: key = "RIGHT"; break;
+ case WXK_DOWN: key = "DOWN"; break;
+ case WXK_SELECT: key = "SELECT"; break;
+ case WXK_PRINT: key = "PRINT"; break;
+ case WXK_EXECUTE: key = "EXECUTE"; break;
+ case WXK_SNAPSHOT: key = "SNAPSHOT"; break;
+ case WXK_INSERT: key = "INSERT"; break;
+ case WXK_HELP: key = "HELP"; break;
+ case WXK_NUMPAD0: key = "NUMPAD0"; break;
+ case WXK_NUMPAD1: key = "NUMPAD1"; break;
+ case WXK_NUMPAD2: key = "NUMPAD2"; break;
+ case WXK_NUMPAD3: key = "NUMPAD3"; break;
+ case WXK_NUMPAD4: key = "NUMPAD4"; break;
+ case WXK_NUMPAD5: key = "NUMPAD5"; break;
+ case WXK_NUMPAD6: key = "NUMPAD6"; break;
+ case WXK_NUMPAD7: key = "NUMPAD7"; break;
+ case WXK_NUMPAD8: key = "NUMPAD8"; break;
+ case WXK_NUMPAD9: key = "NUMPAD9"; break;
+ case WXK_MULTIPLY: key = "MULTIPLY"; break;
+ case WXK_ADD: key = "ADD"; break;
+ case WXK_SEPARATOR: key = "SEPARATOR"; break;
+ case WXK_SUBTRACT: key = "SUBTRACT"; break;
+ case WXK_DECIMAL: key = "DECIMAL"; break;
+ case WXK_DIVIDE: key = "DIVIDE"; break;
+ case WXK_F1: key = "F1"; break;
+ case WXK_F2: key = "F2"; break;
+ case WXK_F3: key = "F3"; break;
+ case WXK_F4: key = "F4"; break;
+ case WXK_F5: key = "F5"; break;
+ case WXK_F6: key = "F6"; break;
+ case WXK_F7: key = "F7"; break;
+ case WXK_F8: key = "F8"; break;
+ case WXK_F9: key = "F9"; break;
+ case WXK_F10: key = "F10"; break;
+ case WXK_F11: key = "F11"; break;
+ case WXK_F12: key = "F12"; break;
+ case WXK_F13: key = "F13"; break;
+ case WXK_F14: key = "F14"; break;
+ case WXK_F15: key = "F15"; break;
+ case WXK_F16: key = "F16"; break;
+ case WXK_F17: key = "F17"; break;
+ case WXK_F18: key = "F18"; break;
+ case WXK_F19: key = "F19"; break;
+ case WXK_F20: key = "F20"; break;
+ case WXK_F21: key = "F21"; break;
+ case WXK_F22: key = "F22"; break;
+ case WXK_F23: key = "F23"; break;
+ case WXK_F24: key = "F24"; break;
+ case WXK_NUMLOCK: key = "NUMLOCK"; break;
+ case WXK_SCROLL: key = "SCROLL"; break;
+ case WXK_PAGEUP: key = "PAGEUP"; break;
+ case WXK_PAGEDOWN: key = "PAGEDOWN"; break;
+ case WXK_NUMPAD_SPACE: key = "NUMPAD_SPACE"; break;
+ case WXK_NUMPAD_TAB: key = "NUMPAD_TAB"; break;
+ case WXK_NUMPAD_ENTER: key = "NUMPAD_ENTER"; break;
+ case WXK_NUMPAD_F1: key = "NUMPAD_F1"; break;
+ case WXK_NUMPAD_F2: key = "NUMPAD_F2"; break;
+ case WXK_NUMPAD_F3: key = "NUMPAD_F3"; break;
+ case WXK_NUMPAD_F4: key = "NUMPAD_F4"; break;
+ case WXK_NUMPAD_HOME: key = "NUMPAD_HOME"; break;
+ case WXK_NUMPAD_LEFT: key = "NUMPAD_LEFT"; break;
+ case WXK_NUMPAD_UP: key = "NUMPAD_UP"; break;
+ case WXK_NUMPAD_RIGHT: key = "NUMPAD_RIGHT"; break;
+ case WXK_NUMPAD_DOWN: key = "NUMPAD_DOWN"; break;
+ case WXK_NUMPAD_PRIOR: key = "NUMPAD_PRIOR"; break;
+ case WXK_NUMPAD_PAGEUP: key = "NUMPAD_PAGEUP"; break;
+ case WXK_NUMPAD_PAGEDOWN: key = "NUMPAD_PAGEDOWN"; break;
+ case WXK_NUMPAD_END: key = "NUMPAD_END"; break;
+ case WXK_NUMPAD_BEGIN: key = "NUMPAD_BEGIN"; break;
+ case WXK_NUMPAD_INSERT: key = "NUMPAD_INSERT"; break;
+ case WXK_NUMPAD_DELETE: key = "NUMPAD_DELETE"; break;
+ case WXK_NUMPAD_EQUAL: key = "NUMPAD_EQUAL"; break;
+ case WXK_NUMPAD_MULTIPLY: key = "NUMPAD_MULTIPLY"; break;
+ case WXK_NUMPAD_ADD: key = "NUMPAD_ADD"; break;
+ case WXK_NUMPAD_SEPARATOR: key = "NUMPAD_SEPARATOR"; break;
+ case WXK_NUMPAD_SUBTRACT: key = "NUMPAD_SUBTRACT"; break;
+ case WXK_NUMPAD_DECIMAL: key = "NUMPAD_DECIMAL"; break;
+
+ default:
+ {
+ if ( wxIsprint((int)keycode) )
+ key.Printf(_T("'%c'"), (char)keycode);
+ else if ( keycode > 0 && keycode < 27 )
+ key.Printf(_("Ctrl-%c"), _T('A') + keycode - 1);
+ else
+ key.Printf(_T("unknown (%ld)"), keycode);
+ }
+ }
+ }
+
+ wxLogMessage( _T("%s event: %s (flags = %c%c%c%c)"),
+ name,
+ key.c_str(),
+ event.ControlDown() ? _T('C') : _T('-'),
+ event.AltDown() ? _T('A') : _T('-'),
+ event.ShiftDown() ? _T('S') : _T('-'),
+ event.MetaDown() ? _T('M') : _T('-'));
+}
+
+void MyTreeCtrl::OnTreeKeyDown(wxTreeEvent& event)
+{
+ LogKeyEvent(_T("Tree key down "), event.GetKeyEvent());
+
+ event.Skip();
+}
+
+void MyTreeCtrl::OnBeginDrag(wxTreeEvent& event)
+{
+ // need to explicitly allow drag
+ if ( event.GetItem() != GetRootItem() )
+ {
+ m_draggedItem = event.GetItem();
+
+ wxLogMessage(wxT("OnBeginDrag: started dragging %s"),
+ GetItemText(m_draggedItem).c_str());
+
+ event.Allow();
+ }
+ else
+ {
+ wxLogMessage(wxT("OnBeginDrag: this item can't be dragged."));
+ }