Simplify on_enter/on_exit callbacks to position-only signature
BREAKING CHANGE: Hover callbacks now take only (pos) instead of (pos, button, action) - Add PyHoverCallable class for on_enter/on_exit/on_move callbacks (position-only) - Add PyCellHoverCallable class for on_cell_enter/on_cell_exit callbacks - Change UIDrawable member types from PyClickCallable to PyHoverCallable - Update PyScene::do_mouse_hover() to call hover callbacks with only position - Add tryCallPythonMethod overload for position-only subclass method calls - Update UIGrid::fireCellEnter/fireCellExit to use position-only signature - Update all tests for new callback signatures New callback signatures: | Callback | Old | New | |----------------|--------------------------|------------| | on_enter | (pos, button, action) | (pos) | | on_exit | (pos, button, action) | (pos) | | on_move | (pos, button, action) | (pos) | | on_cell_enter | (cell_pos, button, action)| (cell_pos)| | on_cell_exit | (cell_pos, button, action)| (cell_pos)| | on_click | unchanged | unchanged | | on_cell_click | unchanged | unchanged | closes #230 Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
parent
e14f3cb9fc
commit
2daebc84b5
12 changed files with 598 additions and 71 deletions
|
|
@ -49,9 +49,10 @@ def test_callback_refcount():
|
|||
errors.append(f"on_click returned non-callable after repeated access: {type(final_cb)}")
|
||||
|
||||
# Test on_enter, on_exit, on_move
|
||||
frame.on_enter = lambda pos, button, action: None
|
||||
frame.on_exit = lambda pos, button, action: None
|
||||
frame.on_move = lambda pos, button, action: None
|
||||
# #230 - Hover callbacks now take only (pos)
|
||||
frame.on_enter = lambda pos: None
|
||||
frame.on_exit = lambda pos: None
|
||||
frame.on_move = lambda pos: None
|
||||
|
||||
for name in ['on_enter', 'on_exit', 'on_move']:
|
||||
for i in range(5):
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue