JavaFX TableView:为复选框单元格实现模型驱动的提示信息

javafx tableview:为复选框单元格实现模型驱动的提示信息

本教程详细介绍了如何在JavaFX TableView中为包含 CheckBoxTableCell 的行添加动态提示(Tooltip)。通过利用 TableView 的 setRowFactory 方法,我们可以自定义 TableRow 的行为,使其能够根据模型(Model)中的特定属性(如“reason”)来动态绑定并显示提示信息,从而增强用户交互体验,并确保提示内容与数据同步更新。

在JavaFX应用程序中,TableView 是展示数据的重要组件。当 TableView 的某个单元格,特别是交互式单元格如 CheckBoxTableCell,需要根据其关联的数据模型显示额外信息时,使用提示(Tooltip)是一个常见的需求。本文将指导您如何为 TableView 中的 CheckBoxTableCell 所在行动态添加基于模型属性的提示信息。

1. 理解需求与挑战

我们的目标是:当用户鼠标悬停在 TableView 中包含 CheckBoxTableCell 的某一行时,显示一个提示框,其内容来源于该行数据模型中的一个特定属性(例如,一个名为 reason 的 String 属性)。

直接在 CheckBoxTableCell 的 setCellFactory 中添加提示通常不够灵活,因为它只作用于单个单元格。而我们的需求是基于整行的数据模型来显示提示,这意味着我们需要在行级别进行控制。

2. 核心解决方案:使用 TableRow 工厂

JavaFX TableView 提供了 setRowFactory 方法,允许开发者自定义 TableRow 的创建方式。这是实现行级别动态提示的关键。通过重写自定义 TableRow 的 updateItem 方法,我们可以根据当前行所关联的数据模型来设置或更新提示。

立即学习“Java免费学习笔记(深入)”;

2.1 定义数据模型

首先,我们需要一个数据模型,其中包含用于 CheckBoxTableCell 的布尔属性和用于提示的字符串属性。

import javafx.beans.property.SimpleBooleanProperty;import javafx.beans.property.SimpleStringProperty;public class Model {    private final SimpleBooleanProperty flag;    private final SimpleStringProperty reason;    public Model(boolean flag, String reason) {        this.flag = new SimpleBooleanProperty(flag);        this.reason = new SimpleStringProperty(reason);    }    // flag 属性的 getter 和 property 方法    public SimpleBooleanProperty flagProperty() {        return flag;    }    public boolean isFlag() {        return flag.get();    }    public void setFlag(boolean flag) {        this.flag.set(flag);    }    // reason 属性的 getter 和 property 方法    public SimpleStringProperty reasonProperty() {        return reason;    }    public String getReason() {        return reason.get();    }    public void setReason(String reason) {        this.reason.set(reason);    }}

2.2 构建 TableView 和 TableColumn

接下来,设置基本的 TableView 结构,包括 CheckBoxTableCell 所在的列和其他可能需要的列。

import javafx.application.Application;import javafx.scene.Scene;import javafx.scene.control.TableColumn;import javafx.scene.control.TableView;import javafx.scene.control.cell.CheckBoxTableCell;import javafx.stage.Stage;public class TableViewTooltipDemo extends Application {    public static void main(String[] args) {        launch(args);    }    @Override    public void start(Stage primaryStage) {        TableView table = new TableView();        // 示例数据        table.getItems().add(new Model(true, "此项已启用,这是详细原因。"));        table.getItems().add(new Model(false, "此项已禁用,需要进一步检查。"));        table.getItems().add(new Model(true, "另一个重要的项目,具有较长的提示文本,用于演示。"));        table.getItems().add(new Model(false, "")); // 没有提示文本的项目        table.getItems().add(new Model(true, null)); // 提示文本为null的项目        // 设置复选框列        TableColumn checkboxColumn = new TableColumn("状态");        checkboxColumn.setCellFactory(CheckBoxTableCell.forTableColumn(checkboxColumn));        checkboxColumn.setCellValueFactory(features -> features.getValue().flagProperty());        checkboxColumn.setPrefWidth(80);        // 设置原因列(可选,用于显示reason数据本身)        TableColumn reasonColumn = new TableColumn("原因描述");        reasonColumn.setCellValueFactory(features -> features.getValue().reasonProperty());        reasonColumn.setPrefWidth(200);        table.getColumns().addAll(checkboxColumn, reasonColumn);        // ... (此处将添加行工厂代码)        Scene scene = new Scene(table, 480, 300);        primaryStage.setScene(scene);        primaryStage.setTitle("JavaFX TableView 动态提示示例");        primaryStage.show();    }    // Model 类定义如上所示    // ...}

2.3 实现 TableRow 工厂以添加动态提示

现在,我们将实现 table.setRowFactory() 方法。在这个工厂中,我们将创建一个自定义的 TableRow 子类,并重写其 updateItem 方法。

import javafx.scene.control.TableRow;import javafx.scene.control.Tooltip;// ... 其他导入// 在 start 方法中,table.getColumns().addAll(checkboxColumn, reasonColumn); 之后添加:table.setRowFactory(tv -> new TableRow() {    private final Tooltip rowTooltip = new Tooltip(); // 每个TableRow实例一个Tooltip    @Override    protected void updateItem(Model item, boolean empty) {        super.updateItem(item, empty); // 必须调用父类方法        if (empty || item == null || item.getReason() == null || item.getReason().isEmpty()) {            // 如果行是空的、item为null、或reason属性为空/null,则移除提示            rowTooltip.textProperty().unbind(); // 解绑旧的属性,避免内存泄漏和错误更新            setTooltip(null); // 移除当前行的Tooltip        } else {            // 将Tooltip的文本属性绑定到Model的reasonProperty()            // 这样当Model的reason值改变时,Tooltip会自动更新            rowTooltip.textProperty().bind(item.reasonProperty());            setTooltip(rowTooltip); // 为当前行设置Tooltip        }    }});

代码解析:

table.setRowFactory(tv -> new TableRow() { … });:这定义了一个匿名内部类,用于创建自定义的 TableRow 实例。private final Tooltip rowTooltip = new Tooltip();:为每个 TableRow 实例创建一个 Tooltip 对象。由于 TableRow 会被虚拟化重用,所以每个实例拥有自己的 Tooltip 是高效且正确的做法。@Override protected void updateItem(Model item, boolean empty):这是核心方法。当 TableRow 被用于显示新的 Model 实例或其状态(如空/非空)发生变化时,此方法会被调用。super.updateItem(item, empty);:始终调用父类的 updateItem 方法以确保 TableRow 的基本功能正常。if (empty || item == null || item.getReason() == null || item.getReason().isEmpty()):这是一个条件判断,用于处理三种情况:empty:当前行是空的(例如,表格底部未填充数据的行)。item == null:没有关联的数据模型。item.getReason() == null || item.getReason().isEmpty():数据模型存在,但其 reason 属性为 null 或空字符串。在这些情况下,我们希望不显示提示,因此调用 rowTooltip.textProperty().unbind() 解除任何之前的绑定,然后 setTooltip(null) 移除提示。else { … }:当行包含有效数据且 reason 属性非空时:rowTooltip.textProperty().bind(item.reasonProperty());:这是关键一步。它将 Tooltip 的 textProperty 与当前 Model 实例的 reasonProperty 进行双向绑定。这意味着,如果 Model 中的 reason 值发生变化,Tooltip 的显示内容将自动更新,无需手动干预。setTooltip(rowTooltip);:将配置好的 Tooltip 对象设置给当前的 TableRow。

3. 完整示例代码

将上述所有部分组合起来,形成一个完整的可运行的JavaFX应用程序:

import javafx.application.Application;import javafx.beans.property.SimpleBooleanProperty;import javafx.beans.property.SimpleStringProperty;import javafx.scene.Scene;import javafx.scene.control.TableColumn;import javafx.scene.control.TableRow;import javafx.scene.control.TableView;import javafx.scene.control.Tooltip;import javafx.scene.control.cell.CheckBoxTableCell;import javafx.stage.Stage;public class TableViewTooltipDemo extends Application {    public static void main(String[] args) {        launch(args);    }    @Override    public void start(Stage primaryStage) {        TableView table = new TableView();        // 示例数据        table.getItems().add(new Model(true, "此项已启用,这是详细原因。"));        table.getItems().add(new Model(false, "此项已禁用,需要进一步检查。"));        table.getItems().add(new Model(true, "另一个重要的项目,具有较长的提示文本,用于演示。"));        table.getItems().add(new Model(false, "")); // 没有提示文本的项目        table.getItems().add(new Model(true, null)); // 提示文本为null的项目        table.getItems().add(new Model(false, "这是一个动态更新的示例。")); // 准备用于动态更新        // 设置复选框列        TableColumn checkboxColumn = new TableColumn("状态");        checkboxColumn.setCellFactory(CheckBoxTableCell.forTableColumn(checkboxColumn));        checkboxColumn.setCellValueFactory(features -> features.getValue().flagProperty());        checkboxColumn.setPrefWidth(80);        // 设置原因列(可选,用于显示reason数据本身)        TableColumn reasonColumn = new TableColumn("原因描述");        reasonColumn.setCellValueFactory(features -> features.getValue().reasonProperty());        reasonColumn.setPrefWidth(200);        table.getColumns().addAll(checkboxColumn, reasonColumn);        // 实现TableRow工厂以添加动态提示        table.setRowFactory(tv -> new TableRow() {            private final Tooltip rowTooltip = new Tooltip(); // 每个TableRow实例一个Tooltip            @Override            protected void updateItem(Model item, boolean empty) {                super.updateItem(item, empty); // 必须调用父类方法                if (empty || item == null || item.getReason() == null || item.getReason().isEmpty()) {                    // 如果行是空的、item为null、或reason属性为空/null,则移除提示                    rowTooltip.textProperty().unbind(); // 解绑旧的属性,避免内存泄漏和错误更新                    setTooltip(null); // 移除当前行的Tooltip                } else {                    // 将Tooltip的文本属性绑定到Model的reasonProperty()                    // 这样当Model的reason值改变时,Tooltip会自动更新                    rowTooltip.textProperty().bind(item.reasonProperty());                    setTooltip(rowTooltip); // 为当前行设置Tooltip                }            }        });        Scene scene = new Scene(table, 480, 300);        primaryStage.setScene(scene);        primaryStage.setTitle("JavaFX TableView 动态提示示例");        primaryStage.show();        // 演示动态更新:10秒后更新第一个项目的reason        new Thread(() -> {            try {                Thread.sleep(10000);            } catch (InterruptedException e) {                e.printStackTrace();            }            javafx.application.Platform.runLater(() -> {                if (!table.getItems().isEmpty()) {                    Model firstItem = table.getItems().get(0);                    firstItem.setReason("第一个项目的原因已在运行时

以上就是JavaFX TableView:为复选框单元格实现模型驱动的提示信息的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/33912.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 13:12:07
下一篇 2025年11月4日 13:12:50

相关推荐

  • Shiba Inu vs. Ruvi AI:哪个模因硬币将统治下一个公牛?

    加密货币市场正蓄势待发,准备迎接下一轮牛市的到来,投资者已开始加大对潜在赢家的关注力度。 加密货币市场正逐步从沉寂中苏醒,为即将到来的牛市做准备,投资者已开始增加潜在的代币持有量以提升其资产组合。在这个过程中,有两个脱颖而出的名字:Shiba Inu,作为模因币领域的明星项目,以及Ruvi AI,一…

    2025年12月8日
    000
  • ALR矿工:具有全球范围的尖端比特币采矿平台

    发现alr矿工平台的优势,包括尖端设备,法律合规性,直观界面和多个加密货币支持。 ALR Miner平台为用户提供了几种优势,这是加密货币采矿的一种吸引人的选择。这是关键好处的细分: 1。**高效采矿的尖端设备:** – 该平台利用Bitmain,Antminer和Giant Energ…

    2025年12月8日
    000
  • Solaxy(Solx)是Solana上的第一层项目,筹集了超过4300万美元的代币预售

    solaxy(solx)作为solana上的第二层项目,正接近其大规模代币预售的尾声,目前已筹集超过4,330万美元的资金。 加密行业的专家们长期就Solana(Sol)是否能超越以太坊(ETH)成为全球顶级区块链展开激烈讨论。 从马耳他的明媚海岸到硅谷充满活力的科技中心,区块链技术的潜力引发了加密…

    2025年12月8日
    000
  • 如预测的那样

    由Till Sawala和Helsinki大学。 2020年4月1日在PDT上午1:13更新。 计算机模拟周一透露,这种银河系可能与另一个巨大的星系造成灾难性的碰撞,但面临50-50的机会在一次粉碎中被摧毁的机会。 这是一个模态窗口。对话框窗口的开始。逃生将取消并关闭窗口。 这是一个模态窗口。可以通…

    2025年12月8日
    000
  • 毕竟,银河系可能不会被仙女座摧毁,模拟表明

    如预测的那样,银河系与另一个巨大的星系可能没有灾难性的碰撞。 如预测的那样,银河系与另一个巨大的星系可能没有灾难性的碰撞。 但是请不要担心:在我们的衰老阳光之后很长时间以来,预计不会出现银河系的粉碎。 银河系和均匀的银河系仙女座每秒以100公里(60英里)的速度相互驶向彼此,科学家长期以来预测他们将…

    2025年12月8日
    000
  • 链链接(链接)市场前景正在转向看涨,因为它朝着可能的突破偏离

    chainlink(link)正呈现出潜在突破的早期征兆,技术指标显示看涨动力正在增强。 ChainLink(链接)的价格展现出可能突破的迹象,因技术指标表明看涨动能正在提升。经过一段时间的盘整后,链接已形成对称三角形形态,若其能突破上行趋势线,这可能会引发剧烈的价格变动。 目前,部分分析师认为,一…

    2025年12月8日
    000
  • BlockDag:$ 0.0018入场和真正的技术力量

    在如今变幻莫测的市场环境中,仅有少数几个加密项目成功吸引了人们的注意。这些项目并不总是在你的预料之中。 在瞬息万变的市场里,仅有一些加密项目实现了真正的转型。一些熟悉的名称,如Filecoin、VeChain和Stellar,依旧活跃在人们的视野中,然而一个更为低调的项目正悄然崛起:Blockdag…

    2025年12月8日
    000
  • Ruvi AI成为Avalanche主导地位的竞争者,将区块链与人工智能融合在一起

    区块链技术领域正在飞速发展,众多项目争相重新定义去中心化系统的可能性。 在快速变化的区块链世界里,各类项目层出不穷,每个项目都致力于重新构想去中心化系统的潜能。尽管Avalanche凭借其闪电般的交易速度与可靠的可扩展性备受关注,但一位新兴的竞争者Ruvi AI也迅速吸引了市场的目光。 Ruvi A…

    2025年12月8日
    000
  • JetBolt(JBolt),Chainlink(链接)和仲裁(ARB)是加密专家现在购买的首选

    所有人的注意力都转向了即将到来的季节,部分分析人士指出,若以太坊能够保持当前势头,而比特币突破55%的水平。 所有人的目光聚焦于下一季,一些分析人士认为,如果以太坊维持领先地位,并且比特币达到超出55%的高度。 在主要的Altcoin行情爆发前,投资者正积极寻找最具潜力的加密货币,其中一些已在Alt…

    2025年12月8日
    000
  • Solana的逐渐崛起表现出稳定性

    solana每月收益达到6.5%,表明市场中成熟加密货币的可靠性。 索拉纳(Solana)在过去的一个月中实现了稳定的6.5%增长,彰显了其在投资者群体中的持久吸引力,尤其是在其在加密货币领域的成熟地位背景下。这种稳定性体现了已确立的加密货币持续的力量,得益于其强大的生态系统及高水平的投资者信任。 …

    2025年12月8日
    000
  • 比特币(BTC)价格再次处于最前沿

    随着加密货币市场的浪潮席卷而来,比特币的价格再次成为众人瞩目的焦点,但显然它并非独行侠。另一种极具潜力的替代币正迅速吸引市场的目光。 随着加密货币市场的浪潮席卷而来,比特币的价格再次成为众人瞩目的焦点,但显然它并非独行侠。另一种极具潜力的替代币正迅速吸引市场的目光。根据最新的BTC图表分析,比特币的…

    2025年12月8日
    000
  • PM Modi在Shilpa River沿岸的Indore Metro,Datia和Satna机场开设

    在传奇女王阿海·霍尔卡(ahilyabhai holkar)诞辰300周年之际,莫迪总理发表了讲话。 总理纳伦德拉·莫迪访问了中央邦,为多个项目奠基、启用并奉献。 **开发项目启动仪式** *在阿海女王诞辰300周年之际,莫迪总理在博帕尔詹博里梅丹的妇女赋权大会(Mahila Sashaktikar…

    2025年12月8日
    000
  • Fiobit- AI驱动的云采矿平台彻底改变了移动采矿

    加密货币云挖矿和比特币挖矿正逐渐成为一种流行的赚钱方式,尤其对于那些不想投资昂贵硬件的人来说。据coinbase的专业人士称,云挖矿让用户能够租赁远程数据中心的算力,这样即使是在智能手机上也能进行挖矿操作。这意味着你无需购买或维护任何挖矿设备。 接下来,我们将深入探讨比特币云挖矿的工作原理,并在20…

    2025年12月8日
    000
  • 您是否密切关注加密货币市场,想知道今年6月将您的钱放在哪里?

    随着比特币在市场中的主导地位稳固,vechain正在推动供应链追踪的发展,eos则致力于为去中心化应用提供动力,而arweave正在突破永久数据存储的极限。 你是否一直在密切注视着加密货币市场,并思考六月份资金应如何配置?当比特币维持其领先地位时,诸如Vechain和EOS这样的项目因其在供应链追踪…

    2025年12月8日
    000
  • Shiba Inu(Shib)价格前景亮起,Monero(XMR)价格跳高,但$ WAI可能是真正的突破性游戏

    由于即将来临的shibarium升级和象征性的销毁,shiba inu(shib)依然是一个值得期待的模因类项目。不过,shiba inu(shib)的价格依旧面临较大的阻力。 Shibarium升级的临近以及代币销毁行动,让Shiba Inu(Shib)的价格依然吸引眼球,尽管它在重要支撑位上遭遇…

    2025年12月8日
    000
  • XRP价格预测延长了,雷米(Remi Relife)预测到6月的3000%飙升至75美元

    加密分析师remi relife发表大胆夏季预测后,xrp的价格预期发生了显著调整。他表示xrp可能攀升至75美元。 Remi Relife针对XRP的价格做出了激进的夏季预测,预计到6月或7月将达到75美元的目标价位,这意味着较当前水平增长超过3,000%,引起了市场的广泛热议。 随着XRP长期路…

    2025年12月8日
    000
  • 2025年的十大云采矿服务提供商

    随着2025年加密货币市场的蓬勃发展,云挖矿逐渐成为投资者获取每日被动收入的热门方式。 在快速发展的2025年加密货币市场中,云挖矿已经成为寻求从比特币(BTC)和狗狗币(Doge)获得每日被动收入的投资者的首选方法。 与传统的挖矿方式不同,后者需要购置昂贵的挖矿设备并承担高额电费,云挖矿让用户通过…

    2025年12月8日
    000
  • Qubetics($ TICS):Web3聚合器更改规则

    您正注视着下一场大型altcoin浪潮吗?想知道什么会引发2025年的web3革命?准备好迎接未来——因为下一代加密货币不仅在颠覆,还在重新定义规则。 您正注视着下一场大型Altcoin浪潮吗?想知道什么会引发2025年的Web3革命?准备好迎接未来——因为下一代加密货币不仅在颠覆,因此。 数字金融…

    2025年12月8日
    000
  • Shiba Inu(Shib)价格上涨,Dogecoin(Doge)模式集会,以及为什么$ WAI可能会将它们都留在后面

    Shiba Inu(Shib)目标定在0.01,狗狗币(Doge)呼应了2021年的高点,而Web3 AI的$ WAI则提供了真正的AI交易工具,该代币是否具备最大的上涨潜力? Shiba Inu(Shib)的价格潜力再次吸引了交易者的目光,这得益于Shibarium的持续采用、代币销毁计划的推进以…

    2025年12月8日
    000
  • 六月购买的顶级加密货币? Blockdag的$ 0.0018价格和记录预售是超过Doge,Pepe和Shib

    随着加密市场在2025年重新卷土重来,寻找下一个突破的altcoin正在加热。用户专注于项目 加密货币市场在2025年进行了强烈的复出,随着对下一个突破的Altcoin升温的搜索,用户专注于具有真正的可扩展性,强大效用和可见牵引力的项目。 尽管模因硬币,例如Dogecoin,Shiba Inu和Pe…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信