File: SavePresentationStateDialog.java

package info (click to toggle)
dicomscope 3.6.0-28
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 6,256 kB
  • sloc: java: 22,911; cpp: 5,957; sh: 270; makefile: 45
file content (180 lines) | stat: -rw-r--r-- 5,940 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
/*
 *
 *  Copyright (C) 1999, Institute for MicroTherapy
 *
 *  This software and supporting documentation were developed by
 *
 *    University of Witten/Herdecke
 *    Department of Radiology and MicroTherapy
 *    Institute for MicroTherapy
 *    Medical computer science
 *    
 *    Universitaetsstrasse 142
 *    44799 Bochum, Germany
 *    
 *    http://www.microtherapy.de/go/cs
 *    mailto:computer.science@microtherapy.de
 *
 *  THIS SOFTWARE IS MADE AVAILABLE,  AS IS,  AND THE INSTITUTE MAKES  NO 
 *  WARRANTY REGARDING THE SOFTWARE, ITS PERFORMANCE, ITS MERCHANTABILITY
 *  OR FITNESS FOR ANY PARTICULAR USE, FREEDOM FROM ANY COMPUTER DISEASES 
 *  OR ITS CONFORMITY TO ANY SPECIFICATION. THE ENTIRE RISK AS TO QUALITY 
 *  AND PERFORMANCE OF THE SOFTWARE IS WITH THE USER.
 *
 *  Author :      $Author: kleber $
 *  Last update : $Date: 2001/06/06 10:32:29 $
 *  Revision :    $Revision: 1.1.1.1 $
 *  State:        $State: Exp $
*/
package browser;

import javax.swing.*;
import javax.swing.border.*;
import java.awt.*;
import jToolkit.gui.*;
import main.*;
/**
* This class contains the diaog for saving a presentation state. 
* @autor Klaus Kleber
* @since 01.06.2000
*/
public class SavePresentationStateDialog extends javax.swing.JDialog implements jToolkit.gui.CommandButtonListener
{
    /**
    * Action for pressing the OK-Button
    */
    public static final int ID_OK = 0;
    /**
    * Action for pressing the Cancel-Button
    */
    public static final int ID_CANCEL = 1;
    
    
    private CommandJButton okButton = new CommandJButton("OK", this, ID_OK);
    private CommandJButton cancelButton = new CommandJButton("CANCEL", this,ID_CANCEL);
    private int actionValue;
    private JTextField nameTextField;
    private JTextField creatorTextField;
    private JRadioButton implicitButton = new JRadioButton("Implicit VR Little Endian", false);
    private JRadioButton explicitButton= new JRadioButton("Explicit VR Little Endian", true);
    private JCheckBox displayAreaCheckBox = new JCheckBox("Set Displayed Area to Image Size", true);
    
    /**
    * Constructor.
    * @param parent Parent Frame.
    * @param chooseTransferSyntax If true the transfer syntax of the image is selectable.
    */
    public SavePresentationStateDialog(JFrame parent, boolean chooseTransferSyntax, String title, boolean savePS) 
    {
        super(parent,title , true);
        setLocationRelativeTo(parent);
        getContentPane().setSize(400,300);
        
        JPanel paintPanel = new JPanel();
        paintPanel.setLayout(new BoxLayout(paintPanel,BoxLayout.Y_AXIS));
        getContentPane().add(paintPanel);
        
        GuiComponents gui = GuiComponents.getInstance();
        nameTextField = gui.nameTextField;
        creatorTextField = gui.creatorTextField;
        
        JPanel psPanel = new JPanel(new BorderLayout());
        psPanel.setBorder(new TitledBorder("Presentation State"));
        JPanel nPanel = new JPanel(new GridLayout(2,2));
        nPanel.add(new JLabel("Label: "));
        nPanel.add(nameTextField);
        nPanel.add(new JLabel("Creator: "));
        nPanel.add(creatorTextField);
        psPanel.add(nPanel, BorderLayout.NORTH);        
        
        paintPanel.add(psPanel);        
        
        JPanel daPanel = new JPanel();
        daPanel.setBorder(new TitledBorder("Displayed Area"));
        daPanel.add(displayAreaCheckBox);
        paintPanel.add(daPanel);        
        
         
         
         if (chooseTransferSyntax)
         {
            JPanel trPanel = new JPanel();
            trPanel.setBorder(new TitledBorder("Transfer Syntax"));
            trPanel.setLayout(new GridLayout(1,2));
            trPanel.add(implicitButton);
            trPanel.add(explicitButton);
            ButtonGroup bg = new ButtonGroup();
            bg.add(implicitButton);
            bg.add(explicitButton);
            paintPanel.add(trPanel);
         }
         
         JPanel southPanel = new JPanel();
         southPanel.add(okButton);
         if (savePS) southPanel.add(cancelButton);
        
        paintPanel.add(southPanel);
        pack();
        
    }
    /**
    * Action handling.
    * @param id the id of the pressed JButton.
    */
    public void buttonClicked (int id)
    {
            if (id == ID_OK)  
            {
                actionValue = ID_OK;
                setVisible (false);
            }
            if (id == ID_CANCEL) 
            {
                actionValue = ID_CANCEL;
                setVisible (false);
            }
    }
    /**
    * Returns the Action applied to this JDialog. The following values are possible:
    * ID_OK for pressing the OK Button and ID_CANCEL for pressing the Cancel Button.
    * returns the Action applied to this JDialog.
    */
    public int getActionValue()
    {
        return actionValue;
    }
    /**
    * Returns the name of the presentation state.
    * @return the name of the presentation state.
    */
    public String getPresentationStateName()
    {
        if (nameTextField != null) return nameTextField.getText();
        else return new String("");
    }
    /**
    * Returns true if the display Area of the mage should be set to the image size
    * @return true if the display Area of the mage should be set to the image size
    */
    public boolean saveImageSize()
    {
        return displayAreaCheckBox.isSelected();
    }
    /**
    * Returns true if image and presentation state should be save in Explicit VR Little Endian
    * @return true if image and presentation state should be saved in Explicit VR Little Endian, 
    * if false Implicit Little VR Endian
    */
    public boolean saveAsExplicit()
    {
        return explicitButton.isSelected();
    }
}
/*
 *  CVS Log
 *  $Log: SavePresentationStateDialog.java,v $
 *  Revision 1.1.1.1  2001/06/06 10:32:29  kleber
 *  Init commit for DICOMscope 3.5
 *  Create new CVS
 *
*/