Java图形界面开发:高级Swing容器(三)

开发 后端
在本文中,我们将会了解一些构建在这些布局管理器之上的容器以及其他的一些无需布局管理器的容器。详细请看下文

11.5 JViewport类

JViewport很少在JScrollPane之外使用。通常情况下他位于JScrollPane的中间并且使用ViewportLayout管理器来响应在小空间内显示大Component的定位请求。除了位于JScrollPane的中间以外,JViewport也可以用于JScrollPane的行头与列头。

11.5.1 创建JViewport

JViewport只有一个无参数的构造函数:public JViewport()。一旦我们创建了JViewport,我们可以通过setView(Component)向其中添加组件。

11.5.2 JViewport属性

表11-10显示了JViewport的13个属性。将布局管理器设置为ViewportLayout以外的布局管理也可以的,但是并不推荐,因为ViewportLayout布局管理器可以使得JViewport正确工作。


 

 

 

由于滚动的复杂性以及性能原因,JViewport并不支持边框。试着使用setBorder(Border)方法将边框设置为非null会抛出IllegalArgumentException。因为没有边框,所以insets属性的设置总为(0,0,0,0)。我们不能在JViewport周围显示边框,但是我们可以在视图所在的组件周围显示边框。只需要简单的在组件周围放置一个边框,或是将组件放在一个具有边框的JPanel中,然后将其添加到JViewport。如果我们确实在组件周围添加了边框,只有当组件部分可以见时边框才可见。如果我们不希望边框滚动,我们必须将JViewport放在类似JScrollPane这样具有自己边框的组件中。

提示,要设置显示在JScrollPane中的背景色,我们需要设置视图区域的背景色:aScrollPane.getViewport().setBackground(newColor)。

视图的尺寸(viewSize属性)是基于JViewport内组件的尺寸的(view属性)。视图位置(viewPosition属性)是视图矩形区域(viewRect属性)的左上角,其中矩形区域的尺寸是视图区域的扩展尺寸(extentSize属性)。如果感到迷惑,图11-18会有助于我们理解JViewport中的各种属性。


 

 

 

scrollMode属性可以设置为表11-11中所列的类常量的一个。在大多数情况下,我们可以使用默认的BLIST_SCROLL_MODE模式。


 

 

 

为了在周围移动视图的可见部分,我们只需要修改viewPosition属性。这会移动viewRect,使得我们可以看到视图的不同部分。为了显示这一行为,列表11-5中的程序将键盘快捷键绑定到了JViewport,从而我们可以使用箭头键来移动视图。(通常情况下,JScrollPane会获得这些键盘动作。)代码的主要部分对于设置相应的输入/动作映射是必须的。以粗体显示的代码是移动视图所必须的。

  1. package swingstudy.ch11;  
  2.    
  3. import java.awt.BorderLayout;  
  4. import java.awt.Dimension;  
  5. import java.awt.EventQueue;  
  6. import java.awt.Point;  
  7. import java.awt.event.ActionEvent;  
  8.    
  9. import javax.swing.AbstractAction;  
  10. import javax.swing.Action;  
  11. import javax.swing.ActionMap;  
  12. import javax.swing.Icon;  
  13. import javax.swing.ImageIcon;  
  14. import javax.swing.InputMap;  
  15. import javax.swing.JComponent;  
  16. import javax.swing.JFrame;  
  17. import javax.swing.JLabel;  
  18. import javax.swing.JViewport;  
  19. import javax.swing.KeyStroke;  
  20.    
  21. public class MoveViewSample {  
  22.    
  23.     public static final int INCREASE = 0// direction  
  24.     public static final int DECREASE = 1// direction  
  25.     public static final int X_AXIS = 0// axis  
  26.     public static final int Y_AXIS = 1// axis  
  27.     public static final int UNIT = 0;   // type  
  28.     public static final int BLOCK = 1;  // type  
  29.    
  30.     static class MoveAction extends AbstractAction {  
  31.         JViewport viewport;  
  32.         int direction;  
  33.         int axis;  
  34.         int type;  
  35.         public MoveAction(JViewport viewport, int direction, int axis, int type) {  
  36.             if(viewport == null) {  
  37.                 throw new IllegalArgumentException("null viewport not permitted");  
  38.             }  
  39.             this.viewport = viewport;  
  40.             this.direction = direction;  
  41.             this.axis = axis;  
  42.             this.type = type;  
  43.         }  
  44.    
  45.         public void actionPerformed(ActionEvent event) {  
  46.             Dimension extentSize = viewport.getExtentSize();  
  47.             int horizontalMoveSize = 0;  
  48.             int verticalMoveSize = 0;  
  49.             if(axis == X_AXIS) {  
  50.                 if(type == UNIT) {  
  51.                     horizontalMoveSize = 1;  
  52.                 }  
  53.                 else {  
  54.                     // type == BLOCK  
  55.                     horizontalMoveSize = extentSize.width;  
  56.                 }  
  57.             }  
  58.             else {  
  59.                 // axis == Y_AXIS  
  60.                 if(type == UNIT) {  
  61.                     verticalMoveSize = 1;  
  62.                 }  
  63.                 else {  
  64.                     // type = BLOCK  
  65.                     verticalMoveSize = extentSize.height;  
  66.                 }  
  67.             }  
  68.             if(direction == DECREASE) {  
  69.                 horizontalMoveSize = -horizontalMoveSize;  
  70.                 verticalMoveSize = -verticalMoveSize;  
  71.             }  
  72.             // translate origin by some amount  
  73.             Point origin = viewport.getViewPosition();  
  74.             origin.x += horizontalMoveSize;  
  75.             origin.y += verticalMoveSize;  
  76.             // set new viewing origin  
  77.             viewport.setViewPosition(origin);  
  78.         }  
  79.     }  
  80.    
  81.     /**  
  82.      * @param args  
  83.      */ 
  84.     public static void main(String[] args) {  
  85.         // TODO Auto-generated method stub  
  86.    
  87.         Runnable runner = new Runnable() {  
  88.             public void run() {  
  89.                 JFrame frame = new JFrame("JViewport Sample");  
  90.                 frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);  
  91.                 Icon icon = new ImageIcon("dog.jpg");  
  92.                 JLabel dogLabel = new JLabel(icon);  
  93.                 JViewport viewport =  new JViewport();  
  94.                 viewport.setView(dogLabel);  
  95.    
  96.                 InputMap inputMap = viewport.getInputMap(JComponent.WHEN_IN_FOCUSED_WINDOW);  
  97.                 ActionMap actionMap = viewport.getActionMap();  
  98.    
  99.                 // up key moves view up unit  
  100.                 Action upKeyAction = new MoveAction(viewport, DECREASE, Y_AXIS, UNIT);  
  101.                 KeyStroke upKey = KeyStroke.getKeyStroke("UP");  
  102.                 inputMap.put(upKey, "up");  
  103.                 actionMap.put("up", upKeyAction);  
  104.    
  105.                 // down key moves view down unit  
  106.                 Action downKeyAction = new MoveAction(viewport, INCREASE, Y_AXIS, UNIT);  
  107.                 KeyStroke downKey = KeyStroke.getKeyStroke("DOWN");  
  108.                 inputMap.put(downKey, "down");  
  109.                 actionMap.put("down", downKeyAction);  
  110.    
  111.                 // left key moves view left unit  
  112.                 Action leftKeyAction = new MoveAction(viewport, DECREASE, X_AXIS, UNIT);  
  113.                 KeyStroke leftKey = KeyStroke.getKeyStroke("LEFT");  
  114.                 inputMap.put(leftKey, "left");  
  115.                 actionMap.put("left", leftKeyAction);  
  116.    
  117.                 // right key mvoes view right unit  
  118.                 Action rightKeyAction = new MoveAction(viewport, INCREASE, X_AXIS, UNIT);  
  119.                 KeyStroke rightKey = KeyStroke.getKeyStroke("RIGHT");  
  120.                 inputMap.put(rightKey, "right");  
  121.                 actionMap.put("right", rightKeyAction);  
  122.    
  123.                 // pgup key moves view up block  
  124.                 Action pgUpKeyAction = new MoveAction(viewport, DECREASE, Y_AXIS, BLOCK);  
  125.                 KeyStroke pgUpKey = KeyStroke.getKeyStroke("PAGE_UP");  
  126.                 inputMap.put(pgUpKey, "pgUp");  
  127.                 actionMap.put("pgUp", pgUpKeyAction);  
  128.    
  129.                 // pgdn key moves view down block  
  130.                 Action pgDnKeyAction = new MoveAction(viewport, INCREASE, Y_AXIS, BLOCK);  
  131.                 KeyStroke pgDnKey = KeyStroke.getKeyStroke("PAGE_DOWN");  
  132.                 inputMap.put(pgDnKey, "pgDn");  
  133.                 actionMap.put("pgDn", pgDnKeyAction);  
  134.    
  135.                 // shift-pgup key moves view left block  
  136.                 Action shiftPgUpKeyAction = new MoveAction(viewport, DECREASE, X_AXIS, BLOCK);  
  137.                 KeyStroke shiftPgUpKey = KeyStroke.getKeyStroke("shift PAGE_UP");  
  138.                 inputMap.put(shiftPgUpKey, "shiftPgUp");  
  139.                 actionMap.put("shiftPgUp", shiftPgUpKeyAction);  
  140.    
  141.                 // shift-pgdn key moves view right block  
  142.                 Action shiftPgDnKeyAction = new MoveAction(viewport, INCREASE, X_AXIS, BLOCK);  
  143.                 KeyStroke shiftPgDnKey = KeyStroke.getKeyStroke("shift PAGE_DOWN");  
  144.                 inputMap.put(shiftPgDnKey, "shiftPgDn");  
  145.                 actionMap.put("shiftPgDn", shiftPgDnKeyAction);  
  146.    
  147.                 frame.add(viewport, BorderLayout.CENTER);  
  148.                 frame.setSize(300200);  
  149.                 frame.setVisible(true);  
  150.             }  
  151.         };  
  152.         EventQueue.invokeLater(runner);  
  153.     }  
  154.    

11.5.3 自定义JViewport观感

每一个可安装的Swing观感通过BasicViewportUI共享相同的JViewport外观,并没有实际外观上的区别。然而,仍然存在一个JViewport的UIResource相关属性集合,如表11-12所示。对于JViewport组件,有四个这样的属性。


 

 

 

11.6 小结

在本章中,我们探讨了一些高级的Swing容器。对于Box类,我们可以更容易的使用BoxLayout管理器考虑到组件的最小尺寸,***尺寸与***尺寸以***的可能方式来创建单行或单列的组件。

对于JSplitPane组件,我们可以通过在其所包含的两个组件间添加分隔符来创建一行或一列的组件,并允许用户通过移动分隔符来手动修改组件的尺寸。

JTabbedPane容器每次只显示所包含的组件集合中的一个组件。所显示的组件是通过用户选择标签来选择的,标签中可以包含具有或是不具有热键的标题,图标以及工具提示文本。这就是我们通常在程序中见到的流行的属性页。

JScrollPane与JViewport容器可以使得我们在一小区域内显示一个大组件。JScrollPane添加了滚动条使得终端用户移动可视化部分,而JViewport没有添加这些滚动条。

在第12章中,我们将会再次探讨Swing库中的单个组件,包括JProgressBar,JScrollBar以及共享BoundedRangeModel作为其数据模型的JSlider。
 

原文链接:http://blog.csdn.net/mylxiaoyi/article/details/7487194

【编辑推荐】

  1. Java图形界面开发:高级Swing容器(二)
  2. Java图形界面开发:高级Swing容器(一)
  3. Java图形用户界面:高级组件综合例子
责任编辑:林师授 来源: mylxiaoyi的博客
相关推荐

2012-04-24 09:40:42

SwingJava

2012-04-27 15:21:45

JavaSwing

2012-01-16 11:03:09

javaswing

2011-07-28 17:40:04

MySQLMySQL Workb

2010-11-25 09:05:53

MonoDevelop

2010-03-03 17:50:45

Android图形界面

2011-10-11 13:22:55

FreeBSD

2009-05-26 15:22:14

Linux图形备份

2011-02-22 18:09:08

2016-10-28 08:57:56

Git图形界面

2009-09-10 10:02:18

VxWorksLinux图形界面Linux

2021-11-08 08:14:50

Python图形界面框架

2011-09-06 15:10:20

Ubuntu图形界面

2021-02-04 11:08:00

LinuxSSH工具

2010-01-07 10:04:49

Ubuntu图形

2012-04-19 13:21:02

Javaswing

2009-03-06 15:12:24

LinuxUbuntuPrefixSuffi

2009-10-13 14:44:02

图形界面linuxunix

2019-02-21 19:00:49

LinuxSSH图形界面工具

2010-03-05 13:31:32

Ubuntu图形界面
点赞
收藏

51CTO技术栈公众号