动画";“鬼影”;关于xxhdpi安卓javafxports应用程序

动画";“鬼影”;关于xxhdpi安卓javafxports应用程序,javafx,gluon-mobile,javafxports,Javafx,Gluon Mobile,Javafxports,我已经编写了一个小型javafx应用程序,它可以为从左上角到右下角移动的正方形设置动画。然后,它反转动画并连续运行。在我的像素4(xxhdpi)上,正方形在回程时留下了一条边的轨迹。这不会发生在我的Nexus 7 2013(xhdpi)或我的桌面上 尝试了gluon插件和gluon vm插件 似乎与屏幕像素密度有关。如何防止密集屏幕上的重影瑕疵?下面的图片和代码 像素4屏幕截图: Nexus 2013屏幕截图: 应用程序: public class StockJavaFx extends A

我已经编写了一个小型javafx应用程序,它可以为从左上角到右下角移动的正方形设置动画。然后,它反转动画并连续运行。在我的像素4(xxhdpi)上,正方形在回程时留下了一条边的轨迹。这不会发生在我的Nexus 7 2013(xhdpi)或我的桌面上

尝试了gluon插件和gluon vm插件

似乎与屏幕像素密度有关。如何防止密集屏幕上的重影瑕疵?下面的图片和代码

像素4屏幕截图:

Nexus 2013屏幕截图:

应用程序:

public class StockJavaFx extends Application {
    @Override
    public void start(Stage primaryStage) {
        Dimension2D dimension = Services.get(DisplayService.class)
                .map(DisplayService::getDefaultDimensions)
                .orElseThrow(() -> new NullPointerException("DisplayService"));

        Rectangle rectangle = new Rectangle(75, 75);

        Pane container = new Pane();
        container.getChildren().add(new Rectangle(dimension.getWidth(), dimension.getHeight(), Color.DARKSLATEGRAY));
        container.getChildren().add(rectangle);

        Scene scene = new Scene(container);

        primaryStage.setScene(scene);

        TranslateTransition tt = new TranslateTransition(Duration.millis(750), rectangle);
        tt.setFromX(0);
        tt.setToX(dimension.getWidth() - 75);
        tt.setFromY(0);
        tt.setToY(dimension.getHeight() - 75);
        tt.setCycleCount(Animation.INDEFINITE);
        tt.setAutoReverse(true);

        FillTransition ft = new FillTransition(Duration.millis(750), rectangle);
        ft.setFromValue(Color.ORANGERED);
        ft.setToValue(Color.CADETBLUE);
        ft.setCycleCount(Animation.INDEFINITE);
        ft.setAutoReverse(true);

        tt.play();
        ft.play();

        primaryStage.show();
    }
}
旧的Gluon
jfxmobile
插件或多或少是EOL,它正在被新的Gluon客户端插件所取代。更多详细信息,请参阅。可以找到详细的文档

这就是你可以尝试创建一个Android应用程序来解决“重影”问题的方法,还有一些额外的“小”好处,比如使用Java和JavaFX11+、GraalVM,以及获得一个性能更高的应用程序。 请注意,Android客户端插件仍在大量开发中,尚未准备好投入生产

开始之前,请检查您是否遵循了先决条件:

  • 使用Linux机器
  • GraalVM的下载和摘录
  • GRAALVM\u HOME
    环境变量设置为GRAALVM安装目录,如下所示:

    export GRAALVM_HOME=/opt/graalvm-svm-linux-20.1.0-ea+28
    
  • 使用Java 11,或设置
    export Java_HOME=$GRAALVM_HOME
您可以修改其中一个现有示例,如

您可以修改pom以使用最新版本,如:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.gluonhq.hello</groupId>
    <artifactId>hellogluon</artifactId>
    <version>1.0-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>hellogluon</name>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.release>11</maven.compiler.release>
        <javafx.version>14.0.1</javafx.version>
        <attach.version>4.0.7</attach.version>
        <client.plugin.version>0.1.22</client.plugin.version>
        <mainClassName>com.gluonhq.hello.HelloGluon</mainClassName>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.openjfx</groupId>
            <artifactId>javafx-controls</artifactId>
            <version>${javafx.version}</version>
        </dependency>
        <dependency>
            <groupId>com.gluonhq</groupId>
            <artifactId>charm-glisten</artifactId>
            <version>6.0.4</version>
        </dependency>
        <dependency>
            <groupId>com.gluonhq.attach</groupId>
            <artifactId>display</artifactId>
            <version>${attach.version}</version>
        </dependency>
        <dependency>
            <groupId>com.gluonhq.attach</groupId>
            <artifactId>lifecycle</artifactId>
            <version>${attach.version}</version>
        </dependency>
        <dependency>
            <groupId>com.gluonhq.attach</groupId>
            <artifactId>statusbar</artifactId>
            <version>${attach.version}</version>
        </dependency>
        <dependency>
            <groupId>com.gluonhq.attach</groupId>
            <artifactId>storage</artifactId>
            <version>${attach.version}</version>
        </dependency>
        <dependency>
            <groupId>com.gluonhq.attach</groupId>
            <artifactId>util</artifactId>
            <version>${attach.version}</version>
        </dependency>
    </dependencies>

    <repositories>
        <repository>
            <id>Gluon</id>
            <url>https://nexus.gluonhq.com/nexus/content/repositories/releases</url>
        </repository>
    </repositories>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>3.8.1</version>
                <configuration>
                    <release>${maven.compiler.release}</release>
                </configuration>
            </plugin>

            <plugin>
                <groupId>org.openjfx</groupId>
                <artifactId>javafx-maven-plugin</artifactId>
                <version>0.0.4</version>
                <configuration>
                    <mainClass>${mainClassName}</mainClass>
                </configuration>
            </plugin>

            <plugin>
                <groupId>com.gluonhq</groupId>
                <artifactId>client-maven-plugin</artifactId>
                <version>${client.plugin.version}</version>
                <configuration>
                    <target>${client.target}</target>
                    <attachList>
                        <list>display</list>
                        <list>lifecycle</list>
                        <list>statusbar</list>
                        <list>storage</list>
                    </attachList>
                    <mainClass>${mainClassName}</mainClass>
                </configuration>
            </plugin>
        </plugins>

    <profiles>
        <profile>
            <id>desktop</id>
            <activation>
                <activeByDefault>true</activeByDefault>
            </activation>
            <properties>
                <client.target>host</client.target>
            </properties>
            <dependencies>
                <dependency>
                    <groupId>com.gluonhq.attach</groupId>
                    <artifactId>display</artifactId>
                    <version>${attach.version}</version>
                    <classifier>desktop</classifier>
                    <scope>runtime</scope>
                </dependency>
                <dependency>
                    <groupId>com.gluonhq.attach</groupId>
                    <artifactId>lifecycle</artifactId>
                    <version>${attach.version}</version>
                    <classifier>desktop</classifier>
                    <scope>runtime</scope>
                </dependency>
                <dependency>
                    <groupId>com.gluonhq.attach</groupId>
                    <artifactId>storage</artifactId>
                    <version>${attach.version}</version>
                    <classifier>desktop</classifier>
                    <scope>runtime</scope>
                </dependency>
            </dependencies>
        </profile>
        <profile>
            <id>ios</id>
            <properties>
                <client.target>ios</client.target>
            </properties>
        </profile>
        <profile>
            <id>android</id>
            <properties>
                <client.target>android</client.target>
            </properties>
        </profile>
    </profiles>
    </build>
</project>
现在,您可以在计算机上使用常规JDK运行:

mvn clean javafx:run
mvn clean client:build
并验证其工作正常

如果是这种情况,您现在也可以在您的计算机上使用GraalVM创建本机映像:

mvn clean javafx:run
mvn clean client:build
这是一个漫长的过程,通常需要16 GB RAM和几分钟的时间

成功完成后,您可以运行它:

mvn client:run
它应按预期工作:

最后,您可以尝试构建Android本机映像:

mvn -Pandroid client:build
完成后,创建apk:

mvn -Pandroid client:package
它将在
target/client/aarch64-android/gvm/apk/bin/hellogluon.apk
下创建一个apk

插入设备,以安装和运行:

mvn -Pandroid client:install client:run


注意:默认情况下,图标资产和AndroidManifest在
target/client/aarch64-android/gensrc/android
处生成。如果您想修改其中任何一个,您必须将此文件夹的内容复制到
src/android

您是否尝试过使用JavaFX11+的Glion客户端插件?请参见此处:。我已经测试了我的像素XL(密度3.5),没有“重影”问题。我不知道胶子客户端存在!gluonhq.com上的产品列表中没有显示它,这是一个奇怪的遗漏。我将试验并更新。@JoséPereda使用Glon客户端,动画不会受到重影的影响。非常感谢。如果你发布一个正式的答案,我会选择它。现在,我必须弄清楚如何定制android清单,并大体了解胶子基质。另外,在YouTube上看到您的一个JavaFX视频后,我开始研究Gluon很好,很高兴知道。我很快会发布答案。这里有很多非常详细的信息!非常感谢你。我正在“观看”github上的maven插件和底层项目。另外,继上个月他们在twitter上提到maven客户端插件的gluonhq之后。开发者还可以从哪里获得最新的进展细节?希望android的目标在夏天成熟是不是太过分了?