我想使用一些“ gluonhq魅力下降”服务,例如磁力计。
我不明白为什么不能将MagnetometerService导入我的Java类文件中。错误消息是
“无法解析导入com.gluonhq.charm.down.plugins.accelerometer”。
以前,在Eclipse Neon2-帮助-可用软件站点中,我已经安装了e(fx)clipse。您可以在安装详细信息中看到:
"e(fx)clipse - IDE - Update site" with http://download.eclipse.org/efxclipse/updates-released/2.4.0/site
注意:我已经安装了GluonTools 2.4.0,包括e(fx)mobile IDE 2.3.0。这是我的项目的build.gradle:
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'org.javafxports:jfxmobile-plugin:2.4.0'
}
}
plugins {
id "com.github.hierynomus.license" version "0.13.1"
}
apply plugin: 'org.javafxports.jfxmobile'
repositories {
jcenter()
maven {
url 'http://nexus.gluonhq.com/nexus/content/repositories/releases'
}
}
mainClassName = 'com.gluonapplication.GluonApplication'
jfxmobile {
downConfig {
version '4.0.0'
plugins 'accelerometer', 'compass', 'device', 'orientation', 'storage', 'vibration', 'display', 'lifecycle', 'statusbar', 'position'
}
android {
applicationPackage = 'com.gluonapplication'
manifest = 'src/android/AndroidManifest.xml'
androidSdk = 'C:/Users/pascal/AppData/Local/Android/sdk'
resDirectory = 'src/android/res'
compileSdkVersion = '23'
buildToolsVersion = '25.0.1'
}
ios {
infoPList = file('src/ios/Default-Info.plist')
}
}
最佳答案
这些是在安装了Gluon插件2.4.0的Eclipse上创建应用程序的步骤。
1.使用IDE插件
单击新建,选择Gluon-> Gluon Mobile-单视图项目,填写所需的数据(项目名称,程序包,...),然后单击完成。
2.查看build.gradle文件
打开构建文件,然后更新版本:current jfxmobile插件版本为1.3.2。 Gluon Charm为4.3.0,而Gluon Down plugins使用3.2.0。
3.添加您的Down插件
将磁力计插件添加到downConfig
。
这应该是您的build.gradle文件(主类名称除外):
buildscript {
repositories {
jcenter()
}
dependencies {
classpath 'org.javafxports:jfxmobile-plugin:1.3.2'
}
}
apply plugin: 'org.javafxports.jfxmobile'
repositories {
jcenter()
maven {
url 'http://nexus.gluonhq.com/nexus/content/repositories/releases'
}
}
mainClassName = 'com.gluonhq.magnetometer.TestMagnetometer'
dependencies {
compile 'com.gluonhq:charm:4.3.0'
}
jfxmobile {
downConfig {
version = '3.2.0'
plugins 'display', 'lifecycle', 'magnetometer', 'statusbar', 'storage'
}
android {
manifest = 'src/android/AndroidManifest.xml'
}
ios {
infoPList = file('src/ios/Default-Info.plist')
forceLinkClasses = [
'com.gluonhq.**.*',
'javax.annotations.**.*',
'javax.inject.**.*',
'javax.json.**.*',
'org.glassfish.json.**.*'
]
}
}
请注意,您不需要添加任何其他插件依赖性,
downConfig
会为您完成。4.将服务添加到基本视图
这是磁力计服务的简单用例:
package com.gluonhq.magnetometer;
import com.gluonhq.charm.down.Services;
import com.gluonhq.charm.down.plugins.MagnetometerService;
import com.gluonhq.charm.glisten.control.AppBar;
import com.gluonhq.charm.glisten.control.Icon;
import com.gluonhq.charm.glisten.mvc.View;
import com.gluonhq.charm.glisten.visual.MaterialDesignIcon;
import javafx.geometry.Pos;
import javafx.scene.control.Button;
import javafx.scene.control.Label;
import javafx.scene.layout.VBox;
public class BasicView extends View {
public BasicView(String name) {
super(name);
Label label1 = new Label();
Label label2 = new Label();
Button button = new Button("Start Magnetometer");
button.setGraphic(new Icon(MaterialDesignIcon.VIBRATION));
button.setOnAction(e ->
Services.get(MagnetometerService.class)
.ifPresent(s -> s.readingProperty()
.addListener((obs, ov, nv) -> {
label1.setText(String.format("X: %.4f Y: %.4f Z: %.4f\n Mag: %.4f", nv.getX(), nv.getY(), nv.getZ(), nv.getMagnitude()));
label2.setText(String.format("Yaw: %.2f\u00b0 Pitch: %.4f\u00b0 Roll: %.4f\u00b0", Math.toDegrees(nv.getYaw()),
Math.toDegrees(nv.getPitch()), Math.toDegrees(nv.getRoll())));
})));
VBox controls = new VBox(15.0, button, label1, label2);
controls.setAlignment(Pos.CENTER);
setCenter(controls);
}
@Override
protected void updateAppBar(AppBar appBar) {
appBar.setNavIcon(MaterialDesignIcon.MENU.button(e -> System.out.println("Menu")));
appBar.setTitleText("Magnetometer");
}
}
5.在桌面上测试
使用Gradle Task窗口,选择
application->run
请注意,该服务在桌面设备上不可用,并且无法使用,但是您将检查应用程序是否运行无误。
6.在Android上部署
在“使用Gradle任务”窗口中,选择
other->androidInstall
。在运行任务之前,请插入手机。如果一切正常,您应该可以在设备上测试该应用程序: