我创建了我自己的CellRenderer,它在一个JList项目中包含一些字符串和一个JProgressBar……但是JProgressBar和整个JList项目只会绘制一次,我正在寻找一种重新绘制这些项目的方法……我试着启动一个线程,它将永久重绘...但我不知道我要重新画什么才能得到结果。
JList重绘...无结果CellRenderer重绘...无结果JFrame重绘...无结果
有没有人理解我的问题并知道解决的方法?
非常感谢!
更新:更新已删除
下一次更新:
import java.awt.Component;
import java.awt.Dimension;
import javax.swing.DefaultListModel;
import javax.swing.JFrame;
import javax.swing.JList;
import javax.swing.JPanel;
import javax.swing.JProgressBar;
import javax.swing.ListCellRenderer;
public class Main extends JFrame{
public DefaultListModel contentListModel = new DefaultListModel();
public MyCellRenderer MCR = new MyCellRenderer();
public JList contentList = new JList(contentListModel);
public Main(){
super("Example");
setMinimumSize(new Dimension(300,300));
setDefaultCloseOperation(EXIT_ON_CLOSE);
contentList.setCellRenderer(MCR);
contentListModel.addElement("");
contentListModel.addElement("");
add(contentList);
}
public static void main(String[] args){
new Main().setVisible(true);
}
class MyCellRenderer extends JPanel implements ListCellRenderer{
public MyCellRenderer(){
JProgressBar jpb = new JProgressBar();
jpb.setIndeterminate(true);
add(jpb);
}
@Override
public Component getListCellRendererComponent(JList arg0, Object arg1,
int arg2, boolean arg3, boolean arg4) {
// TODO Auto-generated method stub
return this;
}
}
}发布于 2013-04-17 19:42:02
如前所述,渲染器不是活动组件,这不是组件层次结构的一部分。因此,“自然”动画效果(如f.i.不确定进度条的移动)丢失。一个可能有效的技巧--但要注意:这是高度依赖于LAF的!--就是对系统撒谎,并报告酒吧总是不可支付的。再加上计时器每隔x毫秒伪造一个新值,可能会再次显示动画:
public static class ProgressBarRenderer implements TableCellRenderer {
/** The bar. */
private JProgressBar indeterminate = new JProgressBar() {
// fake displayable to trigger ui animation
@Override
public boolean isDisplayable() {
return true;
};
};
/** The bar. */
private JProgressBar determinate = new JProgressBar() ;
public ProgressBarRenderer() {
indeterminate.setStringPainted(true);
indeterminate.setIndeterminate(true);
indeterminate.setString(null);
}
@Override
public Component getTableCellRendererComponent(JTable table,
Object value, boolean isSelected, boolean hasFocus, int row,
int column) {
int pbi = (Integer) value;
if (pbi < 0) {
return indeterminate;
}
determinate.setValue(pbi);
return determinate;
}
}
// a timer driving the animation
Action update = new AbstractAction() {
int count;
@Override
public void actionPerformed(ActionEvent e) {
table.setValueAt(-1, 0, AncientSwingTeam.INTEGER_COLUMN);
}
};
new Timer(100, update).start();发布于 2013-04-17 15:13:58
单元格渲染器是组件的静态/橡皮图章,它们不是“真实”的活动组件。它们被简单地“绘制”到使用它们的视图表面上。
这意味着(实际上)不可能这样重新绘制它们。您可以通过更改要更改的行的值来鼓励列表更新。这将导致模型触发更新,从而导致列表重新绘制。
import java.awt.BorderLayout;
import java.awt.Component;
import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import javax.swing.DefaultListModel;
import javax.swing.JFrame;
import javax.swing.JList;
import javax.swing.JProgressBar;
import javax.swing.JScrollPane;
import javax.swing.ListCellRenderer;
import javax.swing.Timer;
import javax.swing.UIManager;
import javax.swing.UnsupportedLookAndFeelException;
public class TestProgressListCellRenderer {
public static void main(String[] args) {
new TestProgressListCellRenderer();
}
public TestProgressListCellRenderer() {
EventQueue.invokeLater(new Runnable() {
@Override
public void run() {
try {
UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
} catch (ClassNotFoundException | InstantiationException | IllegalAccessException | UnsupportedLookAndFeelException ex) {
}
final DefaultListModel<Float> model = new DefaultListModel<>();
model.addElement(0f);
JList<Float> list = new JList<>(model);
list.setCellRenderer(new ProgressListCellRenderer());
JFrame frame = new JFrame("Testing");
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
frame.setLayout(new BorderLayout());
frame.add(new JScrollPane(list));
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
Timer timer = new Timer(125, new ActionListener() {
@Override
public void actionPerformed(ActionEvent e) {
float value = model.getElementAt(0);
value += 0.01;
if (value >= 1f) {
value = 1f;
((Timer)e.getSource()).stop();
}
model.setElementAt(value, 0);
}
});
timer.setRepeats(true);
timer.setCoalesce(true);
timer.start();
}
});
}
public class ProgressListCellRenderer extends JProgressBar implements ListCellRenderer<Float> {
@Override
public Component getListCellRendererComponent(JList<? extends Float> list, Float value, int index, boolean isSelected, boolean cellHasFocus) {
setValue(Math.round(value * 100));
return this;
}
}
}这是一个简单的例子,我试着使用setIndeterminate,但我不能让它更新(非常烦人),但这可能会引发一些想法
发布于 2013-04-17 15:28:22
Renderer并不是用来显示动画的,这只是静态绘画,幻觉,快照,JProgressBar.setIndeterminate(true);来说,如果没有肮脏的hack,<代码>F29不是一件容易的事情。
1. required own `JProgressBar`
2. required own animation for `ListCellRenderer`, and the result could be so far in compare with `JProgressBar` placed in `JPanel` e.g.
对于
JList不可能是正确的JComponents,使用只有一列的JTable和没有JTableHeader
JPanel (由GridLayout分层)与JProgressBars JProgressBar.setIndeterminate(true);一起使用,然后输出到Swing图形用户界面将非常类似于<代码>D23(没有<代码>D24或JList)1. put this `JPanel` to `JScrollPane`
2. override `getPreferredSize` for `JScrollPane`, then you'll simulating [JList.setVisibleRowCount](http://docs.oracle.com/javase/7/docs/api/javax/swing/JList.html#setVisibleRowCount%28int%29) properly
3. change [JScrollBar.setUnitIncrement](http://docs.oracle.com/javase/7/docs/api/javax/swing/JScrollBar.html#unitIncrement) for natural scrolling for `JPanel` with JComponents and with `JList`, `JTable`, `JTextArea` placed in `JScrollPane`
https://stackoverflow.com/questions/16052980
复制相似问题