+ private void deleteSelectedNodes( final boolean delete ) {\r
+ final Phylogeny phy = getMainPanel().getCurrentPhylogeny();\r
+ if ( ( phy == null ) || ( phy.getNumberOfExternalNodes() < 2 ) ) {\r
+ return;\r
+ }\r
+ final List<PhylogenyNode> nodes = new ArrayList<PhylogenyNode>();\r
+ if ( ( getCurrentTreePanel().getFoundNodes0() != null ) || ( getCurrentTreePanel().getFoundNodes1() != null ) ) {\r
+ final List<PhylogenyNode> all_selected_nodes = getCurrentTreePanel().getFoundNodesAsListOfPhylogenyNodes();\r
+ for( final PhylogenyNode n : all_selected_nodes ) {\r
+ if ( n.isExternal() ) {\r
+ nodes.add( n );\r
+ }\r
+ }\r
+ }\r
+ String function = "Retain";\r
+ if ( delete ) {\r
+ function = "Delete";\r
+ }\r
+ if ( ( nodes == null ) || nodes.isEmpty() ) {\r
+ JOptionPane\r
+ .showMessageDialog( this,\r
+ "Need to select external nodes, either via direct selection or via the \"Search\" function",\r
+ "No external nodes selected to " + function.toLowerCase(),\r
+ JOptionPane.ERROR_MESSAGE );\r
+ return;\r
+ }\r
+ final int todo = nodes.size();\r
+ final int ext = phy.getNumberOfExternalNodes();\r
+ int res = todo;\r
+ if ( delete ) {\r
+ res = ext - todo;\r
+ }\r
+ if ( res < 1 ) {\r
+ JOptionPane.showMessageDialog( this,\r
+ "Cannot delete all nodes",\r
+ "Attempt to delete all nodes ",\r
+ JOptionPane.ERROR_MESSAGE );\r
+ return;\r
+ }\r
+ final int result = JOptionPane.showConfirmDialog( null, function + " " + todo\r
+ + " external node(s), from a total of " + ext + " external nodes," + "\nresulting in tree with " + res\r
+ + " nodes?", function + " external nodes", JOptionPane.OK_CANCEL_OPTION );\r
+ if ( result == JOptionPane.OK_OPTION ) {\r
+ if ( !delete ) {\r
+ final List<PhylogenyNode> to_delete = new ArrayList<PhylogenyNode>();\r
+ for( final PhylogenyNodeIterator it = phy.iteratorExternalForward(); it.hasNext(); ) {\r
+ final PhylogenyNode n = it.next();\r
+ if ( !nodes.contains( n ) ) {\r
+ to_delete.add( n );\r
+ }\r
+ }\r
+ for( final PhylogenyNode n : to_delete ) {\r
+ phy.deleteSubtree( n, true );\r
+ }\r
+ }\r
+ else {\r
+ for( final PhylogenyNode n : nodes ) {\r
+ phy.deleteSubtree( n, true );\r
+ }\r
+ }\r
+ resetSearch();\r
+ getCurrentTreePanel().setNodeInPreorderToNull();\r
+ phy.externalNodesHaveChanged();\r
+ phy.clearHashIdToNodeMap();\r
+ phy.recalculateNumberOfExternalDescendants( true );\r
+ getCurrentTreePanel().resetNodeIdToDistToLeafMap();\r
+ getCurrentTreePanel().setEdited( true );\r
+ repaint();\r
+ }\r
+ }\r
+\r
+ private void doUpdateProcessMenu() {\r
+ if ( _process_pool.size() > 0 ) {\r
+ if ( _process_menu == null ) {\r
+ _process_menu = createMenu( "", getConfiguration() );\r
+ _process_menu.setForeground( Color.RED );\r
+ }\r
+ _process_menu.removeAll();\r
+ final String text = "processes running: " + _process_pool.size();\r
+ _process_menu.setText( text );\r
+ _jmenubar.add( _process_menu );\r
+ for( int i = 0; i < _process_pool.size(); ++i ) {\r
+ final ProcessRunning p = _process_pool.getProcessByIndex( i );\r
+ _process_menu.add( customizeJMenuItem( new JMenuItem( p.getName() + " [" + p.getStart() + "]" ) ) );\r
+ }\r
+ }\r
+ else {\r
+ if ( _process_menu != null ) {\r
+ _process_menu.removeAll();\r
+ _jmenubar.remove( _process_menu );\r
+ }\r
+ }\r
+ _jmenubar.validate();\r
+ _jmenubar.repaint();\r
+ repaint();\r
+ }\r
+\r
+ private String getPreviousNodeAnnotationReference() {\r
+ return _previous_node_annotation_ref;\r
+ }\r
+\r
+ private void removeBranchColors() {\r
+ if ( getMainPanel().getCurrentPhylogeny() != null ) {\r
+ AptxUtil.removeBranchColors( getMainPanel().getCurrentPhylogeny() );\r
+ }\r
+ }\r
+\r
+ private void removeVisualStyles() {\r
+ if ( getMainPanel().getCurrentPhylogeny() != null ) {\r
+ AptxUtil.removeVisualStyles( getMainPanel().getCurrentPhylogeny() );\r
+ }\r
+ }\r
+\r
+ private void setPreviousNodeAnnotationReference( final String previous_node_annotation_ref ) {\r
+ _previous_node_annotation_ref = previous_node_annotation_ref;\r
+ }\r
+\r
+ private void writeAllToFile() {\r
+ if ( ( getMainPanel().getTabbedPane() == null ) || ( getMainPanel().getTabbedPane().getTabCount() < 1 ) ) {\r
+ return;\r
+ }\r
+ final File my_dir = getCurrentDir();\r
+ if ( my_dir != null ) {\r
+ _save_filechooser.setCurrentDirectory( my_dir );\r
+ }\r
+ _save_filechooser.setSelectedFile( new File( "" ) );\r
+ final int result = _save_filechooser.showSaveDialog( _contentpane );\r
+ final File file = _save_filechooser.getSelectedFile();\r
+ setCurrentDir( _save_filechooser.getCurrentDirectory() );\r
+ if ( ( file != null ) && ( result == JFileChooser.APPROVE_OPTION ) ) {\r
+ if ( file.exists() ) {\r
+ final int i = JOptionPane.showConfirmDialog( this,\r
+ file + " already exists. Overwrite?",\r
+ "Warning",\r
+ JOptionPane.OK_CANCEL_OPTION,\r
+ JOptionPane.WARNING_MESSAGE );\r
+ if ( i != JOptionPane.OK_OPTION ) {\r
+ return;\r
+ }\r
+ else {\r
+ try {\r
+ file.delete();\r
+ }\r
+ catch ( final Exception e ) {\r
+ JOptionPane.showMessageDialog( this,\r
+ "Failed to delete: " + file,\r
+ "Error",\r
+ JOptionPane.WARNING_MESSAGE );\r
+ }\r
+ }\r
+ }\r
+ final int count = getMainPanel().getTabbedPane().getTabCount();\r
+ final List<Phylogeny> trees = new ArrayList<Phylogeny>();\r
+ for( int i = 0; i < count; ++i ) {\r
+ final Phylogeny phy = getMainPanel().getPhylogeny( i );\r
+ if ( ForesterUtil.isEmpty( phy.getName() )\r
+ && !ForesterUtil.isEmpty( getMainPanel().getTabbedPane().getTitleAt( i ) ) ) {\r
+ phy.setName( getMainPanel().getTabbedPane().getTitleAt( i ) );\r
+ }\r
+ trees.add( phy );\r
+ getMainPanel().getTreePanels().get( i ).setEdited( false );\r
+ }\r
+ final PhylogenyWriter writer = new PhylogenyWriter();\r
+ try {\r
+ writer.toPhyloXML( file, trees, 0, ForesterUtil.LINE_SEPARATOR );\r
+ }\r
+ catch ( final IOException e ) {\r
+ JOptionPane.showMessageDialog( this,\r
+ "Failed to write to: " + file,\r
+ "Error",\r
+ JOptionPane.WARNING_MESSAGE );\r
+ }\r
+ }\r
+ }\r
+\r
+ void activateSaveAllIfNeeded() {\r
+ if ( ( getMainPanel().getTabbedPane() != null ) && ( getMainPanel().getTabbedPane().getTabCount() > 1 ) ) {\r
+ _save_all_item.setEnabled( true );\r
+ }\r
+ else {\r
+ _save_all_item.setEnabled( false );\r
+ }\r
+ }\r
+\r
+ void buildFileMenu() {\r
+ _file_jmenu = MainFrame.createMenu( "File", getConfiguration() );\r
+ _file_jmenu.add( _save_item = new JMenuItem( "Save Tree As..." ) );\r
+ _file_jmenu.addSeparator();\r
+ _file_jmenu.add( _write_to_pdf_item = new JMenuItem( "Export to PDF file ..." ) );\r
+ if ( AptxUtil.canWriteFormat( "tif" ) || AptxUtil.canWriteFormat( "tiff" ) || AptxUtil.canWriteFormat( "TIF" ) ) {\r
+ _file_jmenu.add( _write_to_tif_item = new JMenuItem( "Export to TIFF file..." ) );\r
+ }\r
+ _file_jmenu.add( _write_to_png_item = new JMenuItem( "Export to PNG file..." ) );\r
+ _file_jmenu.add( _write_to_jpg_item = new JMenuItem( "Export to JPG file..." ) );\r
+ if ( AptxUtil.canWriteFormat( "gif" ) ) {\r
+ _file_jmenu.add( _write_to_gif_item = new JMenuItem( "Export to GIF file..." ) );\r
+ }\r
+ if ( AptxUtil.canWriteFormat( "bmp" ) ) {\r
+ _file_jmenu.add( _write_to_bmp_item = new JMenuItem( "Export to BMP file..." ) );\r
+ }\r
+ _file_jmenu.addSeparator();\r
+ _file_jmenu.add( _print_item = new JMenuItem( "Print..." ) );\r
+ _file_jmenu.addSeparator();\r
+ _file_jmenu.add( _exit_item = new JMenuItem( "Exit" ) );\r
+ customizeJMenuItem( _save_item );\r
+ customizeJMenuItem( _write_to_pdf_item );\r
+ customizeJMenuItem( _write_to_png_item );\r
+ customizeJMenuItem( _write_to_jpg_item );\r
+ customizeJMenuItem( _write_to_gif_item );\r
+ customizeJMenuItem( _write_to_tif_item );\r
+ customizeJMenuItem( _write_to_bmp_item );\r
+ customizeJMenuItem( _print_item );\r
+ customizeJMenuItem( _exit_item );\r
+ _jmenubar.add( _file_jmenu );\r
+ }\r
+\r
+ void buildFontSizeMenu() {\r
+ _font_size_menu = createMenu( FONT_SIZE_MENU_LABEL, getConfiguration() );\r
+ _font_size_menu.add( _super_tiny_fonts_item = new JMenuItem( "Super Tiny Fonts" ) );\r
+ _font_size_menu.add( _tiny_fonts_item = new JMenuItem( "Tiny Fonts" ) );\r
+ _font_size_menu.add( _small_fonts_item = new JMenuItem( "Small Fonts" ) );\r
+ _font_size_menu.add( _medium_fonts_item = new JMenuItem( "Medium Fonts" ) );\r
+ _font_size_menu.add( _large_fonts_item = new JMenuItem( "Large Fonts" ) );\r
+ customizeJMenuItem( _super_tiny_fonts_item );\r
+ customizeJMenuItem( _tiny_fonts_item );\r
+ customizeJMenuItem( _small_fonts_item );\r
+ customizeJMenuItem( _medium_fonts_item );\r
+ customizeJMenuItem( _large_fonts_item );\r
+ _jmenubar.add( _font_size_menu );\r
+ }\r
+\r
+ void buildHelpMenu() {\r
+ _help_jmenu = createMenu( "Help", getConfiguration() );\r
+ _help_jmenu.add( _help_item = new JMenuItem( "Documentation" ) );\r
+ _help_jmenu.addSeparator();\r
+ _help_jmenu.add( _website_item = new JMenuItem( "Archaeopteryx Home" ) );\r
+ _aptx_ref_item = new JMenuItem( "Archaeopteryx Reference" ); //TODO need to add this...\r
+ _help_jmenu.add( _phyloxml_website_item = new JMenuItem( "phyloXML Home" ) );\r
+ _help_jmenu.add( _phyloxml_ref_item = new JMenuItem( "phyloXML Reference" ) );\r
+ _help_jmenu.addSeparator();\r
+ _help_jmenu.add( _about_item = new JMenuItem( "About" ) );\r
+ customizeJMenuItem( _help_item );\r
+ customizeJMenuItem( _website_item );\r
+ customizeJMenuItem( _phyloxml_website_item );\r
+ customizeJMenuItem( _aptx_ref_item );\r
+ customizeJMenuItem( _phyloxml_ref_item );\r
+ customizeJMenuItem( _about_item );\r
+ _phyloxml_ref_item.setToolTipText( PHYLOXML_REF_TOOL_TIP );\r
+ _aptx_ref_item.setToolTipText( APTX_REF_TOOL_TIP );\r
+ _jmenubar.add( _help_jmenu );\r
+ }\r