如果您创建的视口大于JScrollPane的组件,那么它会在左上角显示该组件。Swing:创建一个显示其组件居中的JScrollPane?
有什么方法可以改变这种行为,所以它显示组件居中?
下面的示例程序。
澄清:
我有具有(宽度,高度)=(CW,CH)的成分。我有一个带有(宽度,高度)=(vw,vh)视口的JScrollPane。
组件可能会变大或变小。我想用一种方法来使用滚动条将组件的中心点相对于视口的中心点定位,所以如果组件的一个或两个尺寸小于视口,则组件显示在视口的中心。
默认的滚动窗格行为将组件的左上角相对于视口的左上角定位。
我在问的是如何改变参考点。我不确定这对于默认的JScrollPane来说有多容易,所以如果不容易,那么我会学到我能做的,并想到一种不同的方法。
package com.example.test.gui;
import java.awt.BorderLayout;
import java.awt.Dimension;
import java.awt.Graphics;
import java.awt.Graphics2D;
import java.awt.geom.AffineTransform;
import javax.swing.JFrame;
import javax.swing.JPanel;
import javax.swing.JScrollPane;
import javax.swing.JSpinner;
import javax.swing.SpinnerNumberModel;
import javax.swing.event.ChangeEvent;
import javax.swing.event.ChangeListener;
public class SimpleScroller extends JFrame {
static class Thingy extends JPanel
{
private double size = 20.0;
@Override public Dimension getPreferredSize() {
int isize = (int) this.size;
return new Dimension(isize, isize);
}
@Override protected void paintComponent(Graphics g) {
super.paintComponent(g);
int[] x = {0, 100, 100, 0, 0, 75, 75, 25, 25, 50};
int[] y = {0, 0, 100, 100, 25, 25, 75, 75, 50, 50};
Graphics2D g2d = (Graphics2D) g;
AffineTransform at0 = g2d.getTransform();
g2d.scale(size/100, size/100);
g.drawPolyline(x, y, x.length);
g2d.setTransform(at0);
}
public void setThingySize(double size) {
this.size = size;
revalidate();
repaint();
}
public double getThingySize() { return this.size; }
}
public SimpleScroller(String title) {
super(title);
final Thingy thingy = new Thingy();
setLayout(new BorderLayout());
add(new JScrollPane(thingy), BorderLayout.CENTER);
final SpinnerNumberModel spmodel =
new SpinnerNumberModel(thingy.getThingySize(),
10.0, 2000.0, 10.0);
spmodel.addChangeListener(new ChangeListener() {
@Override public void stateChanged(ChangeEvent e) {
thingy.setThingySize((Double) spmodel.getNumber());
}
});
add(new JSpinner(spmodel), BorderLayout.NORTH);
}
public static void main(String[] args) {
new SimpleScroller("simple scroller").start();
}
private void start() {
setDefaultCloseOperation(EXIT_ON_CLOSE);
pack();
setVisible(true);
}
}
请张贴你正在拉你的头发的代码:-)。感谢上帝,因为“我不拉我的头发(还)”,例子会很好,有些事情可以尝试一下,非常感谢:-) –
我不拉我的头发,我希望发布我的代码,但我可以拿出一个例子。 –
你想在JScrollPane – mKorbel