不能将 fontawesomefx 与 kotlin 和 tornadofx 一起使用

Can't use fontawesomefx with kotlin and tornadofx

我正在尝试使用 TornadoFX 创建一些带有 FontAwesomeFX 图标的 JavaFX 按钮。这是代码

    data class ButtonInfo(val texto: String, val icon: GlyphIcon<*>)

    val list = listOf(
        ButtonInfo("Cadastro", FontAwesomeIconView(FontAwesomeIcon.ADDRESS_BOOK)),
        ButtonInfo("Corrida", MaterialDesignIconView(MaterialDesignIcon.RUN)),
        ButtonInfo("Classificacao", FontAwesomeIconView(FontAwesomeIcon.LIST)))

    list.forEach {
        it.icon.size = "3em"
        val bt = Button(it.texto, it.icon)
        bt.contentDisplay = ContentDisplay.TOP
        bt.minWidth = 200.0
        root += bt
    }

在编译中我得到这个错误:

Type parameter bound for T in var <T : Enum<T!>!> GlyphIcon<T>.size: String! where T : GlyphIcons!

不满足:推断类型 CapturedTypeConstructor(*) 不是 GlyphIcons 的子类型!

GlyphIcon 是一个 Java 抽象 class,声明如下:

public abstract class GlyphIcon<T extends Enum<T> & GlyphIcons> extends Text

我不知道如何解决这个错误。如果我声明:

data class ButtonInfo(val texto: String, val icon: Text)

我没有收到上述错误,但我错过了“.size”属性。我如何声明我的 class 'ButtonInfo' 以便此代码有效?

您没有 post 完整的 class,但您似乎尝试 运行 在任何方法或 init 块之外的 list.forEach 指令? Kotlin 被 size 访问器弄糊涂了,使用 setSize() 来避免这个问题。

这是一个完整的 class,对编译和 运行 的示例进行了最小的更改,并在 vbox 中向您显示了图标。

data class ButtonInfo(val texto: String, val icon: GlyphIcon<*>)

class IconView : View() {
    val list = listOf(
            ButtonInfo("Cadastro", FontAwesomeIconView(FontAwesomeIcon.ADDRESS_BOOK)),
            ButtonInfo("Corrida", MaterialDesignIconView(MaterialDesignIcon.RUN)),
            ButtonInfo("Classificacao", FontAwesomeIconView(FontAwesomeIcon.LIST)))

    override val root = vbox {
        list.forEach {
            it.icon.setSize("3em")
            button(it.texto, it.icon) {
                contentDisplay = ContentDisplay.TOP
                minWidth = 200.0
            }
        }
    }
}

我使用了 button 构建器而不是手动添加到根节点。

让我提供一个替代方案:

class IconView : View() {
    override val root = vbox {
        button("Cadastro").icon(FontAwesomeIcon.ADDRESS_BOOK)
        button("Corrida").icon(MaterialDesignIcon.RUN)
        button("Classificacao").icon(FontAwesomeIcon.LIST)
    }
}

然后您在实用程序文件中定义此函数:

fun Button.icon(icon: GlyphIcons, minButtonWidth: Double = 200.0) {
    graphic = when (icon) {
        is FontAwesomeIcon -> FontAwesomeIconView(icon)
        is MaterialDesignIcon -> MaterialDesignIconView(icon)
        else -> throw IllegalArgumentException("Unknown font family ${icon.fontFamily}")
    }
    with(graphic as GlyphIcon<*>) {
        contentDisplay = ContentDisplay.TOP
        setSize("3em")
    }
    minWidth = minButtonWidth
}

这样可以更轻松地查看呼叫站点的情况。

此外,setSize("3em") 仅用于支持 Scene Builder。考虑改用 glyphSize 访问器。