it-swarm.com.ru

Как использовать HTML и CSS в качестве графического интерфейса приложения Java?

Я хочу разработать новый клиент Git с чистым графическим интерфейсом.

Можно ли использовать мощь HTML, CSS и JavaScript в приложении Java?

Я хотел бы использовать Java + JGit для моделей, Java для контроллеров и HTML + CSS + JavaScript для представлений.

Я не хочу модель клиент-сервер. Я хотел бы красиво интегрировать Java и HTML. Событие DOM будет запускать события непосредственно в контроллер Java. Таким образом, можно было бы создать богатое автономное приложение.

18
Guillaume Massé

Вы можете встроить компонент веб-браузера в свое приложение Java Swing/JavaFX Desktop, которое отображает графический интерфейс, созданный с использованием HTML5 + CSS + JavaScript. Вы можете увидеть статью, которая описывает, как это сделать, по адресу http://Java.dzone.com/articles/htmlcssjavascript-gui-Java-0

Одна из библиотек Java Swing/JavaFX, которая позволяет встраивать Chromium в приложения Java, - это JxBrowser . Используя JxBrowser API, вы можете загрузить любую веб-страницу и работать с ее DOM и JavaScript. Вы даже можете вызывать методы Java из кода JavaScript и наоборот. Например:

import com.teamdev.jxbrowser.chromium.Browser;
import com.teamdev.jxbrowser.chromium.JSFunctionCallback;
import com.teamdev.jxbrowser.chromium.JSObject;
import com.teamdev.jxbrowser.chromium.JSValue;
import com.teamdev.jxbrowser.chromium.events.FinishLoadingEvent;
import com.teamdev.jxbrowser.chromium.events.LoadAdapter;

public class JavaScriptJavaSample {
    public static void main(String[] args) {
        Browser browser = new Browser();
        browser.addLoadListener(new LoadAdapter() {
            @Override
            public void onFinishLoadingFrame(FinishLoadingEvent event) {
                if (event.isMainFrame()) {
                    Browser browser = event.getBrowser();
                    JSObject window = (JSObject)
                            browser.executeJavaScriptAndReturnValue("window");
                    window.setProperty("MyFunction", new JSFunctionCallback() {
                        @Override
                        public Object invoke(Object... args) {
                            for (Object arg : args) {
                                System.out.println("arg = " + arg);
                            }
                            return "Hello!";
                        }
                    });
                    JSValue returnValue = browser.executeJavaScriptAndReturnValue(
                            "MyFunction('Hello JxBrowser!', 1, 2, 3, true);");
                    System.out.println("return value = " + returnValue);
                }
            }
        });
        browser.loadURL("about:blank");
    }
}
12
Vladimir

Это не реально осуществимо. Богатые клиенты на Java выполняются с использованием Swing или SWT.

Если вы хотите использовать HTML/CSS для вашего пользовательского интерфейса, вам нужно использовать модель сервер/клиент. Это может быть так же просто, как создать локальный сервер и запустить браузер, который подключается к нему, но это все равно будет эта модель.

Если вам абсолютно необходимо иметь HTML/CSS в качестве структуры пользовательского интерфейса и вы не можете перейти к модели сервер/клиент, вам лучше всего выбрать что-то вроде собственного клиента Google, но при этом используются привязки C/C++ в бэкэнде. Я не использовал Native Client, поэтому лично я не могу дать гораздо больше информации по этому вопросу.

Изменить, чтобы добавить:

Один из вариантов - встроить собственный браузер в приложение Swing, используя что-то вроде: http://djproject.sourceforge.net/ns/

Существуют некоторые чистые Java-рендеры HTML, однако они, скорее всего, не будут полностью совместимы с HTML5/CSS3, не говоря уже о том, что, возможно, также есть ошибки в Javascript.

Посмотрите здесь для некоторых из этих опций: Чистый Java HTML Viewer/рендерер для использования в прокручиваемой панели

6
Reverend Gonzo

Как говорит @Reverand Gonzo, вам понадобится некая форма сервера/клиента. Но вы можете легко встроить сервер Jetty в приложение Java и затем использовать GWT для своего клиентского кода .

4
tinyd

Используйте Angular.js с HTML и остальными, как в Java, просто используйте классы для бизнес-логики, не нужно писать код для awt/swing. Angular with spring boot - это быстрая разработка на Java для веб-приложения с меньшим количеством кода на Java без использования свинга для создания лучшего веб-приложения.

0
Sunil Wagh

JavaFX 2.2 предоставил эту функциональность для предоставления компонента пользовательского интерфейса (GUI), который имеет веб-представление и полную функциональность просмотра.

Для получения дополнительной информации см. Добавление содержимого HTML в приложения JavaFX .

0
Sandeep Singh

Вы можете использовать возможности HTML, CSS, JavaScript в своем приложении Swing, используя JFXPanel для встраивания JavaFX WebView. Посмотрите демонстрацию SimpleSwingBrowser по этой ссылке: https://docs.Oracle.com/javase/8/javafx/interoperability-tutorial/swing-fx-interoperability.htm

WebView позволяет вызывать функции JavaScript из Java и наоборот. Это также хороший способ улучшить свое устаревшее Java-приложение с помощью веб-технологий.

0
johnk