进度条简单模拟demo

本文通过Java代码展示了如何创建一个简单的进度条模拟,详细解释了实现过程和关键代码,帮助读者理解进度条的实现原理。
摘要由CSDN通过智能技术生成
package com.ht.bigdata.Progress_bar;

import java.awt.Color;
import java.awt.Toolkit;
import javax.swing.ImageIcon;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JProgressBar;
import javax.swing.JWindow;


public class Demo extends JWindow implements Runnable {

    // 定义加载窗口大小
    public static final int LOAD_WIDTH = 200;
    public static final int LOAD_HEIGHT = 40;
    // 获取屏幕窗口大小
    public static final int WIDTH = Toolkit.getDefaultToolkit().getScreenSize().width;
    public static final int HEIGHT = Toolkit.getDefaultToolkit().getScreenSize().height;
    // 定义进度条组件
    public JProgressBar progressbar;
    // 定义标签组件
    public JLabel label;

    // 构造函数
    public Demo() {
// 创建标签
        label = new JLabel("数据加载中,请稍后!!!!");
        label.setBounds(0, 0,LOAD_WIDTH , LOAD_HEIGHT - 15);
// 创建进度条
        progressbar = new JProgressBar();
// 显示当前进度值信息
        progressbar.setStringPainted(true);
// 设置进度条边框不显示
        progressbar.setBorderPainted(true);
// 设置进度条的前景色
        progressbar.setForeground(new Color(0, 200, 30));
// 设置进度条的背景色
        progressbar.setBackground(new Color(168, 200, 198));
        progressbar.setBounds(0, LOAD_HEIGHT - 15, LOAD_WIDTH, 15);
// 添加组件
        this.add(label);
        this.add(progressbar);
// 设置布局为空
        this.setLayout(null);
// 设置窗口初始位置
        this.setLocation((WIDTH - LOAD_WIDTH) / 2, (HEIGHT - LOAD_HEIGHT) / 2);
// 设置窗口大小
        this.setSize(LOAD_WIDTH, LOAD_HEIGHT);
// 设置窗口显示
        this.setVisible(true);

    }

    public static void main(String[] args) {
        Demo t = new Demo();
        new Thread(t).start();
    }

    public void run() {

        for (int i = 0; i < 100; i++) {
            try { Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            progressbar.setValue(i);
        }
        try {
            Thread.sleep(3000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        JOptionPane.showMessageDialog(this, "加载完成!!!");
        this.dispose();

    }

}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PyQt5是一个结合了Python语言和Qt库的工具包,可以用于创建用户界面应用程序。为了实现一个电池形状的进度条,你可以使用`QGraphicsView`、`QGraphicsScene`以及自定义的`QGraphicsItem`来模拟这个效果。这里提供一个简化的Demo代码示例: ```python import sys from PyQt5.QtWidgets import QApplication from PyQt5.QtCore import Qt from PyQt5.QtGui import QPainter, QPen, QColor, QGraphicsRectItem, QGraphicsPathItem, QPointF from PyQt5.QtSvg import QSvg class BatteryBar(QGraphicsRectItem): def __init__(self, parent=None, width=100, height=15, value=0): super().__init__(parent) self.setRect(0, 0, width, height) self.value = value self.path = self.createBatteryPath() def paint(self, painter, option, widget): painter.setRenderHint(QPainter.Antialiasing) painter.drawPath(self.path) def createBatteryPath(self): svg_data = QSvg().load('battery.svg') # 加载电池形状的SVG文件 svg_item = QGraphicsPathItem() svg_item.addPixmap(svg_data.pixmap()) path = svg_item.boundingRect().translated(self.pos()).toPath() return path.simplify(4).translated(-self.pos()) def main(): app = QApplication(sys.argv) scene = QGraphicsScene() battery_bar = BatteryBar(value=80) # 设置初始进度为80% scene.addItem(battery_bar) view = QGraphicsView(scene) view.setSceneRect(scene.itemsBoundingRect()) view.resize(300, 200) view.show() sys.exit(app.exec_()) if __name__ == "__main__": main() ``` 在这个例子中,我们首先从一个SVG文件(如'battery.svg')加载电池形状,然后将其转换为`QGraphicsPathItem`。接着,在`paint()`函数中绘制路径。进度值会通过改变`BatteryBar`的宽度比例来显示。 请注意,你需要有一个名为'battery.svg'的SVG文件来包含电池形状,这通常需要你自己设计并保存。此外,这个示例假设SVG文件中的路径适合用于表示电池的渐进状态。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值