zoukankan      html  css  js  c++  java
  • JSplitPane详解

     摘自http://blog.163.com/xiexueyong1987@126/blog/static/1262673422010102711295541/

    JSplitPane详解  

    pasting

    java.lang.Object
        --java.awt.Component
        --java.awt.Container
           --javax.swing.JComponent
              --javax.swing.JSplitPane

     

          Split Pane(分割面版)一次可将两个组件同时显示在两个显示区中,若你想要同时在多个显示区显示组件,你便必须同时使用多个Split Pane。JSplitPane提供两个常数让你设置到底是要水平分割还是垂直分割。这两个常数分别是:HORIZONTAL_SPIT,VERTICAL_SPLIT.除了这两个重要的常数外,JSplitPane还提供许多类常数让你使用,我们会在下面的例子中介绍比较常用的类常数,其余信息请参年java API.

    JsplitPane构造函数:
    JSplitPane():建立一个新的JSplitPane,里面含有两个默认按钮,并以水平方向排列,介没有Continuous Layout功能。

    JSplitPane(int newOrientation):建立一个指定水平或垂直方向切割JSplitPane,但没有Continuous Layout功能。

    JSplitPnae(int newOrientation,boolean newContinuousLayout):

    建立一个指定水平或垂直方向切割的JSplitPane,且指定是否具有Continuous Layout功能。

    JSplitPane(int newOrientation,boolean newContinuousLayout,Component newLeftComponent,Component newRightComponent):
    建立一个指定水平或垂直方向切割的JSplitPane,且指定显示区所要显示的组件,并设置是否Continuous Layout功能。

    JSplitPane(int newOrientation,COmponent newLeftComponent,COmponent newRightComponent):
    建立一个指定水平或垂直方向切割的JSplitPane,且指定显示区所要显示的组件,但没有Continuous Layout功能 。

       上面所说的Continuous Layout意思是指当你拖曳切割面版的分隔线时,窗口内的组件是否会随着分隔线的拖曳而动态改变大小
    。newContinuousLayout是一个boolean值,若设为true,则组件大小会随着分隔线的拖曳而一起改动;
    若设为false,则组件大小在分隔线停止改动时才确定。你也可以使用JSplitPane中的setContinuousLayout()方法来设置此项目。

    JSplitPane的例子:JSplitPane1.java

     1 package com.wst.bj;
     2 
     3 import java.awt.*;
     4 import java.awt.event.*;
     5 import javax.swing.*;
     6 
     7 public class JSplitePanelDemo {
     8 
     9     public static void main(String[] args) {
    10         new JSplitePanelDemo();
    11     }
    12 
    13     public JSplitePanelDemo() {
    14         JFrame f = new JFrame("JSplitPaneDemo");
    15         Container contentPane = f.getContentPane();
    16         JLabel label1 = new JLabel("Label 1", JLabel.CENTER);
    17         label1.setBackground(Color.green);
    18         label1.setOpaque(true);// setOpaque(ture)方法的目的是让组件变成不透明,这样我们在JLabel上所设置的颜色显示出来。
    19 
    20         JLabel label2 = new JLabel("Label 2", JLabel.CENTER);
    21         label2.setBackground(Color.pink);
    22         label2.setOpaque(true);
    23 
    24         JLabel label3 = new JLabel("Label 3", JLabel.CENTER);
    25         label3.setBackground(Color.yellow);
    26         label3.setOpaque(true);
    27         /*
    28          * 加入label1,label2到splitPane1中,并设置此splitPane1为水平分割且具有Continuous Layout的
    29          * 功能。
    30          */
    31         JSplitPane splitPane1 = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT, false, label1, label2);
    32         /*
    33          * 设置splitPane1的分隔线位置,0.3是相对于splitPane1的大小而定,因此这个值的范围在0.0~1.0
    34          * 中。若你使用整数值来设置splitPane的分隔线位置,如第34行所示,则所定义的值以pixel为计算单位
    35          */
    36         splitPane1.setDividerLocation(0.3);
    37 
    38         splitPane1.setResizeWeight(0.3);
    39         /*
    40          * 设置JSplitPane是否可以展开或收起(如同文件总管一般),设为true表示打开此功能。
    41          */
    42         splitPane1.setOneTouchExpandable(true);
    43         splitPane1.setDividerSize(10);// 设置分隔线宽度的大小,以pixel为计算单位。
    44 
    45         JSplitPane splitPane2 = new JSplitPane(JSplitPane.VERTICAL_SPLIT, false, splitPane1, label3);
    46         splitPane2.setDividerLocation(70);
    47         // 设置JSplitPane是否可以展开或收起(如同文件总管一般),设为true表示打开此功能.
    48         splitPane2.setOneTouchExpandable(false);
    49         splitPane2.setDividerSize(5);
    50 
    51         contentPane.add(splitPane2);
    52 
    53         f.setSize(250, 200);
    54         f.setVisible(true);
    55         f.addWindowListener(new WindowAdapter() {
    56             public void windowClosing(WindowEvent e) {
    57                 System.exit(0);
    58             }
    59         });
    60     }
    61 
    62 }
  • 相关阅读:
    Unity接入九游SDK学习与踩坑
    Linux系统下实现Tomcat的安装和项目的部署:
    mac查看端口占用情况并结束进程
    BootStrap
    ES6
    JQuery
    CSS 、JavaScript
    HTML
    XML
    数据库连接池&DBUtils
  • 原文地址:https://www.cnblogs.com/LiuYanYGZ/p/6159008.html
Copyright © 2011-2022 走看看