下面是一个执行此任务的类:
public class MultiPages extends JPanel implements ActionListener {
MultiPages() {
super(new BorderLayout());
add(leftButton, BorderLayout.WEST);
add(pages, BorderLayout.CENTER);
add(rightButton, BorderLayout.EAST);
leftButton.addActionListener(this);
rightButton.addActionListener(this);
animation.setInitialDelay(10);
animation.setRepeats(false);
}
public void addPage(JComponent page) {
page.setLocation(0, 0);
pages.add(page);
pages.setComponentZOrder(page, pages.getComponentCount() - 1);
SwingUtilities.invokeLater(new Runnable() {
@Override public void run() { doLayout(); }});
}
@Override
public void doLayout() {
Dimension size = getParent().getSize();
size.width -= leftButton.getWidth() + rightButton.getWidth();
pages.setSize(size);
for (Component page : pages.getComponents()) {
page.setSize(size);
}
super.doLayout();
}
private void scrollLeft() {
direction = true;
Component next = pages.getComponents()[pages.getComponentCount() - 1];
pages.setComponentZOrder(next, 1);
animation.start();
leftButton.setEnabled(false);
rightButton.setEnabled(false);
}
private void scrollRight() {
direction = false;
animation.start();
leftButton.setEnabled(false);
rightButton.setEnabled(false);
}
@Override
public void actionPerformed(ActionEvent e) {
Object src = e.getSource();
if (src == leftButton) {
scrollLeft();
} else if (src == rightButton) {
scrollRight();
} else if (src == animation) {
Component onTop = pages.getComponents()[0];
onTop.setLocation(onTop.getX() + (direction ? +4 : -4), 0);
if (Math.abs(onTop.getX()) < onTop.getWidth()) {
animation.start();
} else {
if (direction) {
pages.setComponentZOrder(onTop, 1);
} else {
pages.setComponentZOrder(onTop, pages.getComponentCount() - 1);
}
onTop.setLocation(0, 0);
leftButton.setEnabled(true);
rightButton.setEnabled(true);
}
}
}
private final JPanel pages = new JPanel(null);
private final JButton leftButton = new JButton("<<");
private final JButton rightButton = new JButton(">>");
private final Timer animation = new Timer(0, this);
private boolean direction;
public static void main(String[] args) {
SwingUtilities.invokeLater(new Runnable() {
@Override
public void run() {
JFrame frame = new JFrame("Multi pages demo App");
frame.setLayout(new BorderLayout());
frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
MultiPages multiPage = new MultiPages();
multiPage.setPreferredSize(new Dimension(250, 100));
JPanel page;
page = new JPanel();
page.setBackground(Color.CYAN);
page.setLayout(new BorderLayout());
page.add(new JLabel("First page", SwingConstants.CENTER), BorderLayout.CENTER);
multiPage.addPage(page);
page = new JPanel();
page.setBackground(Color.YELLOW);
page.setLayout(new BorderLayout());
page.add(new JLabel("Second page", SwingConstants.CENTER), BorderLayout.CENTER);
multiPage.addPage(page);
page = new JPanel();
page.setBackground(Color.GREEN);
page.setLayout(new BorderLayout());
page.add(new JLabel("Third page", SwingConstants.CENTER), BorderLayout.CENTER);
multiPage.addPage(page);
page = new JPanel();
page.setBackground(Color.RED);
page.setLayout(new BorderLayout());
page.add(new JLabel("Fourth page", SwingConstants.CENTER), BorderLayout.CENTER);
multiPage.addPage(page);
frame.add(multiPage, BorderLayout.CENTER);
frame.pack();
frame.setLocationRelativeTo(null);
frame.setVisible(true);
}
});
}
}
对于CardLayout的优点来说,这里是在没有动画的情况下实现相同的东西,因为CardLayout不公开它的内部映射。
A你可以看到它更简单,更少的代码,更少的bug...
public class MultiPagesCardLayout extends JPanel implements ActionListener {
MultiPagesCardLayout() {
super( new BorderLayout());
add( _leftBtn , BorderLayout.WEST );
add( _pages , BorderLayout.CENTER );
add( _rightBtn, BorderLayout.EAST );
_leftBtn .addActionListener( this );
_rightBtn.addActionListener( this );
_animation.setInitialDelay( 10 );
_animation.setRepeats( false );
}
public void addPage( Component page ) {
_pages.add( page, "" + ( _pages.getComponentCount() - 1 ));
}
@Override
public void actionPerformed( ActionEvent e ) {
Object src = e.getSource();
if( src == _leftBtn ) {
((CardLayout)_pages.getLayout()).previous( _pages );
}
else if( src == _rightBtn ) {
((CardLayout)_pages.getLayout()).next( _pages );
}
}
private final JPanel _pages = new JPanel( new CardLayout());
private final JButton _leftBtn = new JButton( "<<" );
private final JButton _rightBtn = new JButton( ">>" );
private final Timer _animation = new Timer( 0, this );
public static void main( String[] args ) {
SwingUtilities.invokeLater( new Runnable() {
@Override public void run() {
JFrame frame = new JFrame( "Multi pages demo App" );
frame.setLayout( new BorderLayout());
frame.setDefaultCloseOperation( JFrame.EXIT_ON_CLOSE );
MultiPagesCardLayout multiPage = new MultiPagesCardLayout();
multiPage.setPreferredSize( new Dimension( 250, 100 ));
JPanel page;
page = new JPanel();
page.setBackground( Color.CYAN );
page.setLayout( new BorderLayout());
page.add( new JLabel( "First page", SwingConstants.CENTER ), BorderLayout.CENTER );
multiPage.addPage( page );
page = new JPanel();
page.setBackground( Color.YELLOW );
page.setLayout( new BorderLayout());
page.add( new JLabel( "Second page", SwingConstants.CENTER ), BorderLayout.CENTER );
multiPage.addPage( page );
page = new JPanel();
page.setBackground( Color.GREEN );
page.setLayout( new BorderLayout());
page.add( new JLabel( "Third page", SwingConstants.CENTER ), BorderLayout.CENTER );
multiPage.addPage( page );
page = new JPanel();
page.setBackground( Color.RED );
page.setLayout( new BorderLayout());
page.add( new JLabel( "Fourth page", SwingConstants.CENTER ), BorderLayout.CENTER );
multiPage.addPage( page );
frame.add( multiPage, BorderLayout.CENTER );
frame.pack();
frame.setLocationRelativeTo( null );
frame.setVisible( true );
}});
}
}
我想问一下,我如何在我的应用程序中动态添加一些小部件,一个接一个,而不是一次添加完。这些小部件被添加到包含命令的for循环中,并由按钮触发。所以我想知道是否有办法在执行结束时逐渐显示输出,而不是一次显示完。起初,我试图在for循环中添加延迟,但恐怕这与每次构建输出的方式有关。 编辑:嗯,似乎我没有很好地理解和的用法,所以我对他们(或time.sleep)的尝试没有成功在所有。但显然,这是我问题的解
English | 中文 multipages-generator multipages-generator is a multiple pages application generator (or CLI) for mobile. It has the whole DevOps which includes development, build, publish and the deploym
问题内容: 当用户单击按钮时,我正在旋转图像。但这是行不通的。 我想看到图像逐渐旋转90度直到停止,但没有旋转。单击该按钮时,图像必须逐渐旋转90度。 我创建了一个SSCCE来演示该问题。请使用您选择的任何图像替换班级中的图像。只需将图像放在文件夹中并命名。 它包含主要方法。 问题答案: 除了@tulskiy的有益观察之外,我还要补充两点: 始终在事件分发线程上构造GUI ,如下所示。 一个ssc
问题内容: Java (可能还有许多其他类)内部发生的事情是有一个内部对象,对象被写入其中。每当从元素中读取元素时,都会进行转换。因此,每次读取时都要进行转换。 我不知道为什么要这样做。对我来说,似乎他们只是在做不必要的演员。只创建一个,然后不进行强制转换,是否更合乎逻辑,并且速度稍快一些?每次阵列创建仅一次强制转换,通常 远 少于读取次数。 为什么首选他们的方法?我看不出为什么我的想法并不严格吗
我有一个简短的问题。我正在尝试使用Launch4j将Jar转换为Exe。我使用的JRE版本是jre1。8.0_91. 因此,在"JRE"选项卡上启动4j时,我将Bundled JRE Path指定为。 exe文件是否在其他具有较低JRE版本的机器上工作? 是否必须在Launch4j上使用JRE Path,或者我可以使用Min JRE Version并指定1.0.0.0?这样它就可以在更高的版本上工