diff options
| author | Po Lu | 2023-01-13 15:53:08 +0800 |
|---|---|---|
| committer | Po Lu | 2023-01-13 15:53:08 +0800 |
| commit | f9732131cf3c67e24db74a3d49f256d3c189a7e3 (patch) | |
| tree | e44e097c0c4c513390f58fa0020c8662943fbac6 /src/androidgui.h | |
| parent | 2fa5583d96fe78ff66d6fd41f18e54e4e20ea7d6 (diff) | |
| download | emacs-f9732131cf3c67e24db74a3d49f256d3c189a7e3.tar.gz emacs-f9732131cf3c67e24db74a3d49f256d3c189a7e3.zip | |
Update Android port
* configure.ac (ANDROID_MIN_SDK): New variable.
(DX): Remove and replace with D8.
(XCONFIGURE): Check for the minimum version of Android the cross
compiler compiles for. Generate java/AndroidManifest.xml from
java/AndroidManifest.xml.in. Allow using Zlib on Android.
* java/AndroidManifest.xml.in: New file. Use the minimum SDK
detected by configure.
* java/Makefile.in (top_srcdir, version): New variables.
(DX, D8): Replace with D8.
(ANDROID_MIN_SDK, APK_NAME): New variables.
(.PHONY):
(.PRECIOUS):
(classes.dex):
(emacs.apk): Generate $(APK_NAME) instead of `emacs.apk'.
* java/debug.sh: New option --attach-existing. Attach to an
existing Emacs instance when specified.
* java/org/gnu/emacs/EmacsActivity.java (EmacsActivity): New
field `isPaused'.
(invalidateFocus1): Fix infinite recursion.
(detachWindow): Deiconify window.
(attachWindow): Iconify the window if the activity is paused.
(onCreate): Use the ``no title bar'' theme.
(onPause, onResume): New functions.
* java/org/gnu/emacs/EmacsNative.java (sendTouchUp, sendTouchDown)
(sendTouchMove, sendWheel, sendIconified, sendDeiconified): New
functions.
* java/org/gnu/emacs/EmacsSdk7FontDriver.java (Sdk7Typeface):
(list): Remove logging for code that is mostly going to be unused.
* java/org/gnu/emacs/EmacsService.java (ringBell, queryTree)
(getScreenWidth, getScreenHeight, detectMouse): New functions.
* java/org/gnu/emacs/EmacsSurfaceView.java (EmacsSurfaceView)
(surfaceChanged, surfaceCreated, surfaceDestroyed): Add extra
debug logging. Avoid deadlock in surfaceCreated.
* java/org/gnu/emacs/EmacsView.java (EmacsView): Try very hard
to make the SurfaceView respect Z order. It didn't work.
(handleDirtyBitmap): Copy over the contents from the old bitmap.
(explicitlyDirtyBitmap): New function.
(onLayout): Don't dirty bitmap if unnecessary.
(damageRect, swapBuffers): Don't synchronize so hard.
(onTouchEvent): Call window.onTouchEvent instead.
(moveChildToBack, raise, lower): New functions.
* java/org/gnu/emacs/EmacsWindow.java (Coordinate): New
subclass.
(pointerMap, isMapped, isIconified, dontFocusOnMap)
(dontAcceptFocus): New fields.
(EmacsWindow): Don't immediately register unmapped window.
(viewLayout): Send configure event outside the lock.
(requestViewLayout): Explicitly dirty the bitmap.
(mapWindow): Register the window now. Respect dontFocusOnMap.
(unmapWindow): Unregister the window now.
(figureChange, onTouchEvent): New functions.
(onSomeKindOfMotionEvent): Handle scroll wheel events.
(reparentTo, makeInputFocus, raise, lower, getWindowGeometry)
(noticeIconified, noticeDeiconified, setDontAcceptFocus)
(setDontFocusOnMap, getDontFocusOnMap): New functions.
* java/org/gnu/emacs/EmacsWindowAttachmentManager.java
(registerWindow, detachWindow): Synchronize.
(noticeIconified, noticeDeiconified): New functions.
(copyWindows): New function.
* lisp/frame.el (frame-geometry, frame-edges)
(mouse-absolute-pixel-position, set-mouse-absolute-pixel-position)
(frame-list-z-order, frame-restack, display-mouse-p)
(display-monitor-attributes-list): Implement on Android.
* lisp/mwheel.el (mouse-wheel-down-event):
(mouse-wheel-up-event):
(mouse-wheel-left-event):
(mouse-wheel-right-event): Define on Android.
* src/android.c (struct android_emacs_service): New methods
`ringBell', `queryTree', `getScreenWidth', `getScreenHeight',
and `detectMouse'.
(struct android_event_queue, android_init_events)
(android_next_event, android_write_event): Remove write limit.
(android_file_access_p): Handle directories correcty.
(android_close): Fix coding style.
(android_fclose): New function.
(android_init_emacs_service): Initialize new methods.
(android_reparent_window): Implement function.
(android_bell, android_set_input_focus, android_raise_window)
(android_lower_window, android_query_tree, android_get_geometry)
(android_get_screen_width, android_get_screen_height)
(android_get_mm_width, android_get_mm_height, android_detect_mouse)
(android_set_dont_focus_on_map, android_set_dont_accept_focus):
New functions.
(struct android_dir): New structure.
(android_opendir, android_readdir, android_closedir): New
functions.
(emacs_abort): Implement here on Android and poke debuggerd into
generating a tombstone.
* src/android.h: Update prototypes.
* src/androidfns.c (android_set_parent_frame): New function.
(android_default_font_parameter): Use sane font size by default.
(Fx_display_pixel_width, Fx_display_pixel_height)
(Fx_display_mm_width, Fx_display_mm_height)
(Fx_display_monitor_attributes_list): Rename to start with
`android-'. Implement. Fiddle with documentation to introduce
Android specific nuances.
(Fandroid_display_monitor_attributes_list): New function.
(Fx_frame_geometry, frame_geometry): New function.
(Fandroid_frame_geometry): Implement correctly.
(Fx_frame_list_z_order): Rename to start with `android-'.
(android_frame_list_z_order, Fandroid_frame_list_z_order):
Implement.
(Fx_frame_restack): Rename to start with `android-'.
(Fandroid_frame_restack): ``Implement''.
(Fx_mouse_absolute_pixel_position): Rename to start with
`android-'.
(Fandroid_mouse_absolute_pixel_position): ``Implement''.
(Fx_set_mouse_absolute_pixel_position): Rename to start with
`android-'.
(Fandroid_set_mouse_absolute_pixel_position): ``Implement''.
(Fandroid_detect_mouse): New function.
(android_set_menu_bar_lines): Use FRAME_ANDROID_DRAWABLE when
clearing area.
(android_set_no_focus_on_map, android_set_no_accept_focus): New
functions.
(android_frame_parm_handlers): Register new frame parameter
handlers.
(syms_of_androidfns): Update appropriately.
* src/androidfont.c (androidfont_draw): Use
FRAME_ANDROID_DRAWABLE instead of FRAME_ANDROID_WINDOW.
* src/androidgui.h (enum android_event_type): New events.
(struct android_touch_event, struct android_wheel_event)
(struct android_iconify_event): New structures.
(union android_event): Add new events.
* src/androidterm.c (android_clear_frame): Use
FRAME_ANDROID_DRAWABLE instead of FRAME_ANDROID_WINDOW.
(android_flash, android_ring_bell): Implement bell ringing.
(android_toggle_invisible_pointer): Don't TODO function that
can't be implemented.
(show_back_buffer, android_flush_dirty_back_buffer_on): Check if
a buffer flip is required before doing the flip.
(android_lower_frame, android_raise_frame): Implement functions.
(android_update_tools, android_find_tool): New functions.
(handle_one_android_event): Handle new iconification, wheel and
touch events.
(android_read_socket): Implement pending-autoraise-frames.
(android_frame_up_to_date): Implement bell ringing.
(android_buffer_flipping_unblocked_hook): Check if a buffer flip
is required before doing the flip.
(android_focus_frame, android_frame_highlight)
(android_frame_unhighlight): New function.
(android_frame_rehighlight): Implement functions.
(android_iconify_frame): Always display error.
(android_set_alpha): Update commentary.
(android_free_frame_resources): Free frame touch points.
(android_scroll_run, android_flip_and_flush)
(android_clear_rectangle, android_draw_fringe_bitmap)
(android_draw_glyph_string_background, android_fill_triangle)
(android_clear_point, android_draw_relief_rect)
(android_draw_box_rect, android_draw_glyph_string_bg_rect)
(android_draw_image_foreground, android_draw_stretch_glyph_string)
(android_draw_underwave, android_draw_glyph_string_foreground)
(android_draw_composite_glyph_string_foreground)
(android_draw_glyphless_glyph_string_foreground)
(android_draw_glyph_string, android_clear_frame_area)
(android_clear_under_internal_border, android_draw_hollow_cursor)
(android_draw_bar_cursor, android_draw_vertical_window_border)
(android_draw_window_divider): Use FRAME_ANDROID_DRAWABLE
instead of FRAME_ANDROID_WINDOW for drawing operations.
* src/androidterm.h (struct android_touch_point): New structure.
(struct android_output): New fields.
(FRAME_ANDROID_NEED_BUFFER_FLIP): New macro.
* src/dired.c (emacs_readdir, open_directory)
(directory_files_internal_unwind, read_dirent)
(directory_files_internal, file_name_completion): Add
indirection over readdir and opendir. Use android variants on
Android.
* src/dispnew.c (Fopen_termscript):
* src/fileio.c (fclose_unwind): Use emacs_fclose.
(Faccess_file): Call android_file_access_p.
(file_accessible_directory_p): Append right suffix to Android
assets directory.
(do_auto_save_unwind): Use emacs_fclose.
* src/keyboard.c (lispy_function_keys): Use right function key
for page up and page down.
(Fopen_dribble_file): Use emacs_fclose.
* src/lisp.h: New prototype emacs_fclose.
* src/lread.c (close_infile_unwind): Use emacs_fclose.
* src/sfnt.c (sfnt_curve_is_flat): Fix area-squared computation.
(sfnt_prepare_raster): Compute raster width and height
consistently with outline building.
(sfnt_build_outline_edges): Use the same offsets used to set
offy and offx.
(main): Adjust debug code.
* src/sfntfont-android.c (sfntfont_android_saturate32): Delete
function.
(sfntfont_android_blend, sfntfont_android_blendrgb): Remove
unnecessary debug code.
(sfntfont_android_composite_bitmap): Prevent out of bounds
write.
(sfntfont_android_put_glyphs): Use FRAME_ANDROID_DRAWABLE.
(init_sfntfont_android): Initialize Monospace Serif font to
something sensible.
* src/sfntfont.c (sfntfont_text_extents): Clear glyph metrics
before summing up pcm.
(sfntfont_draw): Use s->font instead of s->face->font.
* src/sysdep.c (emacs_fclose): Wrap around android_fclose on
android.
* src/term.c (Fsuspend_tty):
(delete_tty): Use emacs_fclose.
* src/verbose.mk.in (AM_V_DX): Replace with D8 version.
Diffstat (limited to 'src/androidgui.h')
| -rw-r--r-- | src/androidgui.h | 83 |
1 files changed, 83 insertions, 0 deletions
diff --git a/src/androidgui.h b/src/androidgui.h index 7d045f7b450..422e72408c7 100644 --- a/src/androidgui.h +++ b/src/androidgui.h | |||
| @@ -222,6 +222,12 @@ enum android_event_type | |||
| 222 | ANDROID_MOTION_NOTIFY, | 222 | ANDROID_MOTION_NOTIFY, |
| 223 | ANDROID_BUTTON_PRESS, | 223 | ANDROID_BUTTON_PRESS, |
| 224 | ANDROID_BUTTON_RELEASE, | 224 | ANDROID_BUTTON_RELEASE, |
| 225 | ANDROID_TOUCH_DOWN, | ||
| 226 | ANDROID_TOUCH_UP, | ||
| 227 | ANDROID_TOUCH_MOVE, | ||
| 228 | ANDROID_WHEEL, | ||
| 229 | ANDROID_ICONIFIED, | ||
| 230 | ANDROID_DEICONIFIED, | ||
| 225 | }; | 231 | }; |
| 226 | 232 | ||
| 227 | struct android_any_event | 233 | struct android_any_event |
| @@ -312,6 +318,54 @@ struct android_button_event | |||
| 312 | unsigned int button; | 318 | unsigned int button; |
| 313 | }; | 319 | }; |
| 314 | 320 | ||
| 321 | struct android_touch_event | ||
| 322 | { | ||
| 323 | /* Type of the event. */ | ||
| 324 | enum android_event_type type; | ||
| 325 | |||
| 326 | /* Window associated with the event. */ | ||
| 327 | android_window window; | ||
| 328 | |||
| 329 | /* X and Y coordinates of the event. */ | ||
| 330 | int x, y; | ||
| 331 | |||
| 332 | /* Time of the event, and the pointer identifier. */ | ||
| 333 | unsigned long time; | ||
| 334 | |||
| 335 | /* Index of the pointer being tracked. */ | ||
| 336 | unsigned int pointer_id; | ||
| 337 | }; | ||
| 338 | |||
| 339 | struct android_wheel_event | ||
| 340 | { | ||
| 341 | /* Type of the event. */ | ||
| 342 | enum android_event_type type; | ||
| 343 | |||
| 344 | /* Window associated with the event. */ | ||
| 345 | android_window window; | ||
| 346 | |||
| 347 | /* X and Y coordinates of the event. */ | ||
| 348 | int x, y; | ||
| 349 | |||
| 350 | /* Time of the event, and the pointer identifier. */ | ||
| 351 | unsigned long time; | ||
| 352 | |||
| 353 | /* Modifier state at the time of the event. */ | ||
| 354 | int state; | ||
| 355 | |||
| 356 | /* Motion alongside the X and Y axes. */ | ||
| 357 | double x_delta, y_delta; | ||
| 358 | }; | ||
| 359 | |||
| 360 | struct android_iconify_event | ||
| 361 | { | ||
| 362 | /* Type of the event. */ | ||
| 363 | enum android_event_type type; | ||
| 364 | |||
| 365 | /* Window associated with the event. */ | ||
| 366 | android_window window; | ||
| 367 | }; | ||
| 368 | |||
| 315 | union android_event | 369 | union android_event |
| 316 | { | 370 | { |
| 317 | enum android_event_type type; | 371 | enum android_event_type type; |
| @@ -323,8 +377,26 @@ union android_event | |||
| 323 | struct android_crossing_event xcrossing; | 377 | struct android_crossing_event xcrossing; |
| 324 | struct android_motion_event xmotion; | 378 | struct android_motion_event xmotion; |
| 325 | struct android_button_event xbutton; | 379 | struct android_button_event xbutton; |
| 380 | |||
| 381 | /* This has no parallel in X, since the X model of having | ||
| 382 | monotonically increasing touch IDs can't work on Android. */ | ||
| 383 | struct android_touch_event touch; | ||
| 384 | |||
| 385 | /* This has no parallel in X outside the X Input Extension, and | ||
| 386 | emulating the input extension interface would be awfully | ||
| 387 | complicated. */ | ||
| 388 | struct android_wheel_event wheel; | ||
| 389 | |||
| 390 | /* This has no parallel in X because Android doesn't have window | ||
| 391 | properties. */ | ||
| 392 | struct android_iconify_event iconified; | ||
| 326 | }; | 393 | }; |
| 327 | 394 | ||
| 395 | enum | ||
| 396 | { | ||
| 397 | ANDROID_CURRENT_TIME = 0L, | ||
| 398 | }; | ||
| 399 | |||
| 328 | extern int android_pending (void); | 400 | extern int android_pending (void); |
| 329 | extern void android_next_event (union android_event *); | 401 | extern void android_next_event (union android_event *); |
| 330 | 402 | ||
| @@ -396,6 +468,17 @@ extern void android_clear_area (android_window, int, int, unsigned int, | |||
| 396 | extern android_pixmap android_create_bitmap_from_data (char *, unsigned int, | 468 | extern android_pixmap android_create_bitmap_from_data (char *, unsigned int, |
| 397 | unsigned int); | 469 | unsigned int); |
| 398 | 470 | ||
| 471 | extern void android_bell (void); | ||
| 472 | extern void android_set_input_focus (android_window, unsigned long); | ||
| 473 | extern void android_raise_window (android_window); | ||
| 474 | extern void android_lower_window (android_window); | ||
| 475 | extern int android_query_tree (android_window, android_window *, | ||
| 476 | android_window *, android_window **, | ||
| 477 | unsigned int *); | ||
| 478 | extern void android_get_geometry (android_window, android_window *, | ||
| 479 | int *, int *, unsigned int *, | ||
| 480 | unsigned int *, unsigned int *); | ||
| 481 | |||
| 399 | #endif | 482 | #endif |
| 400 | 483 | ||
| 401 | 484 | ||