提交 d564a218 编写于 作者: M malenkov

8010718: [macosx] JFileChooser current filter nullified by addChoosableFileFilter

Reviewed-by: serb
上级 95eea3ea
...@@ -1266,64 +1266,70 @@ public class AquaFileChooserUI extends FileChooserUI { ...@@ -1266,64 +1266,70 @@ public class AquaFileChooserUI extends FileChooserUI {
/** /**
* Data model for a type-face selection combo-box. * Data model for a type-face selection combo-box.
*/ */
protected class FilterComboBoxModel extends DefaultListModel implements ComboBoxModel, PropertyChangeListener { protected class FilterComboBoxModel extends AbstractListModel<FileFilter> implements ComboBoxModel<FileFilter>,
int selectedIndex = -1; PropertyChangeListener {
protected FileFilter[] filters;
protected FilterComboBoxModel() { protected FilterComboBoxModel() {
super(); super();
final FileFilter filters[] = getFileChooser().getChoosableFileFilters(); filters = getFileChooser().getChoosableFileFilters();
for (int i = 0; i < filters.length; i++) {
this.add(i, filters[i]);
}
} }
public void propertyChange(final PropertyChangeEvent e) { public void propertyChange(PropertyChangeEvent e) {
final String prop = e.getPropertyName(); String prop = e.getPropertyName();
if (prop == JFileChooser.CHOOSABLE_FILE_FILTER_CHANGED_PROPERTY) { if(prop == JFileChooser.CHOOSABLE_FILE_FILTER_CHANGED_PROPERTY) {
this.clear(); filters = (FileFilter[]) e.getNewValue();
final FileFilter filters[] = (FileFilter[])e.getNewValue();
for (int i = 0; i < filters.length; i++) {
this.add(i, filters[i]);
}
fireContentsChanged(this, -1, -1); fireContentsChanged(this, -1, -1);
} else if (prop == JFileChooser.FILE_FILTER_CHANGED_PROPERTY) { } else if (prop == JFileChooser.FILE_FILTER_CHANGED_PROPERTY) {
final FileFilter currentFilter = (FileFilter)e.getNewValue(); fireContentsChanged(this, -1, -1);
FileFilter filters[] = getFileChooser().getChoosableFileFilters();
boolean found = false;
if (currentFilter != null) {
for (final FileFilter element : filters) {
if (element == currentFilter) {
found = true;
}
}
if (found == false) {
getFileChooser().addChoosableFileFilter(currentFilter);
}
}
filters = getFileChooser().getChoosableFileFilters();
setSelectedItem(e.getNewValue());
} }
} }
public void setSelectedItem(final Object filter) { public void setSelectedItem(Object filter) {
if (filter != null) { if(filter != null) {
selectedIndex = this.indexOf(filter); getFileChooser().setFileFilter((FileFilter) filter);
fireContentsChanged(this, -1, -1); fireContentsChanged(this, -1, -1);
} }
} }
public Object getSelectedItem() { public Object getSelectedItem() {
final Object returnValue = null; // Ensure that the current filter is in the list.
// NOTE: we shouldnt' have to do this, since JFileChooser adds
// the filter to the choosable filters list when the filter
// is set. Lets be paranoid just in case someone overrides
// setFileFilter in JFileChooser.
FileFilter currentFilter = getFileChooser().getFileFilter();
boolean found = false;
if(currentFilter != null) {
for (FileFilter filter : filters) {
if (filter == currentFilter) {
found = true;
}
}
if(found == false) {
getFileChooser().addChoosableFileFilter(currentFilter);
}
}
return getFileChooser().getFileFilter();
}
if (this.size() > 0) { public int getSize() {
if ((selectedIndex != -1) && (selectedIndex < size())) { return this.get(selectedIndex); } if(filters != null) {
return filters.length;
} else {
return 0;
} }
}
return returnValue; public FileFilter getElementAt(int index) {
if(index > getSize() - 1) {
// This shouldn't happen. Try to recover gracefully.
return getFileChooser().getFileFilter();
}
if(filters != null) {
return filters[index];
} else {
return null;
}
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册