在 android 中使用 jfoenix

using jfoenix in android

JFoenix 在桌面应用程序上运行良好。但是当在 android 上实现它时,它被击中(应用程序停止工作并退出提示对话框,不幸的是应用程序停止使用报告按钮)。

So how to Implement JFoenix in android ?


下面是build.gradle

buildscript {
repositories {
    jcenter()
}
dependencies {
    classpath 'org.javafxports:jfxmobile-plugin:1.2.0'
}
 }
apply plugin :'org.javafxports.jfxmobile'
repositories {
jcenter()
maven {
    url 'http://nexus.gluonhq.com/nexus/content/repositories/releases'
}
   }

    mainClassName = 'com.sample.Main'

    dependencies {
compile 'com.gluonhq:charm:4.2.0'
compile 'com.jfoenix:jfoenix:1.0.0'
       //compile files('lib/jfoenix-0.0.0-SNAPSHOT-retrolambda.jar')
    }

    jfxmobile {
downConfig {
    version = '3.1.0'
    // Do not edit the line below. Use Gluon Mobile Settings in your project context menu instead
    plugins 'display', 'lifecycle', '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.**.*'
    ]
}

}

这里是使用 JFoenix
构建的 fxml 文件(如您所见,我已经包含了 JFXDatePicker)

<?xml version="1.0" encoding="UTF-8"?>

   <?language javascript?>
   <?import com.jfoenix.controls.JFXDatePicker?>
   <?import javafx.scene.control.Button?>
   <?import javafx.scene.control.Label?>
   <?import javafx.scene.control.ToggleButton?>
   <?import javafx.scene.control.ToggleGroup?>
   <?import javafx.scene.image.Image?>
   <?import javafx.scene.image.ImageView?>
   <?import javafx.scene.layout.AnchorPane?>

   <AnchorPane maxHeight="-Infinity" maxWidth="-Infinity" minHeight="-Infinity" minWidth="-Infinity" prefHeight="620.0" prefWidth="360.0" style="-fx-background-color: linear-gradient(#c3361d,fuchsia);" stylesheets="@Next.css" xmlns="http://javafx.com/javafx/8.0.111" xmlns:fx="http://javafx.com/fxml/1" fx:controller="com.android.scheduler.Next">

     <children>
     <Label text="Now ,You can Schedule Wifi" AnchorPane.leftAnchor="70.0" />
     <ToggleButton fx:id="ON" layoutX="152.0" layoutY="68.0" mnemonicParsing="false" onAction="#ON" text="On">
  <toggleGroup>
        <ToggleGroup fx:id="select" />
     </toggleGroup>
  </ToggleButton>
  <ToggleButton fx:id="OFF" layoutX="195.0" layoutY="68.0" mnemonicParsing="false" onAction="#OFF" text="Off" toggleGroup="$select" />
  <Label layoutX="49.0" layoutY="66.0" text="Action:" />      <Label fx:id="scheduled" layoutX="76.0" layoutY="107.0" text="Choose between Any one" />
  <Label layoutX="5.0" layoutY="202.0" text="Start Time:" />
  <Label layoutX="6.0" layoutY="283.0" text="End Time :" />
  <Button defaultButton="true" layoutX="129.0" layoutY="354.0" mnemonicParsing="false" text="Schedule" textAlignment="CENTER">
      <graphic>
          <ImageView>
              <image>
                  <Image url="@reminders-24.png" />
              </image>
          </ImageView>
      </graphic>
  </Button>
  <Button layoutX="113.0" layoutY="436.0" mnemonicParsing="false" onAction="#gotoHome" text="Back to Home">
  <graphic>
      <ImageView>
         <image>
             <Image url="@home-24.png" />
         </image>
      </ImageView>
  </graphic>
  </Button>
  <Label layoutX="195.0" layoutY="247.0" text="to" />
  <Label layoutX="110.0" layoutY="155.0" text="Hours" />
  <Label layoutX="184.0" layoutY="155.0" text="Minutes" />
  <JFXDatePicker fx:id="start" defaultColor="#b2dbee" layoutX="139.0" layoutY="210.0" showTime="true" />
  <JFXDatePicker fx:id="end" defaultColor="#b2dbee" layoutX="139.0" layoutY="287.0" showTime="true" />
   </children>

   </AnchorPane>

如果检查异常(运行 adb logcat -v threadtime):

02-26 19:10:40.811 27570 27595 E AndroidRuntime: java.lang.NoSuchMethodError: No direct method lambda$new3(Ljavafx/beans/value/ObservableValue;Ljavafx/scene/paint/Paint;Ljavafx/scene/paint/Paint;)V in class Lcom/jfoenix/svg/SVGGlyph; or its super classes (declaration of 'com.jfoenix.svg.SVGGlyph' appears in /data/app/com.gluon.testjfoenix-1/base.apk)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at com.jfoenix.svg.SVGGlyph.access$lambda[=10=](SVGGlyph.java)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at com.jfoenix.svg.SVGGlyph$$Lambda.changed(Unknown Source)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at com.sun.javafx.binding.ExpressionHelper$SingleChange.fireValueChangedEvent(ExpressionHelper.java:181)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at com.sun.javafx.binding.ExpressionHelper.fireValueChangedEvent(ExpressionHelper.java:80)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at javafx.beans.property.ObjectPropertyBase.fireValueChangedEvent(ObjectPropertyBase.java:105)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at javafx.beans.property.ObjectPropertyBase.markInvalid(ObjectPropertyBase.java:112)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at javafx.beans.property.ObjectPropertyBase.set(ObjectPropertyBase.java:146)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at javafx.beans.property.ObjectProperty.setValue(ObjectProperty.java:69)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at com.jfoenix.svg.SVGGlyph.setFill(SVGGlyph.java:87)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at com.jfoenix.svg.SVGGlyph.<init>(SVGGlyph.java:65)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at com.jfoenix.skins.JFXDatePickerSkin.<init>(JFXDatePickerSkin.java:77)
02-26 19:10:40.811 27570 27595 E AndroidRuntime:    at com.jfoenix.controls.JFXDatePicker.createDefaultSkin(JFXDatePicker.java:85)

错误是指 com.jfoenix.svg.SVGGlyph 中缺少的方法。

看一下source代码,你会发现有一个lambda表达式。

在 jfxmobile 插件版本 1.1.0 之前,所有作为依赖项添加到 javafxports 项目的外部 jar 都需要使用 retrolambda 插件,所以这可能就是为什么 jfoenix 项目添加了 retrolambda.

在该版本之后,jfxmobile 插件也将 retrolambda 应用于所有外部依赖项,因此它们不再需要 retrolambda 插件。

但是,如果 依赖项和 jfxmobile 插件都应用了 retrolambda 插件,则会出现问题,这正是此处发生的情况:应用两次 retrolambda 插件失败。

有两种可能的解决方案:

  1. 不使用retrolambda编译jfoenix,并将其添加到项目中(并为此创建一个问题,因此作者也将其删除)

  2. 使用compileNoRetrolambda 'com.jfoenix:jfoenix:1.0.0'作为依赖。这将使用原始依赖项,它已经应用了一次 retrolambda。

我已经尝试了第二种解决方案,效果非常好。

顺便说一句,Gluon Mobile(您构建中的 charm 依赖项)还包括遵循 Material 设计的 DatePicker 和 TimePicker。