JavaFX使用自定义字体

本文介绍了一种通过注册字体的方法来解决JavaFX中使用自定义字体的问题,并提供了一个具体的实现案例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

利用注册字体的方式,解决JavaFX使用自定义字体的问题。

 

代码如下: 

function registerFont(url: String) {
    var fontURL = new File(url);
    var font = java.awt.Font.createFont(java.awt.Font.TRUETYPE_FONT, fontURL);
    var ge = GraphicsEnvironment.getLocalGraphicsEnvironment();
    var clazz = ge.getClass();
    var registerFont = clazz.getMethod("registerFont", font.getClass());
    var success = (registerFont.invoke(ge, font)) as Boolean;

    if(success) {
        text.font = Font { name: "创艺简行楷" size: 36 };
    } else {
        println("not success!");
    }
}

var text: Text = Text {
        translateX: bind (300 - text.layoutBounds.width) / 2.0
        content: "世界,你好!"
        font: Font{name:"微软雅黑" size: 22}
        }

var button : Button = Button {
    translateX: bind (300 - button.layoutBounds.width) / 2.0
    text: "Register Font"
    action: function() {
        registerFont("d:/cy23.TTF");
    }
}

var vBox = VBox {
    layoutY: 50
    spacing: 20
    content: [ text, button ]
}

Stage {
    title: "Custom Font"
    resizable: false
    scene: Scene {
        width: 300
        height: 150
        content: vBox
    }
}
 

 

结果显示:



 

 注意字体的名称一定要和字体文件中的名称匹配。

 

Font { name: "创艺简行楷" size: 36 };

 

Font{name:"微软雅黑" size: 22};
 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值