JAVA笔记 Form界面的log展示

   
复制代码
import java.awt.BorderLayout;
import java.awt.FlowLayout;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.WindowEvent;
import java.awt.event.WindowListener;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JTextArea;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

public class MainForm extends Thread{
    private JFrame frame;
    private JScrollPane scrollpanel;
    private JPanel panel = new JPanel();
    private final JTextArea text;
    private boolean islogging=true;
    Log log =LogFactory.getLog(MainForm.class);
    
    public MainForm(){
            final JButton startButton = new JButton("start");
            startButton.setActionCommand("start");
            final JButton stopButton = new JButton("stop");
            stopButton.setActionCommand("stop");

            text= new JTextArea();
            scrollpanel = new JScrollPane();
            scrollpanel.setViewportView(text);
            panel.setLayout(new BorderLayout());
            panel.add(scrollpanel,BorderLayout.CENTER);
            
            JPanel bottom = new JPanel();
            bottom.setLayout(new FlowLayout());
            bottom.add(startButton);
            bottom.add(stopButton);
    
        panel.add(bottom,BorderLayout.SOUTH);
            ActionListener listener = new ActionListener(){
    
                @Override
                public void actionPerformed(ActionEvent e) {
                    if("start".equals(e.getActionCommand())){
                        Thread thread = new Thread(){
                            public void run(){
                                //你自己的操作
                            }
                        };        
                        thread.start();
                    }
                    else if("stop".equals(e.getActionCommand())){
                        //你自己的操作
                    }
                    else{
                        
                    }
                }
                
            };
            startButton.addActionListener(listener);
            stopButton.addActionListener(listener);
    
            frame = new JFrame();
            frame.setTitle("程序");
            frame.getContentPane().add(panel);
            frame.setSize(600,400);
            frame.setResizable(false);
            frame.setVisible(true);
            frame.addWindowListener(new WindowListener(){
        
                    @Override
                    public void windowActivated(WindowEvent e) {
                        // TODO Auto-generated method stub
                        
                    }
        
                    @Override
                    public void windowClosed(WindowEvent e) {
                        System.exit(0);
                    }
        
                    @Override
                    public void windowClosing(WindowEvent e) {                
                        islogging=false;
                        System.exit(0);
                    }
        
                    @Override
                    public void windowDeactivated(WindowEvent e) {
                        // TODO Auto-generated method stub
                        
                    }
        
                    @Override
                    public void windowDeiconified(WindowEvent e) {
                        // TODO Auto-generated method stub
                        
                    }
        
                    @Override
                    public void windowIconified(WindowEvent e) {
                        // TODO Auto-generated method stub
                        
                    }
        
                    @Override
                    public void windowOpened(WindowEvent e) {
                        // TODO Auto-generated method stub
                        
                    }
                });
                
            @Override
          public void run() {
            int count=0;
            while(islogging){
                try{
                    synchronized(this.text){
                      //从log队列中取出下一个
                        LogBean msg =LogDispacher.push();
                        if(msg==null){
                            continue;
                        }
                        LogBean.LogType type=msg.getType();
                        //判断日志是否要显示到界面上
                        if(type==LogBean.LogType.LOGFILE||type==LogBean.LogType.BOTH){
                            log.info(msg.getMsg());
                            if(msg.getType()==LogBean.LogType.LOGFILE){
                                continue;
                            }
                        }
                                            
                        count++;
                        if(count>100){
                            count=0;
                            this.text.setText("");
                        }
                        StringBuilder build = new StringBuilder(this.text.getText());
                        build.append(msg.getMsg());
                        this.text.setText(build.toString()+"\n");
                    }
                    
                }
                catch(Exception ex){
                    
                }
                
                try {
                    Thread.sleep(1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }        
        }
}



package com.ect.smsmessager.server;

import java.util.LinkedList;
import java.util.Queue;

import com.ect.smsmessager.bean.LogBean;

public class LogDispacher {

    public static Queue<LogBean> logQueue= new LinkedList<LogBean>();
    
    public static void poll(String msg,LogBean.LogType type){
        LogBean bean = new LogBean(msg,type);
        synchronized(logQueue){
            logQueue.offer(bean);
        }
    }
    
    public static  LogBean push(){
        synchronized(logQueue){
            if(logQueue!=null&&!logQueue.isEmpty()){
                return logQueue.poll();
            }
            return null;
        }
    }
}
复制代码

posted on   心笑峰  阅读(1548)  评论(0编辑  收藏  举报

编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· .NET周刊【3月第1期 2025-03-02】
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· [AI/GPT/综述] AI Agent的设计模式综述

导航

< 2012年8月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31 1
2 3 4 5 6 7 8
点击右上角即可分享
微信分享提示