gpt4 book ai didi

java - 当相关文件更改时动态刷新 JTextPane

转载 作者:行者123 更新时间:2023-11-30 09:46:24 24 4
gpt4 key购买 nike

我正在工作的当前项目使用 log4j 库创建一个日志文件,并且还必须具有“showLog”功能,该功能创建一个可以查看日志的框架。此外,当日志文件被修改(附加新的日志消息)时,这个框架必须刷新。

好吧,除了刷新 Action 我都做了,这就是问题,我怎样才能做动态刷新?

这里是我的代码片段,我只放了相关的行:

  • 接口(interface)操作:运行事件操作

    public interface Action {
    public void executer();
    }

  • CadreTexte 类:创建和管理显示日志文件的框架

    public class CadreTexte extends JFrame {
    private JTextPane log;
    public CadreTexte(String titre, File texte) {
    super(titre);
    if (texte.exists() && texte.canRead()) {
    this.texte = texte;
    }
    else {
    throw new ExceptionGenerateurs("NE_FILE"); //Own exception
    }
    initializeFrame();<br/>
    log= new JTextPane();
    log.setEditable(false);
    java.net.URL urlFichier = null;
    try {
    urlFichier = texte.toURI().toURL();
    } catch (MalformedURLException e1) {
    throw new ExceptionGenerateurs("Fichier de texte non montrable");
    }
    try {
    log.setPage(urlFichier);
    }
    catch (IOException e) {
    System.out.println(e.getLocalizedMessage()); //CATCH
    } finally {
    urlFichier = null;
    }
    JScrollPane docSP = setScrollPane(); // bars as needed, contains JTextPane
    getContentPane().setLayout(new BorderLayout());
    getContentPane().add(docSP,BorderLayout.CENTER);
    }
    }

  • Vue 类:主框架。它有一个存储在 HashMap 中的 Action 对象列表。这些操作可通过菜单访问。由于这个类很大,我只放了最重要的几行:

    1. ActionPerformed 函数:

      public void actionPerformed(ActionEvent e) {
      JComponent composant;
      Action handler;
      composant = (JComponent) e.getSource();
      String idEvenement = composant.getName();
      modele.log(Modele.LOG_DEBUG, String.format("Événement. ID: %s",idEvenement));
      handler = ACTIONS_MAP.get(idEvenement);
      if (handler == null) {
      modele.log(Modele.LOG_ERROR, "Action non identifiée");
      } else {
      handler.executer();
      modele.log(Modele.LOG_DEBUG, "Fin action");
      }
      }

    2. Action 可视化日志:

      Action visualiserLog = new Action() {
      public void executer() {
      if (cadreLog == null) {
      cadreLog = new CadreTexte("Fichier du log", model.getLogFile());
      visuLog = true;
      }
      else {
      visuLog = !visuLog;
      }
      cadreLog.visualiser(visuLog);
      }
      };

最后,激活 visualiserLog Action 的 MenuItem 是 JCheckBoxMenuItem

我希望你能在理解这个大问题后帮助我。如果有人需要更多信息,请提出要求!

问候!

注意:如果有人可以编辑问题并给出正确的格式,我将不胜感激,我一直在与编辑斗争,它赢得了我 =(

最佳答案

我不确定自动刷新是不是一个好主意:日志文件通常会非常频繁地修改,并且很快就会变得很长,因此您有不断重新读取长文件来更新区域的风险,而这个区域,不断更新,可能会变得难以阅读。

如果你真的想这样做,我认为唯一的解决办法是先读取文件并存储它的长度或修改日期,然后启动一个线程,每 N 秒将长度或修改日期与另一个线程进行比较存储在内存中。如果它已经改变,重新读取文件并更新文本区域和长度或修改日期。

注意不要从轮询线程更新文本区域,而要从事件分发线程更新。使用 SwingUtilities.invokeLater 来完成。

关于java - 当相关文件更改时动态刷新 JTextPane,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7159639/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com