Merge
This commit is contained in:
commit
6960817595
@ -49,11 +49,11 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
|
|
||||||
private FilterComboBoxModel filterComboBoxModel;
|
private FilterComboBoxModel filterComboBoxModel;
|
||||||
|
|
||||||
protected JList directoryList = null;
|
protected JList<File> directoryList = null;
|
||||||
protected JList fileList = null;
|
protected JList<File> fileList = null;
|
||||||
|
|
||||||
protected JTextField pathField = null;
|
protected JTextField pathField = null;
|
||||||
protected JComboBox filterComboBox = null;
|
protected JComboBox<FileFilter> filterComboBox = null;
|
||||||
protected JTextField filenameTextField = null;
|
protected JTextField filenameTextField = null;
|
||||||
|
|
||||||
private static final Dimension hstrut10 = new Dimension(10, 1);
|
private static final Dimension hstrut10 = new Dimension(10, 1);
|
||||||
@ -337,7 +337,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
align(l);
|
align(l);
|
||||||
leftPanel.add(l);
|
leftPanel.add(l);
|
||||||
|
|
||||||
filterComboBox = new JComboBox() {
|
filterComboBox = new JComboBox<FileFilter>() {
|
||||||
public Dimension getMaximumSize() {
|
public Dimension getMaximumSize() {
|
||||||
Dimension d = super.getMaximumSize();
|
Dimension d = super.getMaximumSize();
|
||||||
d.height = getPreferredSize().height;
|
d.height = getPreferredSize().height;
|
||||||
@ -557,7 +557,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected JScrollPane createFilesList() {
|
protected JScrollPane createFilesList() {
|
||||||
fileList = new JList();
|
fileList = new JList<File>();
|
||||||
|
|
||||||
if(getFileChooser().isMultiSelectionEnabled()) {
|
if(getFileChooser().isMultiSelectionEnabled()) {
|
||||||
fileList.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
|
fileList.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
|
||||||
@ -576,7 +576,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
if (SwingUtilities.isLeftMouseButton(e) && !chooser.isMultiSelectionEnabled()) {
|
if (SwingUtilities.isLeftMouseButton(e) && !chooser.isMultiSelectionEnabled()) {
|
||||||
int index = SwingUtilities2.loc2IndexFileList(fileList, e.getPoint());
|
int index = SwingUtilities2.loc2IndexFileList(fileList, e.getPoint());
|
||||||
if (index >= 0) {
|
if (index >= 0) {
|
||||||
File file = (File) fileList.getModel().getElementAt(index);
|
File file = fileList.getModel().getElementAt(index);
|
||||||
setFileName(chooser.getName(file));
|
setFileName(chooser.getName(file));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -593,7 +593,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected JScrollPane createDirectoryList() {
|
protected JScrollPane createDirectoryList() {
|
||||||
directoryList = new JList();
|
directoryList = new JList<File>();
|
||||||
align(directoryList);
|
align(directoryList);
|
||||||
|
|
||||||
directoryList.setCellRenderer(new DirectoryCellRenderer());
|
directoryList.setCellRenderer(new DirectoryCellRenderer());
|
||||||
@ -658,7 +658,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected class MotifDirectoryListModel extends AbstractListModel implements ListDataListener {
|
protected class MotifDirectoryListModel extends AbstractListModel<File> implements ListDataListener {
|
||||||
public MotifDirectoryListModel() {
|
public MotifDirectoryListModel() {
|
||||||
getModel().addListDataListener(this);
|
getModel().addListDataListener(this);
|
||||||
}
|
}
|
||||||
@ -667,7 +667,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
return getModel().getDirectories().size();
|
return getModel().getDirectories().size();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getElementAt(int index) {
|
public File getElementAt(int index) {
|
||||||
return getModel().getDirectories().elementAt(index);
|
return getModel().getDirectories().elementAt(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -694,7 +694,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected class MotifFileListModel extends AbstractListModel implements ListDataListener {
|
protected class MotifFileListModel extends AbstractListModel<File> implements ListDataListener {
|
||||||
public MotifFileListModel() {
|
public MotifFileListModel() {
|
||||||
getModel().addListDataListener(this);
|
getModel().addListDataListener(this);
|
||||||
}
|
}
|
||||||
@ -711,7 +711,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
return getModel().getFiles().indexOf(o);
|
return getModel().getFiles().indexOf(o);
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getElementAt(int index) {
|
public File getElementAt(int index) {
|
||||||
return getModel().getFiles().elementAt(index);
|
return getModel().getFiles().elementAt(index);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -773,7 +773,8 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
/**
|
/**
|
||||||
* Data model for a type-face selection combo-box.
|
* Data model for a type-face selection combo-box.
|
||||||
*/
|
*/
|
||||||
protected class FilterComboBoxModel extends AbstractListModel implements ComboBoxModel, PropertyChangeListener {
|
protected class FilterComboBoxModel extends AbstractListModel<FileFilter> implements ComboBoxModel<FileFilter>,
|
||||||
|
PropertyChangeListener {
|
||||||
protected FileFilter[] filters;
|
protected FileFilter[] filters;
|
||||||
protected FilterComboBoxModel() {
|
protected FilterComboBoxModel() {
|
||||||
super();
|
super();
|
||||||
@ -826,7 +827,7 @@ public class MotifFileChooserUI extends BasicFileChooserUI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getElementAt(int index) {
|
public FileFilter getElementAt(int index) {
|
||||||
if(index > getSize() - 1) {
|
if(index > getSize() - 1) {
|
||||||
// This shouldn't happen. Try to recover gracefully.
|
// This shouldn't happen. Try to recover gracefully.
|
||||||
return getFileChooser().getFileFilter();
|
return getFileChooser().getFileFilter();
|
||||||
|
@ -60,7 +60,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
|
|||||||
private JPanel centerPanel;
|
private JPanel centerPanel;
|
||||||
|
|
||||||
private JLabel lookInLabel;
|
private JLabel lookInLabel;
|
||||||
private JComboBox directoryComboBox;
|
private JComboBox<File> directoryComboBox;
|
||||||
private DirectoryComboBoxModel directoryComboBoxModel;
|
private DirectoryComboBoxModel directoryComboBoxModel;
|
||||||
private ActionListener directoryComboBoxAction = new DirectoryComboBoxAction();
|
private ActionListener directoryComboBoxAction = new DirectoryComboBoxAction();
|
||||||
|
|
||||||
@ -76,7 +76,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
|
|||||||
private JPanel buttonPanel;
|
private JPanel buttonPanel;
|
||||||
private JPanel bottomPanel;
|
private JPanel bottomPanel;
|
||||||
|
|
||||||
private JComboBox filterComboBox;
|
private JComboBox<FileFilter> filterComboBox;
|
||||||
|
|
||||||
private static final Dimension hstrut10 = new Dimension(10, 1);
|
private static final Dimension hstrut10 = new Dimension(10, 1);
|
||||||
|
|
||||||
@ -245,7 +245,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
|
|||||||
topPanel.add(Box.createRigidArea(new Dimension(8,0)));
|
topPanel.add(Box.createRigidArea(new Dimension(8,0)));
|
||||||
|
|
||||||
// CurrentDir ComboBox
|
// CurrentDir ComboBox
|
||||||
directoryComboBox = new JComboBox() {
|
directoryComboBox = new JComboBox<File>() {
|
||||||
public Dimension getMinimumSize() {
|
public Dimension getMinimumSize() {
|
||||||
Dimension d = super.getMinimumSize();
|
Dimension d = super.getMinimumSize();
|
||||||
d.width = 60;
|
d.width = 60;
|
||||||
@ -445,7 +445,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
|
|||||||
|
|
||||||
filterComboBoxModel = createFilterComboBoxModel();
|
filterComboBoxModel = createFilterComboBoxModel();
|
||||||
fc.addPropertyChangeListener(filterComboBoxModel);
|
fc.addPropertyChangeListener(filterComboBoxModel);
|
||||||
filterComboBox = new JComboBox(filterComboBoxModel);
|
filterComboBox = new JComboBox<FileFilter>(filterComboBoxModel);
|
||||||
ftl.setLabelFor(filterComboBox);
|
ftl.setLabelFor(filterComboBox);
|
||||||
filterComboBox.setRenderer(createFilterComboBoxRenderer());
|
filterComboBox.setRenderer(createFilterComboBoxRenderer());
|
||||||
fileAndFilterPanel.add(filterComboBox);
|
fileAndFilterPanel.add(filterComboBox);
|
||||||
@ -1032,7 +1032,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
|
|||||||
/**
|
/**
|
||||||
* Data model for a type-face selection combo-box.
|
* Data model for a type-face selection combo-box.
|
||||||
*/
|
*/
|
||||||
protected class DirectoryComboBoxModel extends AbstractListModel implements ComboBoxModel {
|
protected class DirectoryComboBoxModel extends AbstractListModel<File> implements ComboBoxModel<File> {
|
||||||
Vector<File> directories = new Vector<File>();
|
Vector<File> directories = new Vector<File>();
|
||||||
int[] depths = null;
|
int[] depths = null;
|
||||||
File selectedDirectory = null;
|
File selectedDirectory = null;
|
||||||
@ -1149,7 +1149,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
|
|||||||
return directories.size();
|
return directories.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getElementAt(int index) {
|
public File getElementAt(int index) {
|
||||||
return directories.elementAt(index);
|
return directories.elementAt(index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1189,7 +1189,8 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
|
|||||||
/**
|
/**
|
||||||
* Data model for a type-face selection combo-box.
|
* Data model for a type-face selection combo-box.
|
||||||
*/
|
*/
|
||||||
protected class FilterComboBoxModel extends AbstractListModel implements ComboBoxModel, PropertyChangeListener {
|
protected class FilterComboBoxModel extends AbstractListModel<FileFilter> implements ComboBoxModel<FileFilter>,
|
||||||
|
PropertyChangeListener {
|
||||||
protected FileFilter[] filters;
|
protected FileFilter[] filters;
|
||||||
protected FilterComboBoxModel() {
|
protected FilterComboBoxModel() {
|
||||||
super();
|
super();
|
||||||
@ -1242,7 +1243,7 @@ public class WindowsFileChooserUI extends BasicFileChooserUI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getElementAt(int index) {
|
public FileFilter getElementAt(int index) {
|
||||||
if(index > getSize() - 1) {
|
if(index > getSize() - 1) {
|
||||||
// This shouldn't happen. Try to recover gracefully.
|
// This shouldn't happen. Try to recover gracefully.
|
||||||
return getFileChooser().getFileFilter();
|
return getFileChooser().getFileFilter();
|
||||||
|
@ -81,6 +81,7 @@ public class WindowsTreeUI extends BasicTreeUI {
|
|||||||
else {
|
else {
|
||||||
Rectangle beginRect = getPathBounds(tree, getPathForRow
|
Rectangle beginRect = getPathBounds(tree, getPathForRow
|
||||||
(tree, beginRow));
|
(tree, beginRow));
|
||||||
|
if (beginRect != null) {
|
||||||
Rectangle testRect = beginRect;
|
Rectangle testRect = beginRect;
|
||||||
int beginY = beginRect.y;
|
int beginY = beginRect.y;
|
||||||
int maxY = beginY + visRect.height;
|
int maxY = beginY + visRect.height;
|
||||||
@ -88,15 +89,17 @@ public class WindowsTreeUI extends BasicTreeUI {
|
|||||||
for(int counter = beginRow + 1; counter <= endRow; counter++) {
|
for(int counter = beginRow + 1; counter <= endRow; counter++) {
|
||||||
testRect = getPathBounds(tree,
|
testRect = getPathBounds(tree,
|
||||||
getPathForRow(tree, counter));
|
getPathForRow(tree, counter));
|
||||||
if((testRect.y + testRect.height) > maxY)
|
if(testRect != null && (testRect.y + testRect.height) > maxY) {
|
||||||
counter = endRow;
|
counter = endRow;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
tree.scrollRectToVisible(new Rectangle(visRect.x, beginY, 1,
|
tree.scrollRectToVisible(new Rectangle(visRect.x, beginY, 1,
|
||||||
testRect.y + testRect.height-
|
testRect.y + testRect.height-
|
||||||
beginY));
|
beginY));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static protected final int HALF_SIZE = 4;
|
static protected final int HALF_SIZE = 4;
|
||||||
static protected final int SIZE = 9;
|
static protected final int SIZE = 9;
|
||||||
|
@ -24,6 +24,8 @@
|
|||||||
*/
|
*/
|
||||||
package java.awt;
|
package java.awt;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
|
|
||||||
import java.awt.event.AdjustmentEvent;
|
import java.awt.event.AdjustmentEvent;
|
||||||
import java.awt.event.AdjustmentListener;
|
import java.awt.event.AdjustmentListener;
|
||||||
import java.awt.peer.ScrollPanePeer;
|
import java.awt.peer.ScrollPanePeer;
|
||||||
@ -156,6 +158,12 @@ public class ScrollPaneAdjustable implements Adjustable, Serializable {
|
|||||||
if (!GraphicsEnvironment.isHeadless()) {
|
if (!GraphicsEnvironment.isHeadless()) {
|
||||||
initIDs();
|
initIDs();
|
||||||
}
|
}
|
||||||
|
AWTAccessor.setScrollPaneAdjustableAccessor(new AWTAccessor.ScrollPaneAdjustableAccessor() {
|
||||||
|
public void setTypedValue(final ScrollPaneAdjustable adj,
|
||||||
|
final int v, final int type) {
|
||||||
|
adj.setTypedValue(v, type);
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -63,8 +63,7 @@ import java.io.Serializable;
|
|||||||
public class BasicComboPopup extends JPopupMenu implements ComboPopup {
|
public class BasicComboPopup extends JPopupMenu implements ComboPopup {
|
||||||
// An empty ListMode, this is used when the UI changes to allow
|
// An empty ListMode, this is used when the UI changes to allow
|
||||||
// the JList to be gc'ed.
|
// the JList to be gc'ed.
|
||||||
private static class EmptyListModelClass implements ListModel,
|
private static class EmptyListModelClass implements ListModel<Object>, Serializable {
|
||||||
Serializable {
|
|
||||||
public int getSize() { return 0; }
|
public int getSize() { return 0; }
|
||||||
public Object getElementAt(int index) { return null; }
|
public Object getElementAt(int index) { return null; }
|
||||||
public void addListDataListener(ListDataListener l) {}
|
public void addListDataListener(ListDataListener l) {}
|
||||||
|
@ -810,12 +810,9 @@ public class BasicFileChooserUI extends FileChooserUI {
|
|||||||
putValue(Action.ACTION_COMMAND_KEY, FilePane.ACTION_CHANGE_TO_PARENT_DIRECTORY);
|
putValue(Action.ACTION_COMMAND_KEY, FilePane.ACTION_CHANGE_TO_PARENT_DIRECTORY);
|
||||||
}
|
}
|
||||||
public void actionPerformed(ActionEvent e) {
|
public void actionPerformed(ActionEvent e) {
|
||||||
Component focusOwner = KeyboardFocusManager.getCurrentKeyboardFocusManager().getFocusOwner();
|
|
||||||
if (focusOwner == null || !(focusOwner instanceof javax.swing.text.JTextComponent)) {
|
|
||||||
getFileChooser().changeToParentDirectory();
|
getFileChooser().changeToParentDirectory();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Responds to an Open or Save request
|
* Responds to an Open or Save request
|
||||||
|
@ -444,7 +444,7 @@ public class SynthComboBoxUI extends BasicComboBoxUI implements
|
|||||||
* renderer installed on a Synth combo box is a JLabel. If this is changed,
|
* renderer installed on a Synth combo box is a JLabel. If this is changed,
|
||||||
* then an assert will fail in SynthFileChooserUIImpl
|
* then an assert will fail in SynthFileChooserUIImpl
|
||||||
*/
|
*/
|
||||||
private class SynthComboBoxRenderer extends JLabel implements ListCellRenderer, UIResource {
|
private class SynthComboBoxRenderer extends JLabel implements ListCellRenderer<Object>, UIResource {
|
||||||
public SynthComboBoxRenderer() {
|
public SynthComboBoxRenderer() {
|
||||||
super();
|
super();
|
||||||
setName("ComboBox.renderer");
|
setName("ComboBox.renderer");
|
||||||
@ -452,7 +452,7 @@ public class SynthComboBoxUI extends BasicComboBoxUI implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Component getListCellRendererComponent(JList list, Object value,
|
public Component getListCellRendererComponent(JList<?> list, Object value,
|
||||||
int index, boolean isSelected, boolean cellHasFocus) {
|
int index, boolean isSelected, boolean cellHasFocus) {
|
||||||
setName("ComboBox.listRenderer");
|
setName("ComboBox.listRenderer");
|
||||||
SynthLookAndFeel.resetSelectedUI();
|
SynthLookAndFeel.resetSelectedUI();
|
||||||
|
@ -725,11 +725,11 @@ public class FormView extends ComponentView implements ActionListener {
|
|||||||
}
|
}
|
||||||
Object m = attr.getAttribute(StyleConstants.ModelAttribute);
|
Object m = attr.getAttribute(StyleConstants.ModelAttribute);
|
||||||
if (m instanceof OptionListModel) {
|
if (m instanceof OptionListModel) {
|
||||||
OptionListModel model = (OptionListModel)m;
|
OptionListModel<Option> model = (OptionListModel<Option>) m;
|
||||||
|
|
||||||
for (int i = 0; i < model.getSize(); i++) {
|
for (int i = 0; i < model.getSize(); i++) {
|
||||||
if (model.isSelectedIndex(i)) {
|
if (model.isSelectedIndex(i)) {
|
||||||
Option option = (Option) model.getElementAt(i);
|
Option option = model.getElementAt(i);
|
||||||
appendBuffer(buffer, name, option.getValue());
|
appendBuffer(buffer, name, option.getValue());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3358,13 +3358,13 @@ public class HTMLDocument extends DefaultStyledDocument {
|
|||||||
1);
|
1);
|
||||||
boolean multiple = attr.getAttribute(HTML.Attribute.MULTIPLE) != null;
|
boolean multiple = attr.getAttribute(HTML.Attribute.MULTIPLE) != null;
|
||||||
if ((size > 1) || multiple) {
|
if ((size > 1) || multiple) {
|
||||||
OptionListModel m = new OptionListModel();
|
OptionListModel<Option> m = new OptionListModel<Option>();
|
||||||
if (multiple) {
|
if (multiple) {
|
||||||
m.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
|
m.setSelectionMode(ListSelectionModel.MULTIPLE_INTERVAL_SELECTION);
|
||||||
}
|
}
|
||||||
selectModel = m;
|
selectModel = m;
|
||||||
} else {
|
} else {
|
||||||
selectModel = new OptionComboBoxModel();
|
selectModel = new OptionComboBoxModel<Option>();
|
||||||
}
|
}
|
||||||
attr.addAttribute(StyleConstants.ModelAttribute,
|
attr.addAttribute(StyleConstants.ModelAttribute,
|
||||||
selectModel);
|
selectModel);
|
||||||
@ -3376,14 +3376,14 @@ public class HTMLDocument extends DefaultStyledDocument {
|
|||||||
option = new Option(attr);
|
option = new Option(attr);
|
||||||
|
|
||||||
if (selectModel instanceof OptionListModel) {
|
if (selectModel instanceof OptionListModel) {
|
||||||
OptionListModel m = (OptionListModel)selectModel;
|
OptionListModel<Option> m = (OptionListModel<Option>) selectModel;
|
||||||
m.addElement(option);
|
m.addElement(option);
|
||||||
if (option.isSelected()) {
|
if (option.isSelected()) {
|
||||||
m.addSelectionInterval(optionCount, optionCount);
|
m.addSelectionInterval(optionCount, optionCount);
|
||||||
m.setInitialSelection(optionCount);
|
m.setInitialSelection(optionCount);
|
||||||
}
|
}
|
||||||
} else if (selectModel instanceof OptionComboBoxModel) {
|
} else if (selectModel instanceof OptionComboBoxModel) {
|
||||||
OptionComboBoxModel m = (OptionComboBoxModel)selectModel;
|
OptionComboBoxModel<Option> m = (OptionComboBoxModel<Option>) selectModel;
|
||||||
m.addElement(option);
|
m.addElement(option);
|
||||||
if (option.isSelected()) {
|
if (option.isSelected()) {
|
||||||
m.setSelectedItem(option);
|
m.setSelectedItem(option);
|
||||||
|
@ -527,17 +527,17 @@ public class HTMLWriter extends AbstractWriter {
|
|||||||
Object model = attr.getAttribute(StyleConstants.ModelAttribute);
|
Object model = attr.getAttribute(StyleConstants.ModelAttribute);
|
||||||
incrIndent();
|
incrIndent();
|
||||||
if (model instanceof OptionListModel) {
|
if (model instanceof OptionListModel) {
|
||||||
OptionListModel listModel = (OptionListModel)model;
|
OptionListModel<Option> listModel = (OptionListModel<Option>) model;
|
||||||
int size = listModel.getSize();
|
int size = listModel.getSize();
|
||||||
for (int i = 0; i < size; i++) {
|
for (int i = 0; i < size; i++) {
|
||||||
Option option = (Option)listModel.getElementAt(i);
|
Option option = listModel.getElementAt(i);
|
||||||
writeOption(option);
|
writeOption(option);
|
||||||
}
|
}
|
||||||
} else if (model instanceof OptionComboBoxModel) {
|
} else if (model instanceof OptionComboBoxModel) {
|
||||||
OptionComboBoxModel comboBoxModel = (OptionComboBoxModel)model;
|
OptionComboBoxModel<Option> comboBoxModel = (OptionComboBoxModel<Option>) model;
|
||||||
int size = comboBoxModel.getSize();
|
int size = comboBoxModel.getSize();
|
||||||
for (int i = 0; i < size; i++) {
|
for (int i = 0; i < size; i++) {
|
||||||
Option option = (Option)comboBoxModel.getElementAt(i);
|
Option option = comboBoxModel.getElementAt(i);
|
||||||
writeOption(option);
|
writeOption(option);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -25,7 +25,6 @@
|
|||||||
package javax.swing.text.html;
|
package javax.swing.text.html;
|
||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import javax.swing.event.*;
|
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
|
|
||||||
@ -41,7 +40,7 @@ import java.io.Serializable;
|
|||||||
@author Sunita Mani
|
@author Sunita Mani
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class OptionComboBoxModel extends DefaultComboBoxModel implements Serializable {
|
class OptionComboBoxModel<E> extends DefaultComboBoxModel<E> implements Serializable {
|
||||||
|
|
||||||
private Option selectedOption = null;
|
private Option selectedOption = null;
|
||||||
|
|
||||||
|
@ -26,7 +26,6 @@ package javax.swing.text.html;
|
|||||||
|
|
||||||
import javax.swing.*;
|
import javax.swing.*;
|
||||||
import javax.swing.event.*;
|
import javax.swing.event.*;
|
||||||
import java.util.EventListener;
|
|
||||||
import java.util.BitSet;
|
import java.util.BitSet;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
|
|
||||||
@ -44,7 +43,7 @@ import java.io.Serializable;
|
|||||||
@author Sunita Mani
|
@author Sunita Mani
|
||||||
*/
|
*/
|
||||||
|
|
||||||
class OptionListModel extends DefaultListModel implements ListSelectionModel, Serializable {
|
class OptionListModel<E> extends DefaultListModel<E> implements ListSelectionModel, Serializable {
|
||||||
|
|
||||||
|
|
||||||
private static final int MIN = -1;
|
private static final int MIN = -1;
|
||||||
|
@ -25,15 +25,12 @@
|
|||||||
|
|
||||||
package sun.awt;
|
package sun.awt;
|
||||||
|
|
||||||
|
import sun.misc.Unsafe;
|
||||||
|
|
||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.InputEvent;
|
import java.awt.event.InputEvent;
|
||||||
import java.awt.geom.Point2D;
|
import java.awt.geom.Point2D;
|
||||||
import java.awt.image.BufferedImage;
|
|
||||||
|
|
||||||
import sun.misc.Unsafe;
|
|
||||||
import java.awt.peer.ComponentPeer;
|
import java.awt.peer.ComponentPeer;
|
||||||
|
|
||||||
import java.security.AccessController;
|
|
||||||
import java.security.AccessControlContext;
|
import java.security.AccessControlContext;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -470,6 +467,17 @@ public final class AWTAccessor {
|
|||||||
boolean isMultipleMode(FileDialog fileDialog);
|
boolean isMultipleMode(FileDialog fileDialog);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* An accessor for the ScrollPaneAdjustable class.
|
||||||
|
*/
|
||||||
|
public interface ScrollPaneAdjustableAccessor {
|
||||||
|
/*
|
||||||
|
* Sets the value of this scrollbar to the specified value.
|
||||||
|
*/
|
||||||
|
void setTypedValue(final ScrollPaneAdjustable adj, final int v,
|
||||||
|
final int type);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Accessor instances are initialized in the static initializers of
|
* Accessor instances are initialized in the static initializers of
|
||||||
* corresponding AWT classes by using setters defined below.
|
* corresponding AWT classes by using setters defined below.
|
||||||
@ -485,6 +493,7 @@ public final class AWTAccessor {
|
|||||||
private static EventQueueAccessor eventQueueAccessor;
|
private static EventQueueAccessor eventQueueAccessor;
|
||||||
private static PopupMenuAccessor popupMenuAccessor;
|
private static PopupMenuAccessor popupMenuAccessor;
|
||||||
private static FileDialogAccessor fileDialogAccessor;
|
private static FileDialogAccessor fileDialogAccessor;
|
||||||
|
private static ScrollPaneAdjustableAccessor scrollPaneAdjustableAccessor;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Set an accessor object for the java.awt.Component class.
|
* Set an accessor object for the java.awt.Component class.
|
||||||
@ -675,4 +684,21 @@ public final class AWTAccessor {
|
|||||||
return fileDialogAccessor;
|
return fileDialogAccessor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Set an accessor object for the java.awt.ScrollPaneAdjustable class.
|
||||||
|
*/
|
||||||
|
public static void setScrollPaneAdjustableAccessor(ScrollPaneAdjustableAccessor adj) {
|
||||||
|
scrollPaneAdjustableAccessor = adj;
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Retrieve the accessor object for the java.awt.ScrollPaneAdjustable
|
||||||
|
* class.
|
||||||
|
*/
|
||||||
|
public static ScrollPaneAdjustableAccessor getScrollPaneAdjustableAccessor() {
|
||||||
|
if (scrollPaneAdjustableAccessor == null) {
|
||||||
|
unsafe.ensureClassInitialized(ScrollPaneAdjustable.class);
|
||||||
|
}
|
||||||
|
return scrollPaneAdjustableAccessor;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -570,7 +570,7 @@ public class FilePane extends JPanel implements PropertyChangeListener {
|
|||||||
public JPanel createList() {
|
public JPanel createList() {
|
||||||
JPanel p = new JPanel(new BorderLayout());
|
JPanel p = new JPanel(new BorderLayout());
|
||||||
final JFileChooser fileChooser = getFileChooser();
|
final JFileChooser fileChooser = getFileChooser();
|
||||||
final JList list = new JList() {
|
final JList<Object> list = new JList<Object>() {
|
||||||
public int getNextMatch(String prefix, int startIndex, Position.Bias bias) {
|
public int getNextMatch(String prefix, int startIndex, Position.Bias bias) {
|
||||||
ListModel model = getModel();
|
ListModel model = getModel();
|
||||||
int max = model.getSize();
|
int max = model.getSize();
|
||||||
@ -641,7 +641,7 @@ public class FilePane extends JPanel implements PropertyChangeListener {
|
|||||||
/**
|
/**
|
||||||
* This model allows for sorting JList
|
* This model allows for sorting JList
|
||||||
*/
|
*/
|
||||||
private class SortableListModel extends AbstractListModel
|
private class SortableListModel extends AbstractListModel<Object>
|
||||||
implements TableModelListener, RowSorterListener {
|
implements TableModelListener, RowSorterListener {
|
||||||
|
|
||||||
public SortableListModel() {
|
public SortableListModel() {
|
||||||
|
@ -60,7 +60,7 @@ import sun.swing.*;
|
|||||||
*/
|
*/
|
||||||
public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
||||||
private JLabel lookInLabel;
|
private JLabel lookInLabel;
|
||||||
private JComboBox directoryComboBox;
|
private JComboBox<File> directoryComboBox;
|
||||||
private DirectoryComboBoxModel directoryComboBoxModel;
|
private DirectoryComboBoxModel directoryComboBoxModel;
|
||||||
private Action directoryComboBoxAction = new DirectoryComboBoxAction();
|
private Action directoryComboBoxAction = new DirectoryComboBoxAction();
|
||||||
|
|
||||||
@ -77,10 +77,9 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
private JPanel buttonPanel;
|
private JPanel buttonPanel;
|
||||||
private JPanel bottomPanel;
|
private JPanel bottomPanel;
|
||||||
|
|
||||||
private JComboBox filterComboBox;
|
private JComboBox<FileFilter> filterComboBox;
|
||||||
|
|
||||||
private static final Dimension hstrut5 = new Dimension(5, 1);
|
private static final Dimension hstrut5 = new Dimension(5, 1);
|
||||||
private static final Dimension vstrut5 = new Dimension(1, 5);
|
|
||||||
|
|
||||||
private static final Insets shrinkwrap = new Insets(0,0,0,0);
|
private static final Insets shrinkwrap = new Insets(0,0,0,0);
|
||||||
|
|
||||||
@ -217,7 +216,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
topPanel.add(lookInLabel, BorderLayout.BEFORE_LINE_BEGINS);
|
topPanel.add(lookInLabel, BorderLayout.BEFORE_LINE_BEGINS);
|
||||||
|
|
||||||
// CurrentDir ComboBox
|
// CurrentDir ComboBox
|
||||||
directoryComboBox = new JComboBox();
|
directoryComboBox = new JComboBox<File>();
|
||||||
directoryComboBox.getAccessibleContext().setAccessibleDescription(lookInLabelText);
|
directoryComboBox.getAccessibleContext().setAccessibleDescription(lookInLabelText);
|
||||||
directoryComboBox.putClientProperty( "JComboBox.isTableCellEditor", Boolean.TRUE );
|
directoryComboBox.putClientProperty( "JComboBox.isTableCellEditor", Boolean.TRUE );
|
||||||
lookInLabel.setLabelFor(directoryComboBox);
|
lookInLabel.setLabelFor(directoryComboBox);
|
||||||
@ -394,7 +393,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
|
|
||||||
filterComboBoxModel = createFilterComboBoxModel();
|
filterComboBoxModel = createFilterComboBoxModel();
|
||||||
fc.addPropertyChangeListener(filterComboBoxModel);
|
fc.addPropertyChangeListener(filterComboBoxModel);
|
||||||
filterComboBox = new JComboBox(filterComboBoxModel);
|
filterComboBox = new JComboBox<FileFilter>(filterComboBoxModel);
|
||||||
filterComboBox.getAccessibleContext().setAccessibleDescription(filesOfTypeLabelText);
|
filterComboBox.getAccessibleContext().setAccessibleDescription(filesOfTypeLabelText);
|
||||||
filesOfTypeLabel.setLabelFor(filterComboBox);
|
filesOfTypeLabel.setLabelFor(filterComboBox);
|
||||||
filterComboBox.setRenderer(createFilterComboBoxRenderer());
|
filterComboBox.setRenderer(createFilterComboBoxRenderer());
|
||||||
@ -671,16 +670,16 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
// looking combo boxes.
|
// looking combo boxes.
|
||||||
// So what we do here is delegate most jobs to the "real" or original renderer,
|
// So what we do here is delegate most jobs to the "real" or original renderer,
|
||||||
// and simply monkey with the icon and text of the renderer.
|
// and simply monkey with the icon and text of the renderer.
|
||||||
private class DirectoryComboBoxRenderer implements ListCellRenderer {
|
private class DirectoryComboBoxRenderer implements ListCellRenderer<File> {
|
||||||
private ListCellRenderer delegate;
|
private ListCellRenderer<? super File> delegate;
|
||||||
IndentIcon ii = new IndentIcon();
|
IndentIcon ii = new IndentIcon();
|
||||||
|
|
||||||
private DirectoryComboBoxRenderer(ListCellRenderer delegate) {
|
private DirectoryComboBoxRenderer(ListCellRenderer<? super File> delegate) {
|
||||||
this.delegate = delegate;
|
this.delegate = delegate;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) {
|
public Component getListCellRendererComponent(JList<? extends File> list, File value, int index, boolean isSelected, boolean cellHasFocus) {
|
||||||
Component c = delegate.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
|
Component c = delegate.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
|
||||||
|
|
||||||
assert c instanceof JLabel;
|
assert c instanceof JLabel;
|
||||||
@ -689,9 +688,8 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
label.setText("");
|
label.setText("");
|
||||||
return label;
|
return label;
|
||||||
}
|
}
|
||||||
File directory = (File) value;
|
label.setText(getFileChooser().getName(value));
|
||||||
label.setText(getFileChooser().getName(directory));
|
Icon icon = getFileChooser().getIcon(value);
|
||||||
Icon icon = getFileChooser().getIcon(directory);
|
|
||||||
ii.icon = icon;
|
ii.icon = icon;
|
||||||
ii.depth = directoryComboBoxModel.getDepth(index);
|
ii.depth = directoryComboBoxModel.getDepth(index);
|
||||||
label.setIcon(ii);
|
label.setIcon(ii);
|
||||||
@ -736,7 +734,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
/**
|
/**
|
||||||
* Data model for a type-face selection combo-box.
|
* Data model for a type-face selection combo-box.
|
||||||
*/
|
*/
|
||||||
protected class DirectoryComboBoxModel extends AbstractListModel implements ComboBoxModel {
|
protected class DirectoryComboBoxModel extends AbstractListModel<File> implements ComboBoxModel<File> {
|
||||||
Vector<File> directories = new Vector<File>();
|
Vector<File> directories = new Vector<File>();
|
||||||
int[] depths = null;
|
int[] depths = null;
|
||||||
File selectedDirectory = null;
|
File selectedDirectory = null;
|
||||||
@ -857,7 +855,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
return directories.size();
|
return directories.size();
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getElementAt(int index) {
|
public File getElementAt(int index) {
|
||||||
return directories.elementAt(index);
|
return directories.elementAt(index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -890,18 +888,19 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
/**
|
/**
|
||||||
* Render different type sizes and styles.
|
* Render different type sizes and styles.
|
||||||
*/
|
*/
|
||||||
public class FilterComboBoxRenderer implements ListCellRenderer {
|
public class FilterComboBoxRenderer implements ListCellRenderer<FileFilter> {
|
||||||
private ListCellRenderer delegate;
|
private ListCellRenderer<? super FileFilter> delegate;
|
||||||
private FilterComboBoxRenderer(ListCellRenderer delegate) {
|
private FilterComboBoxRenderer(ListCellRenderer<? super FileFilter> delegate) {
|
||||||
this.delegate = delegate;
|
this.delegate = delegate;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Component getListCellRendererComponent(JList list, Object value, int index, boolean isSelected, boolean cellHasFocus) {
|
public Component getListCellRendererComponent(JList<? extends FileFilter> list, FileFilter value, int index,
|
||||||
|
boolean isSelected, boolean cellHasFocus) {
|
||||||
Component c = delegate.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
|
Component c = delegate.getListCellRendererComponent(list, value, index, isSelected, cellHasFocus);
|
||||||
|
|
||||||
String text = null;
|
String text = null;
|
||||||
if (value != null && value instanceof FileFilter) {
|
if (value != null) {
|
||||||
text = ((FileFilter) value).getDescription();
|
text = value.getDescription();
|
||||||
}
|
}
|
||||||
|
|
||||||
//this should always be true, since SynthComboBoxUI's SynthComboBoxRenderer
|
//this should always be true, since SynthComboBoxUI's SynthComboBoxRenderer
|
||||||
@ -924,7 +923,8 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
/**
|
/**
|
||||||
* Data model for a type-face selection combo-box.
|
* Data model for a type-face selection combo-box.
|
||||||
*/
|
*/
|
||||||
protected class FilterComboBoxModel extends AbstractListModel implements ComboBoxModel, PropertyChangeListener {
|
protected class FilterComboBoxModel extends AbstractListModel<FileFilter> implements ComboBoxModel<FileFilter>,
|
||||||
|
PropertyChangeListener {
|
||||||
protected FileFilter[] filters;
|
protected FileFilter[] filters;
|
||||||
protected FilterComboBoxModel() {
|
protected FilterComboBoxModel() {
|
||||||
super();
|
super();
|
||||||
@ -977,7 +977,7 @@ public class SynthFileChooserUIImpl extends SynthFileChooserUI {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Object getElementAt(int index) {
|
public FileFilter getElementAt(int index) {
|
||||||
if(index > getSize() - 1) {
|
if(index > getSize() - 1) {
|
||||||
// This shouldn't happen. Try to recover gracefully.
|
// This shouldn't happen. Try to recover gracefully.
|
||||||
return getFileChooser().getFileFilter();
|
return getFileChooser().getFileFilter();
|
||||||
|
@ -47,15 +47,7 @@ import java.util.concurrent.ExecutionException;
|
|||||||
import java.util.concurrent.FutureTask;
|
import java.util.concurrent.FutureTask;
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
import javax.swing.BorderFactory;
|
import javax.swing.*;
|
||||||
import javax.swing.CellRendererPane;
|
|
||||||
import javax.swing.JTextField;
|
|
||||||
import javax.swing.JTextArea;
|
|
||||||
import javax.swing.JEditorPane;
|
|
||||||
import javax.swing.JViewport;
|
|
||||||
import javax.swing.JScrollPane;
|
|
||||||
import javax.swing.JTextPane;
|
|
||||||
import javax.swing.SwingUtilities;
|
|
||||||
import javax.swing.border.Border;
|
import javax.swing.border.Border;
|
||||||
import javax.swing.border.TitledBorder;
|
import javax.swing.border.TitledBorder;
|
||||||
import javax.swing.text.BadLocationException;
|
import javax.swing.text.BadLocationException;
|
||||||
@ -336,7 +328,22 @@ public class TextComponentPrintable implements CountingPrintable {
|
|||||||
assert SwingUtilities.isEventDispatchThread();
|
assert SwingUtilities.isEventDispatchThread();
|
||||||
|
|
||||||
JTextComponent ret = null;
|
JTextComponent ret = null;
|
||||||
if (textComponent instanceof JTextField) {
|
if (textComponent instanceof JPasswordField) {
|
||||||
|
ret =
|
||||||
|
new JPasswordField() {
|
||||||
|
{
|
||||||
|
setEchoChar(((JPasswordField) textComponent).getEchoChar());
|
||||||
|
setHorizontalAlignment(
|
||||||
|
((JTextField) textComponent).getHorizontalAlignment());
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public FontMetrics getFontMetrics(Font font) {
|
||||||
|
return (frc.get() == null)
|
||||||
|
? super.getFontMetrics(font)
|
||||||
|
: FontDesignMetrics.getMetrics(font, frc.get());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
} else if (textComponent instanceof JTextField) {
|
||||||
ret =
|
ret =
|
||||||
new JTextField() {
|
new JTextField() {
|
||||||
{
|
{
|
||||||
|
@ -2690,6 +2690,7 @@ public class BidiBase {
|
|||||||
public void setPara(AttributedCharacterIterator paragraph)
|
public void setPara(AttributedCharacterIterator paragraph)
|
||||||
{
|
{
|
||||||
byte paraLvl;
|
byte paraLvl;
|
||||||
|
char ch = paragraph.first();
|
||||||
Boolean runDirection =
|
Boolean runDirection =
|
||||||
(Boolean) paragraph.getAttribute(TextAttributeConstants.RUN_DIRECTION);
|
(Boolean) paragraph.getAttribute(TextAttributeConstants.RUN_DIRECTION);
|
||||||
Object shaper = paragraph.getAttribute(TextAttributeConstants.NUMERIC_SHAPING);
|
Object shaper = paragraph.getAttribute(TextAttributeConstants.NUMERIC_SHAPING);
|
||||||
@ -2705,7 +2706,6 @@ public class BidiBase {
|
|||||||
byte[] embeddingLevels = new byte[len];
|
byte[] embeddingLevels = new byte[len];
|
||||||
char[] txt = new char[len];
|
char[] txt = new char[len];
|
||||||
int i = 0;
|
int i = 0;
|
||||||
char ch = paragraph.first();
|
|
||||||
while (ch != AttributedCharacterIterator.DONE) {
|
while (ch != AttributedCharacterIterator.DONE) {
|
||||||
txt[i] = ch;
|
txt[i] = ch;
|
||||||
Integer embedding =
|
Integer embedding =
|
||||||
@ -3411,18 +3411,21 @@ public class BidiBase {
|
|||||||
* Display the bidi internal state, used in debugging.
|
* Display the bidi internal state, used in debugging.
|
||||||
*/
|
*/
|
||||||
public String toString() {
|
public String toString() {
|
||||||
StringBuffer buf = new StringBuffer(super.toString());
|
StringBuilder buf = new StringBuilder(getClass().getName());
|
||||||
|
|
||||||
buf.append("[dir: " + direction);
|
buf.append("[dir: ");
|
||||||
buf.append(" baselevel: " + paraLevel);
|
buf.append(direction);
|
||||||
buf.append(" length: " + length);
|
buf.append(" baselevel: ");
|
||||||
|
buf.append(paraLevel);
|
||||||
|
buf.append(" length: ");
|
||||||
|
buf.append(length);
|
||||||
buf.append(" runs: ");
|
buf.append(" runs: ");
|
||||||
if (levels == null) {
|
if (levels == null) {
|
||||||
buf.append("null");
|
buf.append("none");
|
||||||
} else {
|
} else {
|
||||||
buf.append('[');
|
buf.append('[');
|
||||||
buf.append(levels[0]);
|
buf.append(levels[0]);
|
||||||
for (int i = 0; i < levels.length; i++) {
|
for (int i = 1; i < levels.length; i++) {
|
||||||
buf.append(' ');
|
buf.append(' ');
|
||||||
buf.append(levels[i]);
|
buf.append(levels[i]);
|
||||||
}
|
}
|
||||||
@ -3430,12 +3433,11 @@ public class BidiBase {
|
|||||||
}
|
}
|
||||||
buf.append(" text: [0x");
|
buf.append(" text: [0x");
|
||||||
buf.append(Integer.toHexString(text[0]));
|
buf.append(Integer.toHexString(text[0]));
|
||||||
for (int i = 0; i < text.length; i++) {
|
for (int i = 1; i < text.length; i++) {
|
||||||
buf.append(" 0x");
|
buf.append(" 0x");
|
||||||
buf.append(Integer.toHexString(text[i]));
|
buf.append(Integer.toHexString(text[i]));
|
||||||
}
|
}
|
||||||
buf.append(']');
|
buf.append("]]");
|
||||||
buf.append(']');
|
|
||||||
|
|
||||||
return buf.toString();
|
return buf.toString();
|
||||||
}
|
}
|
||||||
|
@ -33,12 +33,9 @@ import java.awt.event.ActionEvent;
|
|||||||
import javax.swing.plaf.basic.*;
|
import javax.swing.plaf.basic.*;
|
||||||
import javax.swing.SwingUtilities;
|
import javax.swing.SwingUtilities;
|
||||||
import javax.swing.SwingConstants;
|
import javax.swing.SwingConstants;
|
||||||
|
|
||||||
public class XButtonPeer extends XComponentPeer implements ButtonPeer {
|
public class XButtonPeer extends XComponentPeer implements ButtonPeer {
|
||||||
|
private boolean pressed;
|
||||||
boolean pressed;
|
private boolean armed;
|
||||||
boolean armed;
|
|
||||||
|
|
||||||
private Insets focusInsets;
|
private Insets focusInsets;
|
||||||
private Insets borderInsets;
|
private Insets borderInsets;
|
||||||
private Insets contentAreaInsets;
|
private Insets contentAreaInsets;
|
||||||
@ -86,11 +83,6 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
|
|||||||
this.label = label;
|
this.label = label;
|
||||||
repaint();
|
repaint();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void paint(Graphics g) {
|
|
||||||
paint(g,target);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setBackground(Color c) {
|
public void setBackground(Color c) {
|
||||||
updateMotifColors(c);
|
updateMotifColors(c);
|
||||||
super.setBackground(c);
|
super.setBackground(c);
|
||||||
@ -133,16 +125,10 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
|
|||||||
case MouseEvent.MOUSE_ENTERED:
|
case MouseEvent.MOUSE_ENTERED:
|
||||||
if (pressed)
|
if (pressed)
|
||||||
armed = true;
|
armed = true;
|
||||||
// repaint();
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case MouseEvent.MOUSE_EXITED:
|
case MouseEvent.MOUSE_EXITED:
|
||||||
armed = false;
|
armed = false;
|
||||||
// repaint();
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -209,18 +195,14 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
|
|||||||
public Dimension minimumSize() {
|
public Dimension minimumSize() {
|
||||||
return getMinimumSize();
|
return getMinimumSize();
|
||||||
}
|
}
|
||||||
|
/**
|
||||||
|
* This method is called from Toolkit Thread and so it should not call any
|
||||||
/*
|
* client code.
|
||||||
This method is called from Toolkit Thread and so it should not call any client code
|
|
||||||
|
|
||||||
*/
|
*/
|
||||||
public void paint(Graphics g, Component c)
|
@Override
|
||||||
{
|
void paintPeer(final Graphics g) {
|
||||||
if (!disposed && (g != null))
|
if (!disposed) {
|
||||||
{
|
|
||||||
Dimension size = getPeerSize();
|
Dimension size = getPeerSize();
|
||||||
|
|
||||||
g.setColor( getPeerBackground() ); /* erase the existing button remains */
|
g.setColor( getPeerBackground() ); /* erase the existing button remains */
|
||||||
g.fillRect(0,0, size.width , size.height);
|
g.fillRect(0,0, size.width , size.height);
|
||||||
paintBorder(g,borderInsets.left,
|
paintBorder(g,borderInsets.left,
|
||||||
@ -239,11 +221,9 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
|
|||||||
|
|
||||||
viewRect.width = size.width - (contentAreaInsets.left+contentAreaInsets.right);
|
viewRect.width = size.width - (contentAreaInsets.left+contentAreaInsets.right);
|
||||||
viewRect.height = size.height - (contentAreaInsets.top+contentAreaInsets.bottom);
|
viewRect.height = size.height - (contentAreaInsets.top+contentAreaInsets.bottom);
|
||||||
|
|
||||||
viewRect.x = contentAreaInsets.left;
|
viewRect.x = contentAreaInsets.left;
|
||||||
viewRect.y = contentAreaInsets.right;
|
viewRect.y = contentAreaInsets.top;
|
||||||
String llabel = (label != null) ? label : "";
|
String llabel = (label != null) ? label : "";
|
||||||
|
|
||||||
// layout the text and icon
|
// layout the text and icon
|
||||||
String text = SwingUtilities.layoutCompoundLabel(
|
String text = SwingUtilities.layoutCompoundLabel(
|
||||||
fm, llabel, null,
|
fm, llabel, null,
|
||||||
@ -309,10 +289,9 @@ public class XButtonPeer extends XComponentPeer implements ButtonPeer {
|
|||||||
else {
|
else {
|
||||||
/*** paint the text disabled ***/
|
/*** paint the text disabled ***/
|
||||||
g.setColor(getPeerBackground().brighter());
|
g.setColor(getPeerBackground().brighter());
|
||||||
|
|
||||||
BasicGraphicsUtils.drawStringUnderlineCharAt(g,text, mnemonicIndex,
|
BasicGraphicsUtils.drawStringUnderlineCharAt(g,text, mnemonicIndex,
|
||||||
textRect.x, textRect.y + fm.getAscent());
|
textRect.x, textRect.y + fm.getAscent());
|
||||||
g.setColor(c.getBackground().darker());
|
g.setColor(getPeerBackground().darker());
|
||||||
BasicGraphicsUtils.drawStringUnderlineCharAt(g,text, mnemonicIndex,
|
BasicGraphicsUtils.drawStringUnderlineCharAt(g,text, mnemonicIndex,
|
||||||
textRect.x - 1, textRect.y + fm.getAscent() - 1);
|
textRect.x - 1, textRect.y + fm.getAscent() - 1);
|
||||||
}
|
}
|
||||||
|
@ -297,19 +297,15 @@ class XCheckboxPeer extends XComponentPeer implements CheckboxPeer {
|
|||||||
|
|
||||||
double fsize = (double) checkBoxSize;
|
double fsize = (double) checkBoxSize;
|
||||||
myCheckMark = AffineTransform.getScaleInstance(fsize / MASTER_SIZE, fsize / MASTER_SIZE).createTransformedShape(MASTER_CHECKMARK);
|
myCheckMark = AffineTransform.getScaleInstance(fsize / MASTER_SIZE, fsize / MASTER_SIZE).createTransformedShape(MASTER_CHECKMARK);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
public void paint(Graphics g) {
|
void paintPeer(final Graphics g) {
|
||||||
if (g != null) {
|
|
||||||
//layout();
|
//layout();
|
||||||
Dimension size = getPeerSize();
|
Dimension size = getPeerSize();
|
||||||
Font f = getPeerFont();
|
Font f = getPeerFont();
|
||||||
|
|
||||||
flush();
|
flush();
|
||||||
g.setColor(getPeerBackground()); // erase the existing button
|
g.setColor(getPeerBackground()); // erase the existing button
|
||||||
g.fillRect(0,0, size.width, size.height);
|
g.fillRect(0,0, size.width, size.height);
|
||||||
|
|
||||||
if (label != null) {
|
if (label != null) {
|
||||||
g.setFont(f);
|
g.setFont(f);
|
||||||
paintText(g, textRect, label);
|
paintText(g, textRect, label);
|
||||||
@ -322,7 +318,6 @@ class XCheckboxPeer extends XComponentPeer implements CheckboxPeer {
|
|||||||
focusRect.width,
|
focusRect.width,
|
||||||
focusRect.height);
|
focusRect.height);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Paint the checkbox or radio button
|
// Paint the checkbox or radio button
|
||||||
if (checkBoxGroup == null) {
|
if (checkBoxGroup == null) {
|
||||||
paintCheckbox(g, cbX, cbY, checkBoxSize, checkBoxSize);
|
paintCheckbox(g, cbX, cbY, checkBoxSize, checkBoxSize);
|
||||||
@ -330,8 +325,6 @@ class XCheckboxPeer extends XComponentPeer implements CheckboxPeer {
|
|||||||
else {
|
else {
|
||||||
paintRadioButton(g, cbX, cbY, checkBoxSize, checkBoxSize);
|
paintRadioButton(g, cbX, cbY, checkBoxSize, checkBoxSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
|
||||||
flush();
|
flush();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -550,10 +550,10 @@ public class XChoicePeer extends XComponentPeer implements ChoicePeer, ToplevelS
|
|||||||
/**
|
/**
|
||||||
* Paint the choice
|
* Paint the choice
|
||||||
*/
|
*/
|
||||||
public void paint(Graphics g) {
|
@Override
|
||||||
|
void paintPeer(final Graphics g) {
|
||||||
flush();
|
flush();
|
||||||
Dimension size = getPeerSize();
|
Dimension size = getPeerSize();
|
||||||
|
|
||||||
// TODO: when mouse is down over button, widget should be drawn depressed
|
// TODO: when mouse is down over button, widget should be drawn depressed
|
||||||
g.setColor(getPeerBackground());
|
g.setColor(getPeerBackground());
|
||||||
g.fillRect(0, 0, width, height);
|
g.fillRect(0, 0, width, height);
|
||||||
@ -912,16 +912,22 @@ public class XChoicePeer extends XComponentPeer implements ChoicePeer, ToplevelS
|
|||||||
/*
|
/*
|
||||||
* fillRect with current Background color on the whole dropdown list.
|
* fillRect with current Background color on the whole dropdown list.
|
||||||
*/
|
*/
|
||||||
public void paintBackground(){
|
public void paintBackground() {
|
||||||
Graphics g = getGraphics();
|
final Graphics g = getGraphics();
|
||||||
|
if (g != null) {
|
||||||
|
try {
|
||||||
g.setColor(getPeerBackground());
|
g.setColor(getPeerBackground());
|
||||||
g.fillRect(0, 0, width, height);
|
g.fillRect(0, 0, width, height);
|
||||||
|
} finally {
|
||||||
|
g.dispose();
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 6405689. In some cases we should erase background to eliminate painting
|
* 6405689. In some cases we should erase background to eliminate painting
|
||||||
* artefacts.
|
* artefacts.
|
||||||
*/
|
*/
|
||||||
|
@Override
|
||||||
public void repaint() {
|
public void repaint() {
|
||||||
if (!isVisible()) {
|
if (!isVisible()) {
|
||||||
return;
|
return;
|
||||||
@ -931,8 +937,8 @@ public class XChoicePeer extends XComponentPeer implements ChoicePeer, ToplevelS
|
|||||||
}
|
}
|
||||||
super.repaint();
|
super.repaint();
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
public void paint(Graphics g) {
|
public void paintPeer(Graphics g) {
|
||||||
//System.out.println("UC.paint()");
|
//System.out.println("UC.paint()");
|
||||||
Choice choice = (Choice)target;
|
Choice choice = (Choice)target;
|
||||||
Color colors[] = XChoicePeer.this.getGUIcolors();
|
Color colors[] = XChoicePeer.this.getGUIcolors();
|
||||||
|
@ -38,7 +38,6 @@ import java.awt.Graphics;
|
|||||||
import java.awt.GraphicsConfiguration;
|
import java.awt.GraphicsConfiguration;
|
||||||
import java.awt.Image;
|
import java.awt.Image;
|
||||||
import java.awt.Insets;
|
import java.awt.Insets;
|
||||||
import java.awt.KeyboardFocusManager;
|
|
||||||
import java.awt.Rectangle;
|
import java.awt.Rectangle;
|
||||||
import java.awt.SystemColor;
|
import java.awt.SystemColor;
|
||||||
import java.awt.Toolkit;
|
import java.awt.Toolkit;
|
||||||
@ -59,15 +58,11 @@ import java.awt.image.ImageProducer;
|
|||||||
import java.awt.image.VolatileImage;
|
import java.awt.image.VolatileImage;
|
||||||
import java.awt.peer.ComponentPeer;
|
import java.awt.peer.ComponentPeer;
|
||||||
import java.awt.peer.ContainerPeer;
|
import java.awt.peer.ContainerPeer;
|
||||||
import java.awt.peer.LightweightPeer;
|
|
||||||
import java.lang.reflect.*;
|
import java.lang.reflect.*;
|
||||||
import java.security.*;
|
import java.security.*;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.HashSet;
|
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.Vector;
|
|
||||||
import sun.util.logging.PlatformLogger;
|
import sun.util.logging.PlatformLogger;
|
||||||
|
|
||||||
import sun.awt.*;
|
import sun.awt.*;
|
||||||
import sun.awt.event.IgnorePaintEvent;
|
import sun.awt.event.IgnorePaintEvent;
|
||||||
import sun.awt.image.SunVolatileImage;
|
import sun.awt.image.SunVolatileImage;
|
||||||
@ -428,27 +423,23 @@ public class XComponentPeer extends XWindow implements ComponentPeer, DropTarget
|
|||||||
public void disable() {
|
public void disable() {
|
||||||
setEnabled(false);
|
setEnabled(false);
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
public void paint(Graphics g) {
|
public void paint(final Graphics g) {
|
||||||
|
super.paint(g);
|
||||||
|
// allow target to change the picture
|
||||||
|
target.paint(g);
|
||||||
}
|
}
|
||||||
public void repaint(long tm, int x, int y, int width, int height) {
|
|
||||||
repaint();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public Graphics getGraphics() {
|
public Graphics getGraphics() {
|
||||||
return getGraphics(surfaceData, getPeerForeground(), getPeerBackground(), getPeerFont());
|
return getGraphics(surfaceData, getPeerForeground(), getPeerBackground(), getPeerFont());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public void print(Graphics g) {
|
public void print(Graphics g) {
|
||||||
// clear rect here to emulate X clears rect before Expose
|
// clear rect here to emulate X clears rect before Expose
|
||||||
g.setColor(target.getBackground());
|
g.setColor(target.getBackground());
|
||||||
g.fillRect(0, 0, target.getWidth(), target.getHeight());
|
g.fillRect(0, 0, target.getWidth(), target.getHeight());
|
||||||
g.setColor(target.getForeground());
|
g.setColor(target.getForeground());
|
||||||
// paint peer
|
// paint peer
|
||||||
paint(g);
|
paintPeer(g);
|
||||||
// allow target to change the picture
|
// allow target to change the picture
|
||||||
target.print(g);
|
target.print(g);
|
||||||
}
|
}
|
||||||
|
@ -85,7 +85,8 @@ class XLabelPeer extends XComponentPeer implements LabelPeer {
|
|||||||
*/
|
*/
|
||||||
// NOTE: This method is called by privileged threads.
|
// NOTE: This method is called by privileged threads.
|
||||||
// DO NOT INVOKE CLIENT CODE ON THIS THREAD!
|
// DO NOT INVOKE CLIENT CODE ON THIS THREAD!
|
||||||
public void paint(Graphics g) {
|
@Override
|
||||||
|
void paintPeer(final Graphics g) {
|
||||||
int textX = 0;
|
int textX = 0;
|
||||||
int textY = 0;
|
int textY = 0;
|
||||||
g.setColor(getPeerBackground());
|
g.setColor(getPeerBackground());
|
||||||
|
@ -363,9 +363,7 @@ class XListPeer extends XComponentPeer implements ListPeer, XScrollbarClient {
|
|||||||
return Math.min(items.size()-1, itemsInWindow()-1);
|
return Math.min(items.size()-1, itemsInWindow()-1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void repaintScrollbarRequest(XScrollbar scrollbar) {
|
public void repaintScrollbarRequest(XScrollbar scrollbar) {
|
||||||
Graphics g = getGraphics();
|
|
||||||
if (scrollbar == hsb) {
|
if (scrollbar == hsb) {
|
||||||
repaint(PAINT_HSCROLL);
|
repaint(PAINT_HSCROLL);
|
||||||
}
|
}
|
||||||
@ -373,9 +371,6 @@ class XListPeer extends XComponentPeer implements ListPeer, XScrollbarClient {
|
|||||||
repaint(PAINT_VSCROLL);
|
repaint(PAINT_VSCROLL);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Overridden for performance
|
* Overridden for performance
|
||||||
*/
|
*/
|
||||||
@ -410,18 +405,20 @@ class XListPeer extends XComponentPeer implements ListPeer, XScrollbarClient {
|
|||||||
* @param distance the distance to copy the source area
|
* @param distance the distance to copy the source area
|
||||||
*/
|
*/
|
||||||
private void repaint(int firstItem, int lastItem, int options, Rectangle source, Point distance) {
|
private void repaint(int firstItem, int lastItem, int options, Rectangle source, Point distance) {
|
||||||
Graphics g = getGraphics();
|
final Graphics g = getGraphics();
|
||||||
|
if (g != null) {
|
||||||
try {
|
try {
|
||||||
painter.paint(g, firstItem, lastItem, options, source, distance);
|
painter.paint(g, firstItem, lastItem, options, source, distance);
|
||||||
|
target.paint(g);
|
||||||
} finally {
|
} finally {
|
||||||
g.dispose();
|
g.dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
public void paint(Graphics g) {
|
@Override
|
||||||
|
void paintPeer(final Graphics g) {
|
||||||
painter.paint(g, getFirstVisibleItem(), getLastVisibleItem(), PAINT_ALL);
|
painter.paint(g, getFirstVisibleItem(), getLastVisibleItem(), PAINT_ALL);
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isFocusable() { return true; }
|
public boolean isFocusable() { return true; }
|
||||||
|
|
||||||
// TODO: share/promote the Focus methods?
|
// TODO: share/promote the Focus methods?
|
||||||
|
@ -415,7 +415,7 @@ public class XMenuBarPeer extends XBaseMenuWindow implements MenuBarPeer {
|
|||||||
* Overriden XWindow painting & printing
|
* Overriden XWindow painting & printing
|
||||||
*
|
*
|
||||||
************************************************/
|
************************************************/
|
||||||
public void paint(Graphics g) {
|
public void paintPeer(Graphics g) {
|
||||||
resetColors();
|
resetColors();
|
||||||
/* Calculate menubar dimension. */
|
/* Calculate menubar dimension. */
|
||||||
int width = getWidth();
|
int width = getWidth();
|
||||||
|
@ -432,9 +432,9 @@ public class XMenuWindow extends XBaseMenuWindow {
|
|||||||
/**
|
/**
|
||||||
* Paints menu window
|
* Paints menu window
|
||||||
*/
|
*/
|
||||||
public void paint(Graphics g) {
|
@Override
|
||||||
|
public void paintPeer(Graphics g) {
|
||||||
resetColors();
|
resetColors();
|
||||||
|
|
||||||
int width = getWidth();
|
int width = getWidth();
|
||||||
int height = getHeight();
|
int height = getHeight();
|
||||||
|
|
||||||
|
@ -60,14 +60,13 @@ public class XPanelPeer extends XCanvasPeer implements PanelPeer {
|
|||||||
public Insets getInsets() {
|
public Insets getInsets() {
|
||||||
return new Insets(0, 0, 0, 0);
|
return new Insets(0, 0, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void paint(Graphics g) {
|
public void paint(Graphics g) {
|
||||||
super.paint(g);
|
super.paint(g);
|
||||||
/* SunGraphicsCallback.PaintHeavyweightComponentsCallback.getInstance().
|
SunGraphicsCallback.PaintHeavyweightComponentsCallback.getInstance().
|
||||||
runComponents(((Container)target).getComponents(), g,
|
runComponents(((Container)target).getComponents(), g,
|
||||||
SunGraphicsCallback.LIGHTWEIGHTS |
|
SunGraphicsCallback.LIGHTWEIGHTS |
|
||||||
SunGraphicsCallback.HEAVYWEIGHTS);
|
SunGraphicsCallback.HEAVYWEIGHTS);
|
||||||
*/ }
|
}
|
||||||
public void print(Graphics g) {
|
public void print(Graphics g) {
|
||||||
super.print(g);
|
super.print(g);
|
||||||
SunGraphicsCallback.PrintHeavyweightComponentsCallback.getInstance().
|
SunGraphicsCallback.PrintHeavyweightComponentsCallback.getInstance().
|
||||||
|
@ -53,9 +53,9 @@ class XRepaintArea extends RepaintArea {
|
|||||||
*/
|
*/
|
||||||
protected void updateComponent(Component comp, Graphics g) {
|
protected void updateComponent(Component comp, Graphics g) {
|
||||||
if (comp != null) {
|
if (comp != null) {
|
||||||
ComponentPeer peer = comp.getPeer();
|
final XComponentPeer peer = (XComponentPeer) comp.getPeer();
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
peer.paint(g);
|
peer.paintPeer(g);
|
||||||
}
|
}
|
||||||
super.updateComponent(comp, g);
|
super.updateComponent(comp, g);
|
||||||
}
|
}
|
||||||
@ -66,9 +66,9 @@ class XRepaintArea extends RepaintArea {
|
|||||||
*/
|
*/
|
||||||
protected void paintComponent(Component comp, Graphics g) {
|
protected void paintComponent(Component comp, Graphics g) {
|
||||||
if (comp != null) {
|
if (comp != null) {
|
||||||
ComponentPeer peer = comp.getPeer();
|
final XComponentPeer peer = (XComponentPeer) comp.getPeer();
|
||||||
if (peer != null) {
|
if (peer != null) {
|
||||||
peer.paint(g);
|
peer.paintPeer(g);
|
||||||
}
|
}
|
||||||
super.paintComponent(comp, g);
|
super.paintComponent(comp, g);
|
||||||
}
|
}
|
||||||
|
@ -29,6 +29,8 @@ import java.awt.*;
|
|||||||
import java.awt.event.*;
|
import java.awt.event.*;
|
||||||
import java.awt.peer.*;
|
import java.awt.peer.*;
|
||||||
import java.lang.reflect.*;
|
import java.lang.reflect.*;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.awt.SunToolkit;
|
import sun.awt.SunToolkit;
|
||||||
|
|
||||||
class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollbarClient {
|
class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollbarClient {
|
||||||
@ -41,9 +43,7 @@ class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollb
|
|||||||
public final static int VERTICAL = 1 << 0;
|
public final static int VERTICAL = 1 << 0;
|
||||||
public final static int HORIZONTAL = 1 << 1;
|
public final static int HORIZONTAL = 1 << 1;
|
||||||
|
|
||||||
private static Method m_setValue;
|
|
||||||
static {
|
static {
|
||||||
m_setValue = SunToolkit.getMethod(ScrollPaneAdjustable.class, "setTypedValue", new Class[] {Integer.TYPE, Integer.TYPE});
|
|
||||||
SCROLLBAR = XToolkit.getUIDefaults().getInt("ScrollBar.defaultWidth");
|
SCROLLBAR = XToolkit.getUIDefaults().getInt("ScrollBar.defaultWidth");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -293,18 +293,21 @@ class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollb
|
|||||||
setAdjustableValue(hadj, hsb.getValue(), type);
|
setAdjustableValue(hadj, hsb.getValue(), type);
|
||||||
sx = -(hsb.getValue());
|
sx = -(hsb.getValue());
|
||||||
Graphics g = getGraphics();
|
Graphics g = getGraphics();
|
||||||
|
if (g != null) {
|
||||||
try {
|
try {
|
||||||
paintHorScrollbar(g, colors, true);
|
paintHorScrollbar(g, colors, true);
|
||||||
} finally {
|
} finally {
|
||||||
g.dispose();
|
g.dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if ((flag & VERTICAL) != 0) {
|
if ((flag & VERTICAL) != 0) {
|
||||||
vsb.setValue(Math.min(y, vsb.getMaximum() - vsb.getVisibleAmount()));
|
vsb.setValue(Math.min(y, vsb.getMaximum() - vsb.getVisibleAmount()));
|
||||||
ScrollPaneAdjustable vadj = (ScrollPaneAdjustable)sp.getVAdjustable();
|
ScrollPaneAdjustable vadj = (ScrollPaneAdjustable)sp.getVAdjustable();
|
||||||
setAdjustableValue(vadj, vsb.getValue(), type);
|
setAdjustableValue(vadj, vsb.getValue(), type);
|
||||||
sy = -(vsb.getValue());
|
sy = -(vsb.getValue());
|
||||||
Graphics g = getGraphics();
|
Graphics g = getGraphics();
|
||||||
|
if (g != null) {
|
||||||
try {
|
try {
|
||||||
paintVerScrollbar(g, colors, true);
|
paintVerScrollbar(g, colors, true);
|
||||||
} finally {
|
} finally {
|
||||||
@ -312,29 +315,30 @@ class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollb
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
c.move(sx, sy);
|
c.move(sx, sy);
|
||||||
}
|
}
|
||||||
|
|
||||||
void setAdjustableValue(ScrollPaneAdjustable adj, int value, int type) {
|
private void setAdjustableValue(final ScrollPaneAdjustable adj, final int value,
|
||||||
try {
|
final int type) {
|
||||||
m_setValue.invoke(adj, new Object[] {Integer.valueOf(value), Integer.valueOf(type)});
|
AWTAccessor.getScrollPaneAdjustableAccessor().setTypedValue(adj, value,
|
||||||
} catch (IllegalAccessException iae) {
|
type);
|
||||||
adj.setValue(value);
|
|
||||||
} catch (IllegalArgumentException iae2) {
|
|
||||||
adj.setValue(value);
|
|
||||||
} catch (InvocationTargetException ite) {
|
|
||||||
adj.setValue(value);
|
|
||||||
ite.getCause().printStackTrace();
|
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
|
void paintPeer(final Graphics g) {
|
||||||
|
final Color[] colors = getGUIcolors();
|
||||||
|
g.setColor(colors[BACKGROUND_COLOR]);
|
||||||
|
final int h = height - hsbSpace;
|
||||||
|
final int w = width - vsbSpace;
|
||||||
|
g.fillRect(0, 0, w, h);
|
||||||
|
// paint rectangular region between scrollbars
|
||||||
|
g.fillRect(w, h, vsbSpace, hsbSpace);
|
||||||
|
if (MARGIN > 0) {
|
||||||
|
draw3DRect(g, colors, 0, 0, w - 1, h - 1, false);
|
||||||
}
|
}
|
||||||
|
paintScrollBars(g, colors);
|
||||||
|
|
||||||
public void paint(Graphics g) {
|
|
||||||
paintComponent(g);
|
|
||||||
}
|
}
|
||||||
|
private void paintScrollBars(Graphics g, Color[] colors) {
|
||||||
|
|
||||||
void paintScrollBars(Graphics g, Color[] colors) {
|
|
||||||
if (vsbSpace > 0) {
|
if (vsbSpace > 0) {
|
||||||
paintVerScrollbar(g, colors, true);
|
paintVerScrollbar(g, colors, true);
|
||||||
// paint the whole scrollbar
|
// paint the whole scrollbar
|
||||||
@ -345,51 +349,32 @@ class XScrollPanePeer extends XComponentPeer implements ScrollPanePeer, XScrollb
|
|||||||
// paint the whole scrollbar
|
// paint the whole scrollbar
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void repaintScrollBars() {
|
void repaintScrollBars() {
|
||||||
Graphics g = getGraphics();
|
Graphics g = getGraphics();
|
||||||
Color colors[] = getGUIcolors();
|
Color colors[] = getGUIcolors();
|
||||||
if (g != null) {
|
if (g != null) {
|
||||||
paintScrollBars(g,colors);
|
try {
|
||||||
}
|
paintScrollBars(g, colors);
|
||||||
|
} finally {
|
||||||
g.dispose();
|
g.dispose();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
public void repaintScrollbarRequest(XScrollbar sb) {
|
public void repaintScrollbarRequest(XScrollbar sb) {
|
||||||
Graphics g = getGraphics();
|
Graphics g = getGraphics();
|
||||||
Color colors[] = getGUIcolors();
|
Color colors[] = getGUIcolors();
|
||||||
if (g != null) {
|
if (g != null) {
|
||||||
|
try {
|
||||||
if (sb == vsb) {
|
if (sb == vsb) {
|
||||||
paintVerScrollbar(g,colors,true);
|
paintVerScrollbar(g, colors, true);
|
||||||
|
} else if (sb == hsb) {
|
||||||
|
paintHorScrollbar(g, colors, true);
|
||||||
}
|
}
|
||||||
else if (sb == hsb) {
|
} finally {
|
||||||
paintHorScrollbar(g,colors,true);
|
g.dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Paint the scrollpane.
|
|
||||||
*/
|
|
||||||
public void paintComponent(Graphics g) {
|
|
||||||
|
|
||||||
Color colors[] = getGUIcolors();
|
|
||||||
g.setColor(colors[BACKGROUND_COLOR]);
|
|
||||||
int h = height - hsbSpace;
|
|
||||||
int w = width - vsbSpace;
|
|
||||||
|
|
||||||
g.fillRect(0, 0, w, h);
|
|
||||||
|
|
||||||
// paint rectangular region between scrollbars
|
|
||||||
g.fillRect(w, h, vsbSpace, hsbSpace);
|
|
||||||
|
|
||||||
if (MARGIN > 0) {
|
|
||||||
draw3DRect(g, colors, 0, 0, w - 1, h - 1, false);
|
|
||||||
}
|
|
||||||
|
|
||||||
paintScrollBars(g,colors);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void handleEvent(java.awt.AWTEvent e) {
|
public void handleEvent(java.awt.AWTEvent e) {
|
||||||
super.handleEvent(e);
|
super.handleEvent(e);
|
||||||
|
|
||||||
|
@ -90,18 +90,12 @@ class XScrollbarPeer extends XComponentPeer implements ScrollbarPeer, XScrollbar
|
|||||||
? new Dimension(getDefaultDimension(), DEFAULT_LENGTH)
|
? new Dimension(getDefaultDimension(), DEFAULT_LENGTH)
|
||||||
: new Dimension(DEFAULT_LENGTH, getDefaultDimension());
|
: new Dimension(DEFAULT_LENGTH, getDefaultDimension());
|
||||||
}
|
}
|
||||||
|
|
||||||
public void repaint() {
|
|
||||||
Graphics g = getGraphics();
|
|
||||||
if (g != null) paint(g);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Paint the scrollbar.
|
* Paint the scrollbar.
|
||||||
*/
|
*/
|
||||||
public void paint(Graphics g) {
|
@Override
|
||||||
Scrollbar sb = (Scrollbar)target;
|
void paintPeer(final Graphics g) {
|
||||||
Color colors[] = getGUIcolors();
|
final Color[] colors = getGUIcolors();
|
||||||
g.setColor(colors[BACKGROUND_COLOR]);
|
g.setColor(colors[BACKGROUND_COLOR]);
|
||||||
tsb.paint(g, colors, true);
|
tsb.paint(g, colors, true);
|
||||||
// paint the whole scrollbar
|
// paint the whole scrollbar
|
||||||
|
@ -185,11 +185,8 @@ class XTextAreaPeer extends XComponentPeer implements TextAreaPeer {
|
|||||||
*/
|
*/
|
||||||
@Override
|
@Override
|
||||||
public void pSetCursor(Cursor cursor, boolean ignoreSubComponents) {
|
public void pSetCursor(Cursor cursor, boolean ignoreSubComponents) {
|
||||||
Point onScreen = getLocationOnScreen();
|
|
||||||
if (ignoreSubComponents ||
|
if (ignoreSubComponents ||
|
||||||
javaMouseEventHandler == null ||
|
javaMouseEventHandler == null) {
|
||||||
onScreen == null)
|
|
||||||
{
|
|
||||||
super.pSetCursor(cursor, true);
|
super.pSetCursor(cursor, true);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -197,6 +194,7 @@ class XTextAreaPeer extends XComponentPeer implements TextAreaPeer {
|
|||||||
Point cursorPos = new Point();
|
Point cursorPos = new Point();
|
||||||
((XGlobalCursorManager)XGlobalCursorManager.getCursorManager()).getCursorPos(cursorPos);
|
((XGlobalCursorManager)XGlobalCursorManager.getCursorManager()).getCursorPos(cursorPos);
|
||||||
|
|
||||||
|
final Point onScreen = getLocationOnScreen();
|
||||||
Point localPoint = new Point(cursorPos.x - onScreen.x, cursorPos.y - onScreen.y );
|
Point localPoint = new Point(cursorPos.x - onScreen.x, cursorPos.y - onScreen.y );
|
||||||
|
|
||||||
javaMouseEventHandler.setPointerToUnderPoint(localPoint);
|
javaMouseEventHandler.setPointerToUnderPoint(localPoint);
|
||||||
@ -300,15 +298,14 @@ class XTextAreaPeer extends XComponentPeer implements TextAreaPeer {
|
|||||||
* Paint the component
|
* Paint the component
|
||||||
* this method is called when the repaint instruction has been used
|
* this method is called when the repaint instruction has been used
|
||||||
*/
|
*/
|
||||||
|
|
||||||
public void repaint() {
|
public void repaint() {
|
||||||
if (textPane != null) {
|
if (textPane != null) {
|
||||||
//textPane.validate();
|
//textPane.validate();
|
||||||
textPane.repaint();
|
textPane.repaint();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
public void paint(Graphics g) {
|
void paintPeer(final Graphics g) {
|
||||||
if (textPane != null) {
|
if (textPane != null) {
|
||||||
textPane.paint(g);
|
textPane.paint(g);
|
||||||
}
|
}
|
||||||
|
@ -370,12 +370,11 @@ public class XTextFieldPeer extends XComponentPeer implements TextFieldPeer {
|
|||||||
public void repaint() {
|
public void repaint() {
|
||||||
if (xtext != null) xtext.repaint();
|
if (xtext != null) xtext.repaint();
|
||||||
}
|
}
|
||||||
|
@Override
|
||||||
public void paint(Graphics g) {
|
void paintPeer(final Graphics g) {
|
||||||
if (xtext != null) xtext.paint(g);
|
if (xtext != null) xtext.paint(g);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void print(Graphics g) {
|
public void print(Graphics g) {
|
||||||
if (xtext != null) {
|
if (xtext != null) {
|
||||||
xtext.print(g);
|
xtext.print(g);
|
||||||
|
@ -241,16 +241,19 @@ class XWarningWindow extends XWindow {
|
|||||||
Font getFont () {
|
Font getFont () {
|
||||||
return ownerWindow.getFont();
|
return ownerWindow.getFont();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
public void repaint() {
|
public void repaint() {
|
||||||
Rectangle bounds = getBounds();
|
final Rectangle bounds = getBounds();
|
||||||
Graphics g = getGraphics();
|
final Graphics g = getGraphics();
|
||||||
|
if (g != null) {
|
||||||
try {
|
try {
|
||||||
paint(g, 0, 0, bounds.width, bounds.height);
|
paint(g, 0, 0, bounds.width, bounds.height);
|
||||||
} finally {
|
} finally {
|
||||||
g.dispose();
|
g.dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
@Override
|
@Override
|
||||||
public void handleExposeEvent(XEvent xev) {
|
public void handleExposeEvent(XEvent xev) {
|
||||||
super.handleExposeEvent(xev);
|
super.handleExposeEvent(xev);
|
||||||
@ -263,13 +266,15 @@ class XWarningWindow extends XWindow {
|
|||||||
SunToolkit.executeOnEventHandlerThread(target,
|
SunToolkit.executeOnEventHandlerThread(target,
|
||||||
new Runnable() {
|
new Runnable() {
|
||||||
public void run() {
|
public void run() {
|
||||||
Graphics g = getGraphics();
|
final Graphics g = getGraphics();
|
||||||
|
if (g != null) {
|
||||||
try {
|
try {
|
||||||
paint(g, x, y, width, height);
|
paint(g, x, y, width, height);
|
||||||
} finally {
|
} finally {
|
||||||
g.dispose();
|
g.dispose();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -502,9 +502,8 @@ public class XWindow extends XBaseWindow implements X11ComponentPeer {
|
|||||||
public boolean isEmbedded() {
|
public boolean isEmbedded() {
|
||||||
return embedded;
|
return embedded;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void repaint(int x,int y, int width, int height) {
|
public void repaint(int x,int y, int width, int height) {
|
||||||
if (!isVisible()) {
|
if (!isVisible() || getWidth() == 0 || getHeight() == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Graphics g = getGraphics();
|
Graphics g = getGraphics();
|
||||||
@ -517,12 +516,11 @@ public class XWindow extends XBaseWindow implements X11ComponentPeer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
void repaint() {
|
||||||
public void repaint() {
|
if (!isVisible() || getWidth() == 0 || getHeight() == 0) {
|
||||||
if (!isVisible()) {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Graphics g = getGraphics();
|
final Graphics g = getGraphics();
|
||||||
if (g != null) {
|
if (g != null) {
|
||||||
try {
|
try {
|
||||||
paint(g);
|
paint(g);
|
||||||
@ -531,10 +529,13 @@ public class XWindow extends XBaseWindow implements X11ComponentPeer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
public void paint(final Graphics g) {
|
||||||
void paint(Graphics g) {
|
// paint peer
|
||||||
|
paintPeer(g);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void paintPeer(final Graphics g) {
|
||||||
|
}
|
||||||
//used by Peers to avoid flickering withing paint()
|
//used by Peers to avoid flickering withing paint()
|
||||||
protected void flush(){
|
protected void flush(){
|
||||||
XToolkit.awtLock();
|
XToolkit.awtLock();
|
||||||
|
@ -183,7 +183,9 @@ class WMenuItemPeer extends WObjectPeer implements MenuItemPeer {
|
|||||||
*/
|
*/
|
||||||
private static native void initIDs();
|
private static native void initIDs();
|
||||||
|
|
||||||
// Needed for MenuComponentPeer.
|
private native void _setFont(Font f);
|
||||||
public void setFont(Font f) {
|
|
||||||
|
public void setFont(final Font f) {
|
||||||
|
_setFont(f);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -27,6 +27,8 @@ package sun.awt.windows;
|
|||||||
import java.awt.*;
|
import java.awt.*;
|
||||||
import java.awt.event.AdjustmentEvent;
|
import java.awt.event.AdjustmentEvent;
|
||||||
import java.awt.peer.ScrollPanePeer;
|
import java.awt.peer.ScrollPanePeer;
|
||||||
|
|
||||||
|
import sun.awt.AWTAccessor;
|
||||||
import sun.awt.PeerEvent;
|
import sun.awt.PeerEvent;
|
||||||
|
|
||||||
import sun.util.logging.PlatformLogger;
|
import sun.util.logging.PlatformLogger;
|
||||||
@ -169,8 +171,6 @@ class WScrollPanePeer extends WPanelPeer implements ScrollPanePeer {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
native void setTypedValue(ScrollPaneAdjustable adjustable, int newpos, int type);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Runnable for the ScrollEvent that performs the adjustment.
|
* Runnable for the ScrollEvent that performs the adjustment.
|
||||||
*/
|
*/
|
||||||
@ -247,8 +247,9 @@ class WScrollPanePeer extends WPanelPeer implements ScrollPanePeer {
|
|||||||
// Fix for 4075484 - consider type information when creating AdjustmentEvent
|
// Fix for 4075484 - consider type information when creating AdjustmentEvent
|
||||||
// We can't just call adj.setValue() because it creates AdjustmentEvent with type=TRACK
|
// We can't just call adj.setValue() because it creates AdjustmentEvent with type=TRACK
|
||||||
// Instead, we call private method setTypedValue of ScrollPaneAdjustable.
|
// Instead, we call private method setTypedValue of ScrollPaneAdjustable.
|
||||||
// Because ScrollPaneAdjustable is in another package we should call it through native code.
|
AWTAccessor.getScrollPaneAdjustableAccessor().setTypedValue(adj,
|
||||||
setTypedValue(adj, newpos, type);
|
newpos,
|
||||||
|
type);
|
||||||
|
|
||||||
// Paint the exposed area right away. To do this - find
|
// Paint the exposed area right away. To do this - find
|
||||||
// the heavyweight ancestor of the scroll child.
|
// the heavyweight ancestor of the scroll child.
|
||||||
|
@ -396,12 +396,6 @@ LRESULT CALLBACK AwtChoice::ListWindowProc(HWND hwnd, UINT message,
|
|||||||
|
|
||||||
DASSERT(::IsWindow(hwnd));
|
DASSERT(::IsWindow(hwnd));
|
||||||
|
|
||||||
// This branch is required for the proper work of AwtComponent::GetComponent() method
|
|
||||||
// while hovering drop-down list
|
|
||||||
if (message == WmAwtIsComponent) {
|
|
||||||
return (LRESULT)TRUE;
|
|
||||||
}
|
|
||||||
|
|
||||||
switch (message) {
|
switch (message) {
|
||||||
case WM_LBUTTONDOWN: {
|
case WM_LBUTTONDOWN: {
|
||||||
DWORD curPos = ::GetMessagePos();
|
DWORD curPos = ::GetMessagePos();
|
||||||
|
@ -364,6 +364,7 @@ AwtComponent* AwtComponent::GetComponentImpl(HWND hWnd) {
|
|||||||
AwtComponent *component =
|
AwtComponent *component =
|
||||||
(AwtComponent *)::GetWindowLongPtr(hWnd, GWLP_USERDATA);
|
(AwtComponent *)::GetWindowLongPtr(hWnd, GWLP_USERDATA);
|
||||||
DASSERT(!component || !IsBadReadPtr(component, sizeof(AwtComponent)) );
|
DASSERT(!component || !IsBadReadPtr(component, sizeof(AwtComponent)) );
|
||||||
|
DASSERT(!component || component->GetHWnd() == hWnd );
|
||||||
return component;
|
return component;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,6 +119,41 @@ done:
|
|||||||
return menu;
|
return menu;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void AwtMenu::UpdateLayout()
|
||||||
|
{
|
||||||
|
UpdateLayout(GetHMenu());
|
||||||
|
RedrawMenuBar();
|
||||||
|
}
|
||||||
|
|
||||||
|
void AwtMenu::UpdateLayout(const HMENU hmenu)
|
||||||
|
{
|
||||||
|
const int nMenuItemCount = ::GetMenuItemCount(hmenu);
|
||||||
|
static MENUITEMINFO mii;
|
||||||
|
for (int idx = 0; idx < nMenuItemCount; ++idx) {
|
||||||
|
memset(&mii, 0, sizeof(mii));
|
||||||
|
mii.cbSize = sizeof(mii);
|
||||||
|
mii.fMask = MIIM_CHECKMARKS | MIIM_DATA | MIIM_ID
|
||||||
|
| MIIM_STATE | MIIM_SUBMENU | MIIM_TYPE;
|
||||||
|
if (::GetMenuItemInfo(hmenu, idx, TRUE, &mii)) {
|
||||||
|
VERIFY(::RemoveMenu(hmenu, idx, MF_BYPOSITION));
|
||||||
|
VERIFY(::InsertMenuItem(hmenu, idx, TRUE, &mii));
|
||||||
|
if (mii.hSubMenu != NULL) {
|
||||||
|
UpdateLayout(mii.hSubMenu);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AwtMenu::UpdateContainerLayout()
|
||||||
|
{
|
||||||
|
AwtMenu* menu = GetMenuContainer();
|
||||||
|
if (menu != NULL) {
|
||||||
|
menu->UpdateLayout();
|
||||||
|
} else {
|
||||||
|
UpdateLayout();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
AwtMenuBar* AwtMenu::GetMenuBar() {
|
AwtMenuBar* AwtMenu::GetMenuBar() {
|
||||||
return (GetMenuContainer() == NULL) ? NULL : GetMenuContainer()->GetMenuBar();
|
return (GetMenuContainer() == NULL) ? NULL : GetMenuContainer()->GetMenuBar();
|
||||||
}
|
}
|
||||||
|
@ -72,6 +72,8 @@ public:
|
|||||||
virtual AwtMenuBar* GetMenuBar();
|
virtual AwtMenuBar* GetMenuBar();
|
||||||
|
|
||||||
void AddSeparator();
|
void AddSeparator();
|
||||||
|
virtual void UpdateContainerLayout();
|
||||||
|
void UpdateLayout();
|
||||||
virtual void AddItem(AwtMenuItem *item);
|
virtual void AddItem(AwtMenuItem *item);
|
||||||
virtual void DeleteItem(UINT index);
|
virtual void DeleteItem(UINT index);
|
||||||
|
|
||||||
@ -103,6 +105,7 @@ protected:
|
|||||||
virtual void RemoveCmdID() { /* do nothing */ }
|
virtual void RemoveCmdID() { /* do nothing */ }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
void UpdateLayout(const HMENU hmenu);
|
||||||
HMENU m_hMenu;
|
HMENU m_hMenu;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -198,7 +198,15 @@ void AwtMenuBar::DeleteItem(UINT index)
|
|||||||
if (hOwnerWnd != NULL) {
|
if (hOwnerWnd != NULL) {
|
||||||
VERIFY(::InvalidateRect(hOwnerWnd,0,TRUE));
|
VERIFY(::InvalidateRect(hOwnerWnd,0,TRUE));
|
||||||
}
|
}
|
||||||
::DrawMenuBar(GetOwnerHWnd());
|
RedrawMenuBar();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* If the menu changes after the system has created the window,
|
||||||
|
* this function must be called to draw the changed menu bar.
|
||||||
|
*/
|
||||||
|
void AwtMenuBar::RedrawMenuBar() {
|
||||||
|
VERIFY(::DrawMenuBar(GetOwnerHWnd()));
|
||||||
}
|
}
|
||||||
|
|
||||||
LRESULT AwtMenuBar::WinThreadExecProc(ExecuteArgs * args)
|
LRESULT AwtMenuBar::WinThreadExecProc(ExecuteArgs * args)
|
||||||
@ -232,7 +240,7 @@ void AwtMenuBar::_AddMenu(void *param)
|
|||||||
if (::IsWindow(m->GetOwnerHWnd()))
|
if (::IsWindow(m->GetOwnerHWnd()))
|
||||||
{
|
{
|
||||||
/* The menu was already created and added during peer creation -- redraw */
|
/* The menu was already created and added during peer creation -- redraw */
|
||||||
::DrawMenuBar(m->GetOwnerHWnd());
|
m->RedrawMenuBar();
|
||||||
}
|
}
|
||||||
ret:
|
ret:
|
||||||
env->DeleteGlobalRef(self);
|
env->DeleteGlobalRef(self);
|
||||||
|
@ -65,6 +65,7 @@ public:
|
|||||||
INLINE AwtFrame* GetFrame() { return m_frame; }
|
INLINE AwtFrame* GetFrame() { return m_frame; }
|
||||||
|
|
||||||
virtual HWND GetOwnerHWnd();
|
virtual HWND GetOwnerHWnd();
|
||||||
|
virtual void RedrawMenuBar();
|
||||||
|
|
||||||
AwtMenuItem* GetItem(jobject target, long index);
|
AwtMenuItem* GetItem(jobject target, long index);
|
||||||
int CountItem(jobject menuBar);
|
int CountItem(jobject menuBar);
|
||||||
|
@ -626,7 +626,7 @@ void AwtMenuItem::SetLabel(LPCTSTR sb)
|
|||||||
mii.dwTypeData = (LPTSTR)(*sb);
|
mii.dwTypeData = (LPTSTR)(*sb);
|
||||||
|
|
||||||
// find index by menu item id
|
// find index by menu item id
|
||||||
int nMenuItemCount = ::GetMenuItemCount(hMenu);;
|
int nMenuItemCount = ::GetMenuItemCount(hMenu);
|
||||||
int idx;
|
int idx;
|
||||||
for (idx = 0; (idx < nMenuItemCount); idx++) {
|
for (idx = 0; (idx < nMenuItemCount); idx++) {
|
||||||
memset(&mii1, 0, sizeof(MENUITEMINFO));
|
memset(&mii1, 0, sizeof(MENUITEMINFO));
|
||||||
@ -639,10 +639,7 @@ void AwtMenuItem::SetLabel(LPCTSTR sb)
|
|||||||
::RemoveMenu(hMenu, idx, MF_BYPOSITION);
|
::RemoveMenu(hMenu, idx, MF_BYPOSITION);
|
||||||
::InsertMenuItem(hMenu, idx, TRUE, &mii);
|
::InsertMenuItem(hMenu, idx, TRUE, &mii);
|
||||||
|
|
||||||
// Redraw menu bar if it was affected.
|
RedrawMenuBar();
|
||||||
if (menu->GetMenuBar() == menu) {
|
|
||||||
::DrawMenuBar(menu->GetOwnerHWnd());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AwtMenuItem::Enable(BOOL isEnabled)
|
void AwtMenuItem::Enable(BOOL isEnabled)
|
||||||
@ -658,10 +655,7 @@ void AwtMenuItem::Enable(BOOL isEnabled)
|
|||||||
MF_BYCOMMAND | (isEnabled ? MF_ENABLED : MF_GRAYED))
|
MF_BYCOMMAND | (isEnabled ? MF_ENABLED : MF_GRAYED))
|
||||||
!= 0xFFFFFFFF);
|
!= 0xFFFFFFFF);
|
||||||
|
|
||||||
// Redraw menu bar if it was affected.
|
RedrawMenuBar();
|
||||||
if (menu->GetMenuBar() == menu) {
|
|
||||||
::DrawMenuBar(menu->GetOwnerHWnd());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void AwtMenuItem::SetState(BOOL isChecked)
|
void AwtMenuItem::SetState(BOOL isChecked)
|
||||||
@ -676,23 +670,31 @@ void AwtMenuItem::SetState(BOOL isChecked)
|
|||||||
MF_BYCOMMAND | (isChecked ? MF_CHECKED : MF_UNCHECKED))
|
MF_BYCOMMAND | (isChecked ? MF_CHECKED : MF_UNCHECKED))
|
||||||
!= 0xFFFFFFFF);
|
!= 0xFFFFFFFF);
|
||||||
|
|
||||||
// Redraw menu bar if it was affected.
|
RedrawMenuBar();
|
||||||
if (menu->GetMenuBar() == menu) {
|
}
|
||||||
::DrawMenuBar(menu->GetOwnerHWnd());
|
|
||||||
|
/**
|
||||||
|
* If the menu changes after the system has created the window,
|
||||||
|
* this function must be called to draw the changed menu bar.
|
||||||
|
*/
|
||||||
|
void AwtMenuItem::RedrawMenuBar() {
|
||||||
|
AwtMenu* menu = GetMenuContainer();
|
||||||
|
if (menu != NULL && menu->GetMenuBar() == menu){
|
||||||
|
menu->RedrawMenuBar();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AwtMenuItem::UpdateContainerLayout() {
|
||||||
|
AwtMenu* menu = GetMenuContainer();
|
||||||
|
if (menu != NULL) {
|
||||||
|
DASSERT(menu != NULL && GetID() >= 0);
|
||||||
|
menu->UpdateLayout();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LRESULT AwtMenuItem::WinThreadExecProc(ExecuteArgs * args)
|
LRESULT AwtMenuItem::WinThreadExecProc(ExecuteArgs * args)
|
||||||
{
|
{
|
||||||
switch( args->cmdId ) {
|
switch( args->cmdId ) {
|
||||||
case MENUITEM_SETLABEL:
|
|
||||||
{
|
|
||||||
LPCTSTR sb = (LPCTSTR)args->param1;
|
|
||||||
DASSERT(!IsBadStringPtr(sb, 20));
|
|
||||||
this->SetLabel(sb);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
|
|
||||||
case MENUITEM_ENABLE:
|
case MENUITEM_ENABLE:
|
||||||
{
|
{
|
||||||
BOOL isEnabled = (BOOL)args->param1;
|
BOOL isEnabled = (BOOL)args->param1;
|
||||||
@ -714,8 +716,8 @@ LRESULT AwtMenuItem::WinThreadExecProc(ExecuteArgs * args)
|
|||||||
return 0L;
|
return 0L;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AwtMenuItem::_SetLabel(void *param)
|
void AwtMenuItem::_SetLabel(void *param) {
|
||||||
{
|
if (AwtToolkit::IsMainThread()) {
|
||||||
JNIEnv *env = (JNIEnv *)JNU_GetEnv(jvm, JNI_VERSION_1_2);
|
JNIEnv *env = (JNIEnv *)JNU_GetEnv(jvm, JNI_VERSION_1_2);
|
||||||
|
|
||||||
SetLabelStruct *sls = (SetLabelStruct *)param;
|
SetLabelStruct *sls = (SetLabelStruct *)param;
|
||||||
@ -752,10 +754,8 @@ void AwtMenuItem::_SetLabel(void *param)
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
ExecuteArgs args;
|
DASSERT(!IsBadStringPtr(labelPtr, 20));
|
||||||
args.cmdId = MENUITEM_SETLABEL;
|
m->SetLabel(labelPtr);
|
||||||
args.param1 = (LPARAM)labelPtr;
|
|
||||||
m->WinThreadExecProc(&args);
|
|
||||||
if (empty != NULL)
|
if (empty != NULL)
|
||||||
{
|
{
|
||||||
JNU_ReleaseStringPlatformChars(env, empty, labelPtr);
|
JNU_ReleaseStringPlatformChars(env, empty, labelPtr);
|
||||||
@ -784,6 +784,31 @@ ret:
|
|||||||
{
|
{
|
||||||
throw std::bad_alloc();
|
throw std::bad_alloc();
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
AwtToolkit::GetInstance().InvokeFunction(AwtMenuItem::_SetLabel, param);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AwtMenuItem::_UpdateLayout(void *param)
|
||||||
|
{
|
||||||
|
if (AwtToolkit::IsMainThread()) {
|
||||||
|
JNIEnv *env = (JNIEnv *)JNU_GetEnv(jvm, JNI_VERSION_1_2);
|
||||||
|
|
||||||
|
jobject self = (jobject)param;
|
||||||
|
|
||||||
|
AwtMenuItem *m = NULL;
|
||||||
|
|
||||||
|
PDATA pData;
|
||||||
|
JNI_CHECK_PEER_GOTO(self, ret);
|
||||||
|
|
||||||
|
m = (AwtMenuItem *)pData;
|
||||||
|
|
||||||
|
m->UpdateContainerLayout();
|
||||||
|
ret:
|
||||||
|
env->DeleteGlobalRef(self);
|
||||||
|
} else {
|
||||||
|
AwtToolkit::GetInstance().InvokeFunction(AwtMenuItem::_UpdateLayout, param);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
BOOL AwtMenuItem::IsSeparator() {
|
BOOL AwtMenuItem::IsSeparator() {
|
||||||
@ -883,8 +908,8 @@ extern "C" {
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: sun_awt_windows_WMenuItemPeer
|
* Class: sun_awt_windows_WMenuItemPeer
|
||||||
* Method: _setLabel
|
* Method: initIDs
|
||||||
* Signature: (Ljava/lang/String;)V
|
* Signature: ()V
|
||||||
*/
|
*/
|
||||||
JNIEXPORT void JNICALL
|
JNIEXPORT void JNICALL
|
||||||
Java_sun_awt_windows_WMenuItemPeer_initIDs(JNIEnv *env, jclass cls)
|
Java_sun_awt_windows_WMenuItemPeer_initIDs(JNIEnv *env, jclass cls)
|
||||||
@ -925,6 +950,26 @@ Java_sun_awt_windows_WMenuItemPeer__1setLabel(JNIEnv *env, jobject self,
|
|||||||
CATCH_BAD_ALLOC;
|
CATCH_BAD_ALLOC;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Class: sun_awt_windows_WMenuItemPeer
|
||||||
|
* Method: _setFont
|
||||||
|
* Signature: (Ljava/awt/Font;)V
|
||||||
|
*/
|
||||||
|
JNIEXPORT void JNICALL
|
||||||
|
Java_sun_awt_windows_WMenuItemPeer__1setFont(JNIEnv *env, jobject self, jobject)
|
||||||
|
{
|
||||||
|
TRY;
|
||||||
|
|
||||||
|
jobject selfGlobalRef = env->NewGlobalRef(self);
|
||||||
|
|
||||||
|
// Current implementation of AwtMenuItem get font attribute from the peer
|
||||||
|
// directly, so we ignore it here, but update current menu layout.
|
||||||
|
AwtToolkit::GetInstance().SyncCall(AwtMenuItem::_UpdateLayout, selfGlobalRef);
|
||||||
|
// selfGlobalRef is deleted in _UpdateLayout
|
||||||
|
|
||||||
|
CATCH_BAD_ALLOC;
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Class: sun_awt_windows_WMenuItemPeer
|
* Class: sun_awt_windows_WMenuItemPeer
|
||||||
* Method: create
|
* Method: create
|
||||||
|
@ -48,7 +48,6 @@ class AwtMenuItem : public AwtObject {
|
|||||||
public:
|
public:
|
||||||
// id's for methods executed on toolkit thread
|
// id's for methods executed on toolkit thread
|
||||||
enum {
|
enum {
|
||||||
MENUITEM_SETLABEL,
|
|
||||||
MENUITEM_ENABLE,
|
MENUITEM_ENABLE,
|
||||||
MENUITEM_SETSTATE,
|
MENUITEM_SETSTATE,
|
||||||
MENUITEM_LAST
|
MENUITEM_LAST
|
||||||
@ -78,7 +77,6 @@ public:
|
|||||||
|
|
||||||
virtual LPCTSTR GetClassName();
|
virtual LPCTSTR GetClassName();
|
||||||
|
|
||||||
void AwtMenuItem::LinkObjects(jobject peer);
|
|
||||||
static AwtMenuItem* Create(jobject self, jobject menu);
|
static AwtMenuItem* Create(jobject self, jobject menu);
|
||||||
|
|
||||||
INLINE AwtMenu* GetMenuContainer() { return m_menuContainer; }
|
INLINE AwtMenu* GetMenuContainer() { return m_menuContainer; }
|
||||||
@ -148,6 +146,8 @@ public:
|
|||||||
|
|
||||||
void SetLabel(LPCTSTR sb);
|
void SetLabel(LPCTSTR sb);
|
||||||
virtual void Enable(BOOL isEnabled);
|
virtual void Enable(BOOL isEnabled);
|
||||||
|
virtual void UpdateContainerLayout();
|
||||||
|
virtual void RedrawMenuBar();
|
||||||
void SetState(BOOL isChecked);
|
void SetState(BOOL isChecked);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -163,6 +163,7 @@ public:
|
|||||||
|
|
||||||
// invoked on Toolkit thread
|
// invoked on Toolkit thread
|
||||||
static void _SetLabel(void *param);
|
static void _SetLabel(void *param);
|
||||||
|
static void _UpdateLayout(void *param);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
AwtMenu* m_menuContainer; /* The menu object containing this item */
|
AwtMenu* m_menuContainer; /* The menu object containing this item */
|
||||||
|
@ -4137,7 +4137,7 @@ Java_sun_awt_windows_WPrinterJob_initIDs(JNIEnv *env, jclass cls)
|
|||||||
|
|
||||||
AwtPrintDialog::controlID =
|
AwtPrintDialog::controlID =
|
||||||
env->GetFieldID(cls, "pjob", "Ljava/awt/print/PrinterJob;");
|
env->GetFieldID(cls, "pjob", "Ljava/awt/print/PrinterJob;");
|
||||||
jclass printDialogPeerClass = env->FindClass("Lsun/awt/windows/WPrintDialogPeer;");
|
jclass printDialogPeerClass = env->FindClass("sun/awt/windows/WPrintDialogPeer");
|
||||||
AwtPrintDialog::setHWndMID =
|
AwtPrintDialog::setHWndMID =
|
||||||
env->GetMethodID(printDialogPeerClass, "setHWnd", "(J)V");
|
env->GetMethodID(printDialogPeerClass, "setHWnd", "(J)V");
|
||||||
|
|
||||||
|
@ -808,29 +808,4 @@ Java_sun_awt_windows_WScrollPanePeer_setSpans(JNIEnv *env, jobject self,
|
|||||||
CATCH_BAD_ALLOC;
|
CATCH_BAD_ALLOC;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Class: sun_awt_windows_WScrollPanePeer
|
|
||||||
* Method: setTypedValue
|
|
||||||
* Signature: (Ljava/awt/ScrollPaneAdjustable;II)V
|
|
||||||
*/
|
|
||||||
JNIEXPORT void JNICALL
|
|
||||||
Java_sun_awt_windows_WScrollPanePeer_setTypedValue(JNIEnv *env, jobject peer, jobject adjustable, jint value, jint type)
|
|
||||||
{
|
|
||||||
// need this global ref to make the class unloadable (see 6500204)
|
|
||||||
static jclass scrollPaneAdj;
|
|
||||||
static jmethodID setTypedValueMID = 0;
|
|
||||||
if (setTypedValueMID == NULL) {
|
|
||||||
jclass clazz = env->FindClass("java/awt/ScrollPaneAdjustable");
|
|
||||||
if (safe_ExceptionOccurred(env)) {
|
|
||||||
env->ExceptionDescribe();
|
|
||||||
env->ExceptionClear();
|
|
||||||
}
|
|
||||||
setTypedValueMID = env->GetMethodID(clazz, "setTypedValue", "(II)V");
|
|
||||||
scrollPaneAdj = (jclass) env->NewGlobalRef(clazz);
|
|
||||||
env->DeleteLocalRef(clazz);
|
|
||||||
DASSERT(setTypedValueMID != NULL);
|
|
||||||
}
|
|
||||||
env->CallVoidMethod(adjustable, setTypedValueMID, value, type);
|
|
||||||
}
|
|
||||||
|
|
||||||
} /* extern "C" */
|
} /* extern "C" */
|
||||||
|
@ -1444,7 +1444,6 @@ BOOL AwtToolkit::PreProcessMouseMsg(AwtComponent* p, MSG& msg)
|
|||||||
AwtComponent* mouseComp =
|
AwtComponent* mouseComp =
|
||||||
AwtComponent::GetComponent(hWndFromPoint);
|
AwtComponent::GetComponent(hWndFromPoint);
|
||||||
// Need extra copies for non-client area issues
|
// Need extra copies for non-client area issues
|
||||||
AwtComponent* mouseWheelComp = mouseComp;
|
|
||||||
HWND hWndForWheel = hWndFromPoint;
|
HWND hWndForWheel = hWndFromPoint;
|
||||||
|
|
||||||
// If the point under the mouse isn't in the client area,
|
// If the point under the mouse isn't in the client area,
|
||||||
@ -1510,8 +1509,8 @@ BOOL AwtToolkit::PreProcessMouseMsg(AwtComponent* p, MSG& msg)
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
if (msg.message == WM_MOUSEWHEEL &&
|
if (msg.message == WM_MOUSEWHEEL &&
|
||||||
mouseWheelComp != NULL) { //i.e. mouse is over client area for this
|
AwtToolkit::MainThread() == ::GetWindowThreadProcessId(hWndForWheel, NULL)) {
|
||||||
//window
|
//i.e. mouse is over client area for this window
|
||||||
msg.hwnd = hWndForWheel;
|
msg.hwnd = hWndForWheel;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -0,0 +1,149 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
@test
|
||||||
|
@bug 7050935
|
||||||
|
@summary closed/java/awt/Choice/WheelEventsConsumed/WheelEventsConsumed.html fails on win32
|
||||||
|
@author Oleg Pekhovskiy: area=awt-choice
|
||||||
|
@run main ChoiceMouseWheelTest
|
||||||
|
*/
|
||||||
|
|
||||||
|
import test.java.awt.regtesthelpers.Util;
|
||||||
|
|
||||||
|
import java.awt.*;
|
||||||
|
import java.awt.event.*;
|
||||||
|
|
||||||
|
public class ChoiceMouseWheelTest extends Frame {
|
||||||
|
|
||||||
|
private volatile boolean itemChanged = false;
|
||||||
|
private volatile boolean wheelMoved = false;
|
||||||
|
private volatile boolean frameExited = false;
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
new ChoiceMouseWheelTest();
|
||||||
|
}
|
||||||
|
|
||||||
|
ChoiceMouseWheelTest() {
|
||||||
|
super("ChoiceMouseWheelTest");
|
||||||
|
setLayout(new FlowLayout());
|
||||||
|
|
||||||
|
Choice choice = new Choice();
|
||||||
|
|
||||||
|
addWindowListener(new WindowAdapter() {
|
||||||
|
@Override
|
||||||
|
public void windowClosing(WindowEvent e) {
|
||||||
|
System.exit(0);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
for(Integer i = 0; i < 50; i++) {
|
||||||
|
choice.add(i.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
choice.addItemListener(new ItemListener() {
|
||||||
|
public void itemStateChanged(ItemEvent e) {
|
||||||
|
itemChanged = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
choice.addMouseWheelListener(new MouseWheelListener() {
|
||||||
|
public void mouseWheelMoved(MouseWheelEvent e) {
|
||||||
|
wheelMoved = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
addMouseListener(new MouseAdapter() {
|
||||||
|
@Override
|
||||||
|
public void mouseExited(MouseEvent e) {
|
||||||
|
frameExited = true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
add(choice);
|
||||||
|
setSize(200, 300);
|
||||||
|
setVisible(true);
|
||||||
|
toFront();
|
||||||
|
|
||||||
|
try {
|
||||||
|
Robot robot = new Robot();
|
||||||
|
robot.setAutoDelay(20);
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
|
||||||
|
Point pt = choice.getLocationOnScreen();
|
||||||
|
Dimension size = choice.getSize();
|
||||||
|
int x = pt.x + size.width / 3;
|
||||||
|
robot.mouseMove(x, pt.y + size.height / 2);
|
||||||
|
|
||||||
|
// Test mouse wheel over the choice
|
||||||
|
String name = Toolkit.getDefaultToolkit().getClass().getName();
|
||||||
|
if(!name.equals("sun.awt.X11.XToolkit")) { // mouse wheel doesn't work for the choice on X11, so skip it
|
||||||
|
robot.mouseWheel(1);
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
|
||||||
|
if(!wheelMoved || !itemChanged) {
|
||||||
|
throw new RuntimeException("Mouse Wheel over the choice failed!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Test mouse wheel over the drop-down list
|
||||||
|
robot.mousePress(InputEvent.BUTTON1_DOWN_MASK);
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
robot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK);
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
|
||||||
|
int y = getLocationOnScreen().y + getSize().height;
|
||||||
|
while(!frameExited && y >= 0) { // move to the bottom of drop-down list
|
||||||
|
robot.mouseMove(x, --y);
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(x < 0) {
|
||||||
|
throw new RuntimeException("Could not enter drop-down list!");
|
||||||
|
}
|
||||||
|
|
||||||
|
y -= choice.getHeight() / 2;
|
||||||
|
robot.mouseMove(x, y); // move to the last visible item in the drop-down list
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
|
||||||
|
robot.mouseWheel(choice.getItemCount()); // wheel to the last item
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
|
||||||
|
// click the last item
|
||||||
|
itemChanged = false;
|
||||||
|
robot.mousePress(InputEvent.BUTTON1_DOWN_MASK);
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
robot.mouseRelease(InputEvent.BUTTON1_DOWN_MASK);
|
||||||
|
Util.waitForIdle(robot);
|
||||||
|
|
||||||
|
if(!itemChanged || choice.getSelectedIndex() != choice.getItemCount() - 1) {
|
||||||
|
throw new RuntimeException("Mouse Wheel scroll position error!");
|
||||||
|
}
|
||||||
|
|
||||||
|
System.exit(0);
|
||||||
|
|
||||||
|
} catch (AWTException e) {
|
||||||
|
throw new RuntimeException("AWTException occurred - problem creating robot!");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
301
jdk/test/java/awt/Component/PaintAll/PaintAll.java
Normal file
301
jdk/test/java/awt/Component/PaintAll/PaintAll.java
Normal file
@ -0,0 +1,301 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import sun.awt.SunToolkit;
|
||||||
|
|
||||||
|
import java.awt.Button;
|
||||||
|
import java.awt.Canvas;
|
||||||
|
import java.awt.Checkbox;
|
||||||
|
import java.awt.Choice;
|
||||||
|
import java.awt.Component;
|
||||||
|
import java.awt.Container;
|
||||||
|
import java.awt.Dimension;
|
||||||
|
import java.awt.Frame;
|
||||||
|
import java.awt.Graphics;
|
||||||
|
import java.awt.GridLayout;
|
||||||
|
import java.awt.Label;
|
||||||
|
import java.awt.List;
|
||||||
|
import java.awt.Panel;
|
||||||
|
import java.awt.ScrollPane;
|
||||||
|
import java.awt.Scrollbar;
|
||||||
|
import java.awt.TextArea;
|
||||||
|
import java.awt.TextField;
|
||||||
|
import java.awt.Toolkit;
|
||||||
|
import java.awt.image.BufferedImage;
|
||||||
|
|
||||||
|
/*
|
||||||
|
@test
|
||||||
|
@bug 6596915
|
||||||
|
@summary Test Component.paintAll() method
|
||||||
|
@author sergey.bylokhov@oracle.com: area=awt.component
|
||||||
|
@run main PaintAll
|
||||||
|
*/
|
||||||
|
public class PaintAll {
|
||||||
|
|
||||||
|
private static volatile boolean lwPainted;
|
||||||
|
private static volatile boolean buttonPainted;
|
||||||
|
private static volatile boolean canvasPainted;
|
||||||
|
private static volatile boolean checkboxPainted;
|
||||||
|
private static volatile boolean choicePainted;
|
||||||
|
private static volatile boolean containerPainted;
|
||||||
|
private static volatile boolean framePainted;
|
||||||
|
private static volatile boolean labelPainted;
|
||||||
|
private static volatile boolean listPainted;
|
||||||
|
private static volatile boolean panelPainted;
|
||||||
|
private static volatile boolean scrollbarPainted;
|
||||||
|
private static volatile boolean scrollPanePainted;
|
||||||
|
private static volatile boolean textAreaPainted;
|
||||||
|
private static volatile boolean textFieldPainted;
|
||||||
|
|
||||||
|
private static final Button buttonStub = new Button() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
buttonPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Canvas canvasStub = new Canvas() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
canvasPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Checkbox checkboxStub = new Checkbox() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
checkboxPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Choice choiceStub = new Choice() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
choicePainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Component lwComponentStub = new Component() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
lwPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Container containerStub = new Container() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
containerPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Frame frame = new Frame() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
super.paint(g);
|
||||||
|
framePainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Label labelStub = new Label() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
labelPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final List listStub = new List() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
listPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Panel panelStub = new Panel() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
panelPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final Scrollbar scrollbarStub = new Scrollbar() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
scrollbarPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final ScrollPane scrollPaneStub = new ScrollPane() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
scrollPanePainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final TextArea textAreaStub = new TextArea() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
textAreaPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
private static final TextField textFieldStub = new TextField() {
|
||||||
|
@Override
|
||||||
|
public void paint(final Graphics g) {
|
||||||
|
textFieldPainted = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
public static void main(final String[] args) throws Exception {
|
||||||
|
//Frame initialisation
|
||||||
|
final BufferedImage graphicsProducer =
|
||||||
|
new BufferedImage(BufferedImage.TYPE_INT_ARGB, 1, 1);
|
||||||
|
|
||||||
|
final Graphics g = graphicsProducer.getGraphics();
|
||||||
|
|
||||||
|
frame.setLayout(new GridLayout());
|
||||||
|
frame.add(buttonStub);
|
||||||
|
frame.add(canvasStub);
|
||||||
|
frame.add(checkboxStub);
|
||||||
|
frame.add(choiceStub);
|
||||||
|
frame.add(lwComponentStub);
|
||||||
|
frame.add(containerStub);
|
||||||
|
frame.add(labelStub);
|
||||||
|
frame.add(listStub);
|
||||||
|
frame.add(panelStub);
|
||||||
|
frame.add(scrollbarStub);
|
||||||
|
frame.add(scrollPaneStub);
|
||||||
|
frame.add(textAreaStub);
|
||||||
|
frame.add(textFieldStub);
|
||||||
|
frame.setSize(new Dimension(500, 500));
|
||||||
|
frame.setLocationRelativeTo(null);
|
||||||
|
frame.setVisible(true);
|
||||||
|
sleep();
|
||||||
|
|
||||||
|
//Check results.
|
||||||
|
validation();
|
||||||
|
|
||||||
|
//Reset all flags to 'false'.
|
||||||
|
initPaintedFlags();
|
||||||
|
|
||||||
|
//Tested method.
|
||||||
|
frame.paintAll(g);
|
||||||
|
sleep();
|
||||||
|
|
||||||
|
//Check results.
|
||||||
|
validation();
|
||||||
|
cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void initPaintedFlags() {
|
||||||
|
lwPainted = false;
|
||||||
|
buttonPainted = false;
|
||||||
|
canvasPainted = false;
|
||||||
|
checkboxPainted = false;
|
||||||
|
choicePainted = false;
|
||||||
|
containerPainted = false;
|
||||||
|
framePainted = false;
|
||||||
|
labelPainted = false;
|
||||||
|
listPainted = false;
|
||||||
|
panelPainted = false;
|
||||||
|
scrollbarPainted = false;
|
||||||
|
scrollPanePainted = false;
|
||||||
|
textAreaPainted = false;
|
||||||
|
textFieldPainted = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void validation() {
|
||||||
|
if (!buttonPainted) {
|
||||||
|
fail("Paint is not called a Button "
|
||||||
|
+ "when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!canvasPainted) {
|
||||||
|
fail("Paint is not called a Canvas "
|
||||||
|
+ "when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!checkboxPainted) {
|
||||||
|
fail("Paint is not called a Checkbox "
|
||||||
|
+ "when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!choicePainted) {
|
||||||
|
fail("Paint is not called a Choice "
|
||||||
|
+ "when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!lwPainted) {
|
||||||
|
fail("Paint is not called on a lightweight"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!containerPainted) {
|
||||||
|
fail("Paint is not called on a Container"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!labelPainted) {
|
||||||
|
fail("Paint is not called on a Label"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!listPainted) {
|
||||||
|
fail("Paint is not called on a List"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!panelPainted) {
|
||||||
|
fail("Paint is not called on a Panel"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!scrollbarPainted) {
|
||||||
|
fail("Paint is not called on a Scrollbar"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!scrollPanePainted) {
|
||||||
|
fail("Paint is not called on a ScrollPane"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!textAreaPainted) {
|
||||||
|
fail("Paint is not called on a TextArea"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!textFieldPainted) {
|
||||||
|
fail("Paint is not called on a TextField"
|
||||||
|
+ " subcomponent when paintAll() invoked on a parent");
|
||||||
|
}
|
||||||
|
if (!framePainted) {
|
||||||
|
fail("Paint is not called on a Frame when paintAll()");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void sleep() {
|
||||||
|
((SunToolkit) Toolkit.getDefaultToolkit()).realSync();
|
||||||
|
try {
|
||||||
|
Thread.sleep(500L);
|
||||||
|
} catch (InterruptedException ignored) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void fail(final String message) {
|
||||||
|
cleanup();
|
||||||
|
throw new RuntimeException(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void cleanup() {
|
||||||
|
frame.dispose();
|
||||||
|
}
|
||||||
|
}
|
92
jdk/test/java/text/Bidi/Bug7042148.java
Normal file
92
jdk/test/java/text/Bidi/Bug7042148.java
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 7042148
|
||||||
|
* @summary verify that Bidi.baseIsLeftToRight() returns the correct value even if an incorrect position is set in the given AttributedCharacterIterator.
|
||||||
|
*/
|
||||||
|
import java.awt.font.*;
|
||||||
|
import java.text.*;
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
public class Bug7042148 {
|
||||||
|
|
||||||
|
private static boolean err = false;
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
testDirection();
|
||||||
|
|
||||||
|
if (err) {
|
||||||
|
throw new RuntimeException("Failed");
|
||||||
|
} else {
|
||||||
|
System.out.println("Passed.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void testDirection() {
|
||||||
|
Map attrLTR = new HashMap();
|
||||||
|
attrLTR.put(TextAttribute.RUN_DIRECTION,
|
||||||
|
TextAttribute.RUN_DIRECTION_LTR);
|
||||||
|
Map attrRTL = new HashMap();
|
||||||
|
attrRTL.put(TextAttribute.RUN_DIRECTION,
|
||||||
|
TextAttribute.RUN_DIRECTION_RTL);
|
||||||
|
|
||||||
|
String str1 = "A\u05e0";
|
||||||
|
String str2 = "\u05e0B";
|
||||||
|
|
||||||
|
test(str1, attrLTR, Bidi.DIRECTION_LEFT_TO_RIGHT);
|
||||||
|
test(str1, attrRTL, Bidi.DIRECTION_RIGHT_TO_LEFT);
|
||||||
|
test(str2, attrLTR, Bidi.DIRECTION_LEFT_TO_RIGHT);
|
||||||
|
test(str2, attrRTL, Bidi.DIRECTION_RIGHT_TO_LEFT);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void test(String text, Map attr, int dirFlag) {
|
||||||
|
boolean expected = (dirFlag == Bidi.DIRECTION_LEFT_TO_RIGHT);
|
||||||
|
|
||||||
|
Bidi bidi = new Bidi(text, dirFlag);
|
||||||
|
boolean got = bidi.baseIsLeftToRight();
|
||||||
|
if (got != expected) {
|
||||||
|
err = true;
|
||||||
|
System.err.println("wrong Bidi(String, int).baseIsLeftToRight() value: " +
|
||||||
|
"\n\ttext=" + text +
|
||||||
|
"\n\tExpected=" + expected +
|
||||||
|
"\n\tGot=" + got);
|
||||||
|
}
|
||||||
|
|
||||||
|
AttributedString as = new AttributedString(text, attr);
|
||||||
|
AttributedCharacterIterator itr = as.getIterator();
|
||||||
|
itr.last();
|
||||||
|
itr.next();
|
||||||
|
bidi = new Bidi(itr);
|
||||||
|
got = bidi.baseIsLeftToRight();
|
||||||
|
if (got != expected) {
|
||||||
|
err = true;
|
||||||
|
System.err.println("Wrong Bidi(AttributedCharacterIterator).baseIsLeftToRight() value: " +
|
||||||
|
"\n\ttext=" + text +
|
||||||
|
"\n\tExpected=" + expected +
|
||||||
|
"\n\tGot=" + got);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
72
jdk/test/java/text/Bidi/Bug7051769.java
Normal file
72
jdk/test/java/text/Bidi/Bug7051769.java
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
|
||||||
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
|
*
|
||||||
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* @test
|
||||||
|
* @bug 7051769
|
||||||
|
* @summary verify that Bidi.toString() returns the corect result.
|
||||||
|
*/
|
||||||
|
import java.awt.font.*;
|
||||||
|
import java.text.*;
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
public class Bug7051769 {
|
||||||
|
|
||||||
|
private static boolean err = false;
|
||||||
|
|
||||||
|
public static void main(String[] args) {
|
||||||
|
testNumericShaping();
|
||||||
|
|
||||||
|
if (err) {
|
||||||
|
throw new RuntimeException("Failed");
|
||||||
|
} else {
|
||||||
|
System.out.println("Passed.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static void testNumericShaping() {
|
||||||
|
Map attrNS = new HashMap();
|
||||||
|
attrNS.put(TextAttribute.NUMERIC_SHAPING,
|
||||||
|
NumericShaper.getContextualShaper(NumericShaper.ARABIC));
|
||||||
|
attrNS.put(TextAttribute.RUN_DIRECTION,
|
||||||
|
TextAttribute.RUN_DIRECTION_RTL);
|
||||||
|
|
||||||
|
String text = "\u0623\u0643\u062a\u0648\u0628\u0631 10";
|
||||||
|
String expected = "sun.text.bidi.BidiBase[dir: 2 baselevel: 1 length: 9 runs: [1 1 1 1 1 1 1 2 2] text: [0x623 0x643 0x62a 0x648 0x628 0x631 0x20 0x661 0x660]]";
|
||||||
|
|
||||||
|
AttributedString as = new AttributedString(text, attrNS);
|
||||||
|
AttributedCharacterIterator itr = as.getIterator();
|
||||||
|
itr.last();
|
||||||
|
itr.next();
|
||||||
|
Bidi bidi = new Bidi(itr);
|
||||||
|
String got = bidi.toString();
|
||||||
|
|
||||||
|
if (!got.equals(expected)) {
|
||||||
|
err = true;
|
||||||
|
System.err.println("Wrong toString() output: " +
|
||||||
|
"\n\tExpected=" + expected +
|
||||||
|
"\n\tGot=" + got);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user