不能使用fontawesomefx与kotlin和tornadofx

时间:2017-02-22 02:57:28

标签: kotlin 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抽象类:

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

我不知道如何扭转此错误。如果我宣布:

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

我没有得到上述错误,但我想念'.size'属性。我如何声明我的类'ButtonInfo'以便这段代码有效?

1 个答案:

答案 0 :(得分:5)

您没有发布完整的课程,但看起来您尝试在任何方法或init块之外运行list.forEach指令? Kotlin对size访问者感到困惑,使用setSize()来避免这个问题。

这是一个完整的类,对编译和运行的示例进行最少的更改,并向您显示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访问者。