java图形界面编程之模拟血压计

 更新时间:2014年02月10日 09:28:43   作者:  
本文主要介绍了java基于图形处理的模拟血压计,创新实验项目的部分代码,作为平时练习用。

复制代码 代码如下:

package GraphicsCanvas;

import java.awt.BorderLayout;
import java.awt.Canvas;
import java.awt.Color;
import java.awt.Graphics;
import java.awt.Image;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JTextField;
import javax.swing.Timer;
import javax.swing.UIManager;

/**
 * 模拟血压计类,高压、低压
 *
 * @author 樊俊彬
 * @Time 2013-12-10
 */
public class Blood extends JFrame {

 private static final long serialVersionUID = 1L;
 private Image iBuffer;
 private MyCanvas bloodCanvas = new MyCanvas();
 private JTextField highPressText, lowPressText;

 // 画布长宽
 private final int CANVAS_WIDTH = 400;
 private final int CANVAS_HEIGHT = 800;

 // 玻璃外壳长宽与起始坐标
 private final int BLOOD_WIDTH = 30;
 private final int BLOOD_HEIGHT = 650;
 private final int BLOOD_X = CANVAS_WIDTH / 2 - BLOOD_WIDTH / 2;
 private final int BLOOD_Y = 50;

 // 框架大小与起始坐标
 private final int FRAME_WIDTH = 120;
 private final int FRAME_HEIGHT = 720;
 private final int FRAME_X = CANVAS_WIDTH / 2 - FRAME_WIDTH / 2;
 private final int FRAME_Y = BLOOD_Y - 20;

 // 0刻度线的横纵坐标与长度
 private final int ZORELINE_Y = BLOOD_Y + BLOOD_HEIGHT - 10;
 private final int ZORELINE_X = CANVAS_WIDTH / 2 + BLOOD_WIDTH / 2;
 private final int LINE_LENGTH = 8;

 // 输入的高压、低压
 private int highPressInput, lowPressInput;

 // 高、低压水银柱的动态高度
 int highPressHeight = 0;
 int lowPressHeight = 0;
 int startLow = BLOOD_Y;

 // 高、低水银计时器
 Timer highPressTimer, lowPressTimer;

 public Blood() {

  super("自定义血压计模型-FreeDoman");
  this.setDefaultCloseOperation(EXIT_ON_CLOSE);
  this.setBounds(300, 50, CANVAS_WIDTH, CANVAS_HEIGHT + 20);

  // 添加控制到框架北部区
  JPanel topPanel = new JPanel();
  this.add(topPanel, BorderLayout.NORTH);
  highPressText = new JTextField(5);
  lowPressText = new JTextField(5);

  JButton pressButton = new JButton("显示");
  pressButton.addActionListener(new ActionListener() {

   @Override
   public void actionPerformed(ActionEvent arg0) {
    highPressInput = Integer.parseInt(highPressText.getText());
    lowPressInput = Integer.parseInt(lowPressText.getText());

    ActionListener highPressTaskPerformer = new ActionListener() {
     public void actionPerformed(ActionEvent evt) {
      // 高度增加 1像素/0.01s,只到满足输入的要求,停止计时
      highPressHeight += 1;
      bloodCanvas.repaint();
      if (highPressHeight == highPressInput * 2) {
       highPressTimer.stop();

       // 低压水银柱计时器嵌套于高压计时器内部,有先后顺序(高压先走,后低压)
       startLow = ZORELINE_Y - highPressHeight;
       ActionListener lowPressTaskPerformer = new ActionListener() {
        public void actionPerformed(ActionEvent evt) {
         lowPressHeight += 1;
         bloodCanvas.repaint();
         if (lowPressHeight == ZORELINE_Y
           - lowPressInput * 2 - startLow)
          lowPressTimer.stop();
        }
       };
       lowPressTimer = new Timer(10, lowPressTaskPerformer);
       lowPressTimer.start();
      }
     }
    };
    // 定义每0.01秒执行一次的事件监听器
    highPressTimer = new Timer(10, highPressTaskPerformer);
    highPressTimer.start();
   }
  });

  topPanel.add(new JLabel("高压值", JLabel.CENTER));
  topPanel.add(highPressText);
  topPanel.add(new JLabel("低压值", JLabel.CENTER));
  topPanel.add(lowPressText);
  // topPanel.add(new JLabel("心率", JLabel.CENTER));
  topPanel.add(pressButton);
  // 添加画布到中央区
  this.add(bloodCanvas, BorderLayout.CENTER);
  this.setResizable(false);
  this.setVisible(true);
 }

 /**
  * 画布重绘血压计
  */
 class MyCanvas extends Canvas {
  public void paint(Graphics g) {

   // 画边框
   g.setColor(Color.BLACK);
   g.draw3DRect(FRAME_X, FRAME_Y, FRAME_WIDTH, FRAME_HEIGHT, true);

   // 画玻璃外壳
   g.setColor(Color.ORANGE);
   g.fill3DRect(BLOOD_X, BLOOD_Y, BLOOD_WIDTH, BLOOD_HEIGHT, true);

   // 高压水银柱
   g.setColor(Color.RED);
   g.fill3DRect(BLOOD_X, ZORELINE_Y - highPressHeight, BLOOD_WIDTH,
     highPressHeight, true);

   // 低压高压水银柱
   g.setColor(Color.ORANGE);
   g.fill3DRect(BLOOD_X, startLow, BLOOD_WIDTH, lowPressHeight, true);

   // 画底部水银圆球
   g.setColor(Color.RED);
   g.fillOval(CANVAS_WIDTH / 2 - 30, ZORELINE_Y - 5, 60, 60);

   // 右侧0刻度线起始刻度与坐标(刻度线纵坐标以line_y渐变)
   int rightStartDegree = 0;

   int line_y = ZORELINE_Y;
   for (; line_y > BLOOD_Y; line_y -= 2) {

    // 2个像素点为一个最小分度 1度
    g.setColor(Color.BLACK);
    g.drawLine(ZORELINE_X, line_y, ZORELINE_X + LINE_LENGTH, line_y);

    // 每隔10最小分度个画10度刻度线
    if (line_y % 20 == 10) {
     g.setColor(Color.BLUE);
     g.drawLine(ZORELINE_X, line_y,
       ZORELINE_X + LINE_LENGTH * 2, line_y);
     g.drawString(rightStartDegree + "", ZORELINE_X
       + LINE_LENGTH * 3, line_y + 4);
     rightStartDegree += 10;
    }
   }

   // 左侧0刻度线起始刻度与坐标(刻度线纵坐标以line_y渐变)
   int leftStartDegree = 0;
   int leftLine_y = ZORELINE_Y;
   for (; leftLine_y > BLOOD_Y; leftLine_y -= 6) {

    // 6个像素点为一个最小分度 1度
    g.setColor(Color.BLACK);
    g.drawLine(BLOOD_X, leftLine_y, BLOOD_X - LINE_LENGTH,
      leftLine_y);

    // 每隔10最小分度个画10度刻度线
    if (leftLine_y % 20 == 10) {
     g.setColor(Color.BLUE);
     g.drawLine(BLOOD_X, leftLine_y, BLOOD_X - LINE_LENGTH * 2,
       leftLine_y);
     g.drawString(leftStartDegree + "", BLOOD_X - LINE_LENGTH
       * 4, leftLine_y + 4);
     leftStartDegree += 10;
    }
   }
  }

  /**
   * 双缓冲技术:复杂的计算速度慢于屏幕显示,用缓冲解决屏幕闪烁问题
   */

  @Override
  public void update(Graphics g) {
   if (iBuffer == null) {
    iBuffer = createImage(this.getSize().width,
      this.getSize().height);

   }
   Graphics gBuffer = iBuffer.getGraphics();
   gBuffer.setColor(getBackground());
   gBuffer.fillRect(0, 0, this.getSize().width, this.getSize().height);
   paint(gBuffer);
   gBuffer.dispose();
   g.drawImage(iBuffer, 0, 0, this);
  }
 }

 public static void main(String[] args) {

  // 设置界面的外观,为系统外观
  try {
   UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
  } catch (Exception e) {
   e.printStackTrace();
  }

  new Blood();
 }
}

相关文章

  • Java多线程基础——Lock类

    Java多线程基础——Lock类

    Lock类是Java类来提供的功能,丰富的api使得Lock类的同步功能比synchronized的同步更强大。本文对此进行详细介绍,下面跟着小编一起来看下吧
    2017-02-02
  • Java并发编程之ConcurrentLinkedQueue解读

    Java并发编程之ConcurrentLinkedQueue解读

    这篇文章主要介绍了Java并发编程之ConcurrentLinkedQueue解读,非阻塞的实现方式则可以使用循环CAS的方式来实现,而ConcurrentLinkedQueue就是juc包中自带的经典非堵塞方式实现的工具类,需要的朋友可以参考下
    2023-12-12
  • feign调用中文参数被encode编译的问题

    feign调用中文参数被encode编译的问题

    这篇文章主要介绍了feign调用中文参数被encode编译的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • mybatis调用mysql存储过程(返回参数,单结果集,多结果集)

    mybatis调用mysql存储过程(返回参数,单结果集,多结果集)

    本文主要介绍了mybatis调用mysql存储过程(返回参数,单结果集,多结果集),文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • 详解SpringSecurity如何实现前后端分离

    详解SpringSecurity如何实现前后端分离

    这篇文章主要为大家介绍了详解SpringSecurity如何实现前后端分离,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • Java 泛型的上界和下界通配符示例详解

    Java 泛型的上界和下界通配符示例详解

    这篇文章主要为大家通过示例介绍了Java 泛型的上界和下界通配符,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • Maven入门教程之如何在idea中配置Maven

    Maven入门教程之如何在idea中配置Maven

    Maven是非常出色的项目管理工具,我们可以用它管理本地项目,下面这篇文章主要给大家介绍了关于Maven入门教程之如何在idea中配置Maven的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • Java使用agent实现main方法之前的实例详解

    Java使用agent实现main方法之前的实例详解

    这篇文章主要介绍了Java使用agent实现main方法之前的实例详解的相关资料,希望通过本文能帮助到大家,让大家理解这部分内容,需要的朋友可以参考下
    2017-10-10
  • Java WebSocket客户端接收大量数据的三种方案

    Java WebSocket客户端接收大量数据的三种方案

    WebSocket是一种基于TCP协议的全双工通信协议,它能够在客户端和服务器之间建立一个持久连接,实现实时的双向数据传输,在实际应用中,有时候我们需要处理大量的数据,所以本文将介绍如何使用 Java WebSocket 客户端接收大量数据,并提供一些优化方案
    2023-11-11
  • SpringBoot核心@SpringBootApplication使用介绍

    SpringBoot核心@SpringBootApplication使用介绍

    这篇文章主要介绍了SpringBoot核心@SpringBootApplication的使用,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03

最新评论