/* * Jalview - A Sequence Alignment Editor and Viewer * Copyright (C) 2005 AM Waterhouse, J Procter, G Barton, M Clamp, S Searle * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program 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 for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA */ package jalview.gui; import jalview.datamodel.*; import javax.swing.*; import javax.swing.event.*; import java.awt.*; import java.util.*; import javax.swing.BorderFactory; import java.awt.event.*; import javax.swing.table.*; import java.io.*; import jalview.io.JalviewFileChooser; import java.awt.BorderLayout; import java.awt.Font; import java.awt.Color; import org.biojava.dasobert.dasregistry.DasSource; import org.biojava.dasobert.dasregistry.DasCoordinateSystem; public class FeatureSettings extends JPanel { DasSourceBrowser dassourceBrowser; JPanel settingsPane = new JPanel(); JPanel dasSettingsPane = new JPanel(); final FeatureRenderer fr; final AlignFrame af; Object [][] originalData; final JInternalFrame frame; JScrollPane scrollPane = new JScrollPane(); JTable table; JPanel groupPanel; JSlider transparency = new JSlider(); JPanel transPanel = new JPanel(new FlowLayout()); boolean alignmentHasFeatures = false; public FeatureSettings(AlignFrame af) { this.af = af; fr = af.getFeatureRenderer(); transparency.setMaximum( 100 - (int)(fr.transparency*100) ) ; try { jbInit(); } catch (Exception ex) { ex.printStackTrace(); } dassourceBrowser = new DasSourceBrowser(); dasSettingsPane.add(dassourceBrowser, BorderLayout.CENTER); if (af.getViewport().featuresDisplayed == null || fr.renderOrder==null) fr.findAllFeatures(); setTableData(); frame = new JInternalFrame(); frame.setContentPane(this); Desktop.addInternalFrame(frame, "Sequence Feature Settings", 400, 450); frame.setLayer(JLayeredPane.PALETTE_LAYER); } public void setTableData() { alignmentHasFeatures = false; if (fr.featureGroups == null) fr.featureGroups = new Hashtable(); Vector allFeatures = new Vector(); Vector allGroups = new Vector(); SequenceFeature[] tmpfeatures; String group; for (int i = 0; i < af.getViewport().alignment.getHeight(); i++) { if (af.getViewport().alignment.getSequenceAt(i).getDatasetSequence().getSequenceFeatures() == null) continue; alignmentHasFeatures = true; tmpfeatures = af.getViewport().alignment.getSequenceAt(i).getDatasetSequence().getSequenceFeatures(); int index = 0; while (index < tmpfeatures.length) { if(tmpfeatures[index].begin == 0 && tmpfeatures[index].end ==0) { index++; continue; } if(tmpfeatures[index].getFeatureGroup()!=null) { group = tmpfeatures[index].featureGroup; if(!allGroups.contains(group)) { allGroups.addElement(group); boolean visible = true; if (fr.featureGroups.containsKey(group)) { visible = ( (Boolean) fr.featureGroups.get(group)).booleanValue(); } else { fr.featureGroups.put(group, new Boolean(visible)); if (groupPanel == null) { groupPanel = new JPanel(); } final JCheckBox check = new JCheckBox(group, visible); check.setFont(new Font("Serif", Font.BOLD, 12)); check.addItemListener(new ItemListener() { public void itemStateChanged(ItemEvent evt) { fr.featureGroups.put(check.getText(), new Boolean(check.isSelected())); af.alignPanel.seqPanel.seqCanvas.repaint(); if (af.alignPanel.overviewPanel != null) af.alignPanel.overviewPanel.updateOverviewImage(); resetTable(true); } }); groupPanel.add(check); } } } if (!allFeatures.contains(tmpfeatures[index].getType())) { allFeatures.addElement(tmpfeatures[index].getType()); } index ++; } } if(!alignmentHasFeatures) { // try // { frame.setClosed(true); } // catch (Exception ex){} // JOptionPane.showInternalMessageDialog( /// Desktop.desktop, "No features have been added to this alignment!", // // return; } resetTable(false); } void resetTable(boolean groupsChanged) { SequenceFeature [] tmpfeatures; String group=null, type; Vector visibleChecks = new Vector(); //Find out which features should be visible depending on which groups //are selected / deselected for (int i = 0; i < af.getViewport().alignment.getHeight(); i++) { tmpfeatures = af.getViewport().alignment.getSequenceAt(i).getDatasetSequence().getSequenceFeatures(); if (tmpfeatures == null) continue; int index = 0; while (index < tmpfeatures.length) { group = tmpfeatures[index].featureGroup; if(tmpfeatures[index].begin==0 && tmpfeatures[index].end==0) { index ++; continue; } if (group==null || fr.featureGroups.get(group)==null || ((Boolean) fr.featureGroups.get(group)).booleanValue()) { type = tmpfeatures[index].getType(); if(!visibleChecks.contains(type) ) { visibleChecks.addElement(type); } } index++; } } int fSize = visibleChecks.size(); Object [][] data = new Object[fSize][3]; int dataIndex = 0; if(fr.renderOrder!=null) { //First add the checks in the previous render order, //in case the window has been closed and reopened for(int ro=fr.renderOrder.length-1; ro>-1; ro--) { type = fr.renderOrder[ro]; if(!visibleChecks.contains(type)) continue; data[dataIndex][0] = type; data[dataIndex][1] = fr.getColour(type); data[dataIndex][2] = new Boolean(af.getViewport().featuresDisplayed.containsKey(type)); dataIndex++; visibleChecks.removeElement(type); } } fSize = visibleChecks.size(); for(int i=0; i0) { iSize = af.getViewport().getSelectionGroup().getSize(false); dataset = new SequenceI[iSize]; seqs = af.getViewport().getSelectionGroup(). getSequencesInOrder( af.getViewport().getAlignment()); } else { iSize = af.getViewport().getAlignment().getHeight(); seqs = af.getViewport().getAlignment().getSequencesArray(); } dataset = new SequenceI[iSize]; for (int i = 0; i < iSize; i++) { dataset[i] = seqs[i].getDatasetSequence(); } new jalview.io.DasSequenceFeatureFetcher( dataset, af, selectedSources); af.getViewport().setShowSequenceFeatures(true); af.showSeqFeatures.setSelected(true); } public void saveDAS_actionPerformed(ActionEvent e) { dassourceBrowser.saveProperties(jalview.bin.Cache.applicationProperties); } ///////////////////////////////////////////////////////////////////////// // http://java.sun.com/docs/books/tutorial/uiswing/components/table.html ///////////////////////////////////////////////////////////////////////// class FeatureTableModel extends AbstractTableModel { FeatureTableModel(Object[][] data) { this.data = data; } private String[] columnNames = {"Feature Type", "Colour","Display"}; private Object[][] data; public Object[][] getData() { return data; } public void setData(Object[][] data) { this.data = data; } public int getColumnCount() { return columnNames.length; } public Object[] getRow(int row) { return data[row]; } public int getRowCount() { return data.length; } public String getColumnName(int col) { return columnNames[col]; } public Object getValueAt(int row, int col) { return data[row][col]; } public Class getColumnClass(int c) { return getValueAt(0, c).getClass(); } public boolean isCellEditable(int row, int col) { return col==0 ? false:true; } public void setValueAt(Object value, int row, int col) { data[row][col] = value; fireTableCellUpdated(row, col); updateFeatureRenderer(data); } } class ColorRenderer extends JLabel implements TableCellRenderer { javax.swing.border.Border unselectedBorder = null; javax.swing.border.Border selectedBorder = null; public ColorRenderer() { setOpaque(true); //MUST do this for background to show up. } public Component getTableCellRendererComponent( JTable table, Object color, boolean isSelected, boolean hasFocus, int row, int column) { Color newColor = (Color)color; setBackground(newColor); if (isSelected) { if (selectedBorder == null) { selectedBorder = BorderFactory.createMatteBorder(2,5,2,5, table.getSelectionBackground()); } setBorder(selectedBorder); } else { if (unselectedBorder == null) { unselectedBorder = BorderFactory.createMatteBorder(2,5,2,5, table.getBackground()); } setBorder(unselectedBorder); } setToolTipText("RGB value: " + newColor.getRed() + ", " + newColor.getGreen() + ", " + newColor.getBlue()); return this; } } } class ColorEditor extends AbstractCellEditor implements TableCellEditor, ActionListener { Color currentColor; JButton button; JColorChooser colorChooser; JDialog dialog; protected static final String EDIT = "edit"; public ColorEditor() { //Set up the editor (from the table's point of view), //which is a button. //This button brings up the color chooser dialog, //which is the editor from the user's point of view. button = new JButton(); button.setActionCommand(EDIT); button.addActionListener(this); button.setBorderPainted(false); //Set up the dialog that the button brings up. colorChooser = new JColorChooser(); dialog = JColorChooser.createDialog(button, "Select new Colour", true, //modal colorChooser, this, //OK button handler null); //no CANCEL button handler } /** * Handles events from the editor button and from * the dialog's OK button. */ public void actionPerformed(ActionEvent e) { if (EDIT.equals(e.getActionCommand())) { //The user has clicked the cell, so //bring up the dialog. button.setBackground(currentColor); colorChooser.setColor(currentColor); dialog.setVisible(true); //Make the renderer reappear. fireEditingStopped(); } else { //User pressed dialog's "OK" button. currentColor = colorChooser.getColor(); } } //Implement the one CellEditor method that AbstractCellEditor doesn't. public Object getCellEditorValue() { return currentColor; } //Implement the one method defined by TableCellEditor. public Component getTableCellEditorComponent(JTable table, Object value, boolean isSelected, int row, int column) { currentColor = (Color)value; return button; } }