JavaFXPorts 应用程序代码不在 apk 中
JavaFXPorts application code is not in apk
我正在使用 Gluon 的 JavaFXPorts 在 android 上尝试我的第一个 JavaFX 应用程序。不幸的是,我无法构建包含应用程序代码的 apk。我自己的项目和示例都是如此,例如 Jose Pereda http://jperedadnr.blogspot.com/2015/03/javafx-on-mobile-dream-come-true.html 的 2048FX。
当我检查我生成的 apk 时,我找不到我在项目中创建的任何 classes。我确实找到了任何必需的 SDK classes 和应用程序资源文件。但是没有特定于应用程序的 *.class 文件。
我正在使用 gradle 的 'android' 任务创建 apk。
下面是我的两个 gradle 文件的示例。 Displays 是 TickerUI 的依赖项。
显示器 - build.gradle
group 'com.androidtest'
version '1.0'
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'me.tatarka:gradle-retrolambda:3.2.4'
}
}
apply plugin: 'idea'
apply plugin: 'java'
apply plugin: 'me.tatarka.retrolambda'
sourceCompatibility = 1.8
repositories {
mavenCentral()
}
dependencies {
testCompile 'org.testng:testng:6.9.9'
}
retrolambda {
jdk 'C:\Program Files\Java\jdk1.7.0_75\bin'
oldJdk 'C:\Program Files\Java\jdk1.8.0_65\bin'
defaultMethods true
incremental false
}
TickerUI - build.gradle
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'org.javafxports:jfxmobile-plugin:1.0.6'
}
}
apply plugin: 'org.javafxports.jfxmobile'
apply plugin: 'idea'
repositories {
jcenter()
}
mainClassName = 'com.androidtest.ticker.tickerui.Main'
dependencies {
compile files('../../Displays/Displays/build/libs/Displays-1.0.jar')
}
jfxmobile {
android {
androidSdk = 'C:\Program Files (x86)\Android\android-sdk'
compileSdkVersion = 23
manifest = 'src/android/AndroidManifest.xml'
}
}
备注
我正在家里迁移我的个人 Nexus,这就是我使用本地文件依赖项的原因。
Java 版本
这是我的 Java 版本。
Intellij: 1.8.0_65 x64
Gradle: 1.8.0_65 x64
SDK:1.8.0_65 x64。
Android SDK:24.4.1(x86?)
我尝试切换到 java 的 x86 版本,但收到 dex 错误。 "could not initialize vm, not enough space for object heap."。
如果有人有任何建议,我将不胜感激。提前谢谢你,
Jec
编辑 1
我在 ./gradlew.bat --info android 命令中没有看到任何错误。但是,当我在 phone 上安装我的 TickerUI 应用程序并附加调试器时,我收到以下错误:
12-18 08:33:33.237 18295-18295/com.androidtest.tickerui E/DalvikLauncher﹕ Launch failed with exception.
java.lang.ClassNotFoundException: Didn't find class "com.androidtest.tickerui.Main" on path: DexPathList[[zip file "/data/app/com.androidtest.tickerui-2/base.apk"],nativeLibraryDirectories=[/data/app/com.androidtest.tickerui-2/lib/arm, /vendor/lib, /system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
at javafxports.android.DalvikLauncher.resolveApplicationClass(DalvikLauncher.java:264)
at javafxports.android.DalvikLauncher.launchApp(DalvikLauncher.java:164)
at javafxports.android.FXDalvikEntity.getLauncherAndLaunchApplication(FXDalvikEntity.java:119)
at javafxports.android.FXDalvikEntity.surfaceCreated(FXDalvikEntity.java:145)
at android.view.SurfaceView.updateWindow(SurfaceView.java:607)
at android.view.SurfaceView.onPreDraw(SurfaceView.java:184)
at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:921)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2164)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1191)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6642)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:777)
at android.view.Choreographer.doCallbacks(Choreographer.java:590)
at android.view.Choreographer.doFrame(Choreographer.java:560)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:763)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:5951)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)
Suppressed: java.lang.ClassNotFoundException: com.androidtest.tickerui.Main
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
... 23 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available
我检查了我的 TickerUI.apk,我确实在包中看到了两个 .dex 文件。我不确定为什么 android 找不到我的 Main class.
编辑 2
我开始怀疑我的 android 清单是问题所在。如下:
<?xml version="1.0" encoding="UTF-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.androidtest.tickerui" android:versionCode="1" android:versionName="1.0">
<supports-screens android:xlargeScreens="true"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-sdk android:minSdkVersion="4" android:targetSdkVersion="23"/>
<application android:label="TickerUI" android:name="android.support.multidex.MultiDexApplication" android:icon="@mipmap/ic_launcher">
<activity android:name="javafxports.android.FXActivity" android:label="TickerUI" android:configChanges="orientation|screenSize">
<meta-data android:name="main.class" android:value="com.androidtest.tickerui.Main"/>
<meta-data android:name="debug.port" android:value="0"/>
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>
我在 android 清单中指定了错误的主要 class。感谢何塞的帮助。
我正在使用 Gluon 的 JavaFXPorts 在 android 上尝试我的第一个 JavaFX 应用程序。不幸的是,我无法构建包含应用程序代码的 apk。我自己的项目和示例都是如此,例如 Jose Pereda http://jperedadnr.blogspot.com/2015/03/javafx-on-mobile-dream-come-true.html 的 2048FX。
当我检查我生成的 apk 时,我找不到我在项目中创建的任何 classes。我确实找到了任何必需的 SDK classes 和应用程序资源文件。但是没有特定于应用程序的 *.class 文件。
我正在使用 gradle 的 'android' 任务创建 apk。
下面是我的两个 gradle 文件的示例。 Displays 是 TickerUI 的依赖项。
显示器 - build.gradle
group 'com.androidtest'
version '1.0'
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'me.tatarka:gradle-retrolambda:3.2.4'
}
}
apply plugin: 'idea'
apply plugin: 'java'
apply plugin: 'me.tatarka.retrolambda'
sourceCompatibility = 1.8
repositories {
mavenCentral()
}
dependencies {
testCompile 'org.testng:testng:6.9.9'
}
retrolambda {
jdk 'C:\Program Files\Java\jdk1.7.0_75\bin'
oldJdk 'C:\Program Files\Java\jdk1.8.0_65\bin'
defaultMethods true
incremental false
}
TickerUI - build.gradle
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'org.javafxports:jfxmobile-plugin:1.0.6'
}
}
apply plugin: 'org.javafxports.jfxmobile'
apply plugin: 'idea'
repositories {
jcenter()
}
mainClassName = 'com.androidtest.ticker.tickerui.Main'
dependencies {
compile files('../../Displays/Displays/build/libs/Displays-1.0.jar')
}
jfxmobile {
android {
androidSdk = 'C:\Program Files (x86)\Android\android-sdk'
compileSdkVersion = 23
manifest = 'src/android/AndroidManifest.xml'
}
}
备注 我正在家里迁移我的个人 Nexus,这就是我使用本地文件依赖项的原因。
Java 版本 这是我的 Java 版本。 Intellij: 1.8.0_65 x64 Gradle: 1.8.0_65 x64 SDK:1.8.0_65 x64。 Android SDK:24.4.1(x86?) 我尝试切换到 java 的 x86 版本,但收到 dex 错误。 "could not initialize vm, not enough space for object heap."。
如果有人有任何建议,我将不胜感激。提前谢谢你,
Jec
编辑 1 我在 ./gradlew.bat --info android 命令中没有看到任何错误。但是,当我在 phone 上安装我的 TickerUI 应用程序并附加调试器时,我收到以下错误:
12-18 08:33:33.237 18295-18295/com.androidtest.tickerui E/DalvikLauncher﹕ Launch failed with exception.
java.lang.ClassNotFoundException: Didn't find class "com.androidtest.tickerui.Main" on path: DexPathList[[zip file "/data/app/com.androidtest.tickerui-2/base.apk"],nativeLibraryDirectories=[/data/app/com.androidtest.tickerui-2/lib/arm, /vendor/lib, /system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
at javafxports.android.DalvikLauncher.resolveApplicationClass(DalvikLauncher.java:264)
at javafxports.android.DalvikLauncher.launchApp(DalvikLauncher.java:164)
at javafxports.android.FXDalvikEntity.getLauncherAndLaunchApplication(FXDalvikEntity.java:119)
at javafxports.android.FXDalvikEntity.surfaceCreated(FXDalvikEntity.java:145)
at android.view.SurfaceView.updateWindow(SurfaceView.java:607)
at android.view.SurfaceView.onPreDraw(SurfaceView.java:184)
at android.view.ViewTreeObserver.dispatchOnPreDraw(ViewTreeObserver.java:921)
at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:2164)
at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1191)
at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6642)
at android.view.Choreographer$CallbackRecord.run(Choreographer.java:777)
at android.view.Choreographer.doCallbacks(Choreographer.java:590)
at android.view.Choreographer.doFrame(Choreographer.java:560)
at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:763)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:145)
at android.app.ActivityThread.main(ActivityThread.java:5951)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)
Suppressed: java.lang.ClassNotFoundException: com.androidtest.tickerui.Main
at java.lang.Class.classForName(Native Method)
at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
... 23 more
Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available
我检查了我的 TickerUI.apk,我确实在包中看到了两个 .dex 文件。我不确定为什么 android 找不到我的 Main class.
编辑 2
我开始怀疑我的 android 清单是问题所在。如下:
<?xml version="1.0" encoding="UTF-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android" package="com.androidtest.tickerui" android:versionCode="1" android:versionName="1.0">
<supports-screens android:xlargeScreens="true"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE"/>
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
<uses-sdk android:minSdkVersion="4" android:targetSdkVersion="23"/>
<application android:label="TickerUI" android:name="android.support.multidex.MultiDexApplication" android:icon="@mipmap/ic_launcher">
<activity android:name="javafxports.android.FXActivity" android:label="TickerUI" android:configChanges="orientation|screenSize">
<meta-data android:name="main.class" android:value="com.androidtest.tickerui.Main"/>
<meta-data android:name="debug.port" android:value="0"/>
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>
我在 android 清单中指定了错误的主要 class。感谢何塞的帮助。