1
Fork 0
mirror of git://git.sv.gnu.org/emacs.git synced 2025-12-28 08:11:05 -08:00

Update Android port

* java/org/gnu/emacs/EmacsContextMenu.java (display): Use
`EmacsHolder' instead of `Holder'.
* java/org/gnu/emacs/EmacsDialog.java (toAlertDialog): Use
`EmacsDialogButtonLayout' to ensure that buttons are wrapped
properly.
(display): Adjust for new holder class.
* java/org/gnu/emacs/EmacsDialogButtonLayout.java
(EmacsDialogButtonLayout, onMeasure, onLayout): New functions.

* java/org/gnu/emacs/EmacsDrawLine.java:
* java/org/gnu/emacs/EmacsFillPolygon.java: Remove redundant
imports.
* java/org/gnu/emacs/EmacsHolder.java (EmacsHolder<T>):
* java/org/gnu/emacs/EmacsService.java (class Holder<T>)
(getEmacsView, EmacsService): Rename `Holder' to `EmacsHolder'
and make it public.
This commit is contained in:
Po Lu 2023-06-06 14:35:19 +08:00
parent 5f09df3d6a
commit 5b4dea0fc7
7 changed files with 195 additions and 25 deletions

View file

@ -0,0 +1,152 @@
/* Communication module for Android terminals. -*- c-file-style: "GNU" -*-
Copyright (C) 2023 Free Software Foundation, Inc.
This file is part of GNU Emacs.
GNU Emacs is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or (at
your option) any later version.
GNU Emacs is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>. */
package org.gnu.emacs;
import android.content.Context;
import android.view.View;
import android.view.View.MeasureSpec;
import android.view.ViewGroup;
/* This ``view group'' implements a container widget for multiple
buttons of the type found in pop-up dialogs. It is used when
displaying a dialog box that contains more than three buttons, as
the default dialog box widget is not capable of holding more than
that many. */
public class EmacsDialogButtonLayout extends ViewGroup
{
public
EmacsDialogButtonLayout (Context context)
{
super (context);
}
@Override
protected void
onMeasure (int widthMeasureSpec, int heightMeasureSpec)
{
int width, count, i, x, y, height, spec, tempSpec;
View view;
/* Obtain the width of this widget and create the measure
specification used to measure children. */
width = MeasureSpec.getSize (widthMeasureSpec);
spec = MeasureSpec.makeMeasureSpec (0, MeasureSpec.UNSPECIFIED);
tempSpec
= MeasureSpec.makeMeasureSpec (width, MeasureSpec.AT_MOST);
x = y = height = 0;
/* Run through each widget. */
count = getChildCount ();
for (i = 0; i < count; ++i)
{
view = getChildAt (i);
/* Measure this view. */
view.measure (spec, spec);
if (width - x < view.getMeasuredWidth ())
{
/* Move onto the next line, unless this line is empty. */
if (x != 0)
{
y += height;
height = x = 0;
}
if (view.getMeasuredWidth () > width)
/* Measure the view again, this time forcing it to be at
most width wide, if it is not already. */
view.measure (tempSpec, spec);
}
height = Math.max (height, view.getMeasuredHeight ());
x += view.getMeasuredWidth ();
}
/* Now set the measured size of this widget. */
setMeasuredDimension (width, y + height);
}
@Override
protected void
onLayout (boolean changed, int left, int top, int right,
int bottom)
{
int width, count, i, x, y, height, spec, tempSpec;
View view;
/* Obtain the width of this widget and create the measure
specification used to measure children. */
width = getMeasuredWidth ();
spec = MeasureSpec.makeMeasureSpec (0, MeasureSpec.UNSPECIFIED);
tempSpec
= MeasureSpec.makeMeasureSpec (width, MeasureSpec.AT_MOST);
x = y = height = 0;
/* Run through each widget. */
count = getChildCount ();
for (i = 0; i < count; ++i)
{
view = getChildAt (i);
/* Measure this view. */
view.measure (spec, spec);
if (width - x < view.getMeasuredWidth ())
{
/* Move onto the next line, unless this line is empty. */
if (x != 0)
{
y += height;
height = x = 0;
}
if (view.getMeasuredWidth () > width)
/* Measure the view again, this time forcing it to be at
most width wide, if it is not already. */
view.measure (tempSpec, spec);
}
/* Now assign this view its position. */
view.layout (x, y, x + view.getMeasuredWidth (),
y + view.getMeasuredHeight ());
/* And move on to the next widget. */
height = Math.max (height, view.getMeasuredHeight ());
x += view.getMeasuredWidth ();
}
}
};