--- /dev/null
+
+package org.forester.archaeopteryx;
+
+import java.awt.BorderLayout;
+import java.awt.Container;
+import java.awt.event.ActionEvent;
+import java.awt.event.ActionListener;
+import java.awt.event.ComponentAdapter;
+import java.awt.event.ComponentEvent;
+import java.io.ByteArrayOutputStream;
+import java.io.File;
+import java.io.IOException;
+import java.net.URL;
+import java.util.LinkedList;
+import java.util.List;
+import java.util.NoSuchElementException;
+
+import javax.swing.ButtonGroup;
+import javax.swing.JApplet;
+import javax.swing.JCheckBoxMenuItem;
+import javax.swing.JFileChooser;
+import javax.swing.JMenu;
+import javax.swing.JMenuBar;
+import javax.swing.JMenuItem;
+import javax.swing.JOptionPane;
+import javax.swing.JRadioButtonMenuItem;
+import javax.swing.UIManager;
+import javax.swing.UnsupportedLookAndFeelException;
+import javax.swing.event.ChangeEvent;
+import javax.swing.event.ChangeListener;
+
+import org.apache.commons.codec.binary.Base64;
+import org.forester.archaeopteryx.AptxUtil.GraphicsExportType;
+import org.forester.archaeopteryx.Options.CLADOGRAM_TYPE;
+import org.forester.archaeopteryx.Options.NODE_LABEL_DIRECTION;
+import org.forester.archaeopteryx.Options.PHYLOGENY_GRAPHICS_TYPE;
+import org.forester.io.parsers.nhx.NHXParser.TAXONOMY_EXTRACTION;
+import org.forester.phylogeny.Phylogeny;
+import org.forester.phylogeny.PhylogenyMethods;
+import org.forester.phylogeny.PhylogenyMethods.DESCENDANT_SORT_PRIORITY;
+import org.forester.phylogeny.data.SequenceRelation;
+import org.forester.sdi.GSDI;
+import org.forester.sdi.GSDIR;
+import org.forester.sdi.SDIException;
+import org.forester.util.ForesterConstants;
+import org.forester.util.ForesterUtil;
+import org.forester.util.WindowsUtils;
+
+// Use like this:
+// <applet archive="forester.jar"
+// code="org.forester.archaeopteryx.ArchaeopteryxE.class"
+// codebase="http://www.myserver.org/path/to/forester"
+// width="600"
+// height="500"
+// alt="ArchaeopteryxE is not working on your system (requires at least Sun Java 1.5)!">
+// <param name="url_of_tree_to_load"
+// value="http://www.myserver.org/examples/data/apaf.xml">
+// <param name="config_file"
+// value="http://www.myserver.org/examples/config/config_file.txt">
+// </applet>
+public class ArchaeopteryxE extends JApplet implements ActionListener {
+
+ private final static String NAME = "ArchaeopteryxE";
+ private static final long serialVersionUID = -1220055577935759443L;
+ private Configuration _configuration;
+ private MainPanel _mainpanel;
+ private JMenuBar _jmenubar;
+ private JMenu _options_jmenu;
+ private JMenu _font_size_menu;
+ private JMenuItem _super_tiny_fonts_mi;
+ private JMenuItem _tiny_fonts_mi;
+ private JMenuItem _small_fonts_mi;
+ private JMenuItem _medium_fonts_mi;
+ private JMenuItem _large_fonts_mi;
+ private JMenu _tools_menu;
+ private JMenuItem _taxcolor_item;
+ private JMenuItem _confcolor_item;
+ private JMenuItem _midpoint_root_item;
+ private JMenu _view_jmenu;
+ private JMenuItem _view_as_XML_item;
+ private JMenuItem _view_as_NH_item;
+ private JMenuItem _view_as_nexus_item;
+ private JMenuItem _display_basic_information_item;
+ private JMenu _type_menu;
+ private JCheckBoxMenuItem _rectangular_type_cbmi;
+ private JCheckBoxMenuItem _triangular_type_cbmi;
+ private JCheckBoxMenuItem _curved_type_cbmi;
+ private JCheckBoxMenuItem _convex_type_cbmi;
+ private JCheckBoxMenuItem _euro_type_cbmi;
+ private JCheckBoxMenuItem _rounded_type_cbmi;
+ private JCheckBoxMenuItem _unrooted_type_cbmi;
+ private JCheckBoxMenuItem _circular_type_cbmi;
+ private JMenuItem _help_item;
+ private JMenuItem _about_item;
+ private JMenu _help_jmenu;
+ private JMenuItem _website_item;
+ private JMenuItem _phyloxml_website_item;
+ private JMenuItem _phyloxml_ref_item;
+ private JMenuItem _aptx_ref_item;
+ private JMenuItem _remove_branch_color_item;
+ private JMenuItem _remove_visual_styles_item;
+ private JCheckBoxMenuItem _show_domain_labels;
+ private JCheckBoxMenuItem _show_annotation_ref_source;
+ private JCheckBoxMenuItem _color_labels_same_as_parent_branch;
+ private JCheckBoxMenuItem _abbreviate_scientific_names;
+ private JCheckBoxMenuItem _screen_antialias_cbmi;
+ private JCheckBoxMenuItem _background_gradient_cbmi;
+ private JCheckBoxMenuItem _color_by_taxonomic_group_cbmi;
+ private JRadioButtonMenuItem _non_lined_up_cladograms_rbmi;
+ private JRadioButtonMenuItem _ext_node_dependent_cladogram_rbmi;
+ private Options _options;
+ private JMenuItem _choose_font_mi;
+ private JMenuItem _switch_colors_mi;
+ JCheckBoxMenuItem _label_direction_cbmi;
+ private JCheckBoxMenuItem _show_scale_cbmi;
+ private JCheckBoxMenuItem _search_case_senstive_cbmi;
+ private JCheckBoxMenuItem _search_whole_words_only_cbmi;
+ private JCheckBoxMenuItem _inverse_search_result_cbmi;
+ private JCheckBoxMenuItem _search_with_regex_cbmi;
+ private JCheckBoxMenuItem _show_overview_cbmi;
+ private JMenuItem _choose_minimal_confidence_mi;
+ private JMenuItem _collapse_species_specific_subtrees;
+ private JMenuItem _overview_placment_mi;
+ private ButtonGroup _radio_group_1;
+ private JCheckBoxMenuItem _show_default_node_shapes_internal_cbmi;
+ private JCheckBoxMenuItem _show_default_node_shapes_external_cbmi;
+ private JCheckBoxMenuItem _show_default_node_shapes_for_marked_cbmi;
+ private JMenuItem _cycle_node_shape_mi;
+ private JMenuItem _cycle_node_fill_mi;
+ private JMenuItem _choose_node_size_mi;
+ private JCheckBoxMenuItem _show_confidence_stddev_cbmi;
+ private final LinkedList<TextFrame> _textframes = new LinkedList<TextFrame>();
+ private JMenu _analysis_menu;
+ private JMenuItem _gsdi_item;
+ private JMenuItem _gsdir_item;
+ private Phylogeny _species_tree;
+ private JCheckBoxMenuItem _right_line_up_domains_cbmi;
+ private JCheckBoxMenuItem _line_up_renderable_data_cbmi;
+ // file menu:
+ private JMenuItem _save_item;
+ private JMenuItem _print_item;
+ private JMenuItem _write_to_pdf_item;
+ private JMenuItem _write_to_jpg_item;
+ private JMenuItem _write_to_gif_item;
+ private JMenuItem _write_to_tif_item;
+ private JMenuItem _write_to_png_item;
+ private JMenuItem _write_to_bmp_item;
+ private JMenu _file_jmenu;
+ private JFileChooser _writetopdf_filechooser;
+ private File _current_dir;
+ private JFileChooser _save_filechooser;
+ private JFileChooser _writetographics_filechooser;
+ private JCheckBoxMenuItem _graphics_export_visible_only_cbmi;
+ private JCheckBoxMenuItem _antialias_print_cbmi;
+ private JCheckBoxMenuItem _print_black_and_white_cbmi;
+ private JMenuItem _choose_pdf_width_mi;
+
+ @Override
+ public void actionPerformed( final ActionEvent e ) {
+ final Object o = e.getSource();
+ if ( o == _midpoint_root_item ) {
+ getMainPanel().getCurrentTreePanel().midpointRoot();
+ }
+ else if ( o == _gsdi_item ) {
+ if ( isSubtreeDisplayed() ) {
+ return;
+ }
+ executeGSDI();
+ }
+ else if ( o == _gsdir_item ) {
+ if ( isSubtreeDisplayed() ) {
+ return;
+ }
+ executeGSDIR();
+ }
+ else if ( o == _taxcolor_item ) {
+ getMainPanel().getCurrentTreePanel().taxColor();
+ }
+ else if ( o == _confcolor_item ) {
+ getMainPanel().getCurrentTreePanel().confColor();
+ }
+ else if ( o == _collapse_species_specific_subtrees ) {
+ if ( getCurrentTreePanel() != null ) {
+ getCurrentTreePanel().collapseSpeciesSpecificSubtrees();
+ }
+ }
+ else if ( o == _remove_branch_color_item ) {
+ removeBranchColors();
+ }
+ else if ( o == _remove_visual_styles_item ) {
+ removeVisualStyles();
+ }
+ else if ( o == _switch_colors_mi ) {
+ switchColors();
+ }
+ else if ( o == _display_basic_information_item ) {
+ displayBasicInformation();
+ }
+ else if ( o == _view_as_NH_item ) {
+ viewAsNH();
+ }
+ else if ( o == _view_as_XML_item ) {
+ viewAsXML();
+ }
+ else if ( o == _view_as_nexus_item ) {
+ viewAsNexus();
+ }
+ else if ( o == _super_tiny_fonts_mi ) {
+ if ( getCurrentTreePanel() != null ) {
+ getCurrentTreePanel().setSuperTinyFonts();
+ getCurrentTreePanel().repaint();
+ }
+ }
+ else if ( o == _tiny_fonts_mi ) {
+ if ( getCurrentTreePanel() != null ) {
+ getCurrentTreePanel().setTinyFonts();
+ getCurrentTreePanel().repaint();
+ }
+ }
+ else if ( o == _small_fonts_mi ) {
+ if ( getCurrentTreePanel() != null ) {
+ getCurrentTreePanel().setSmallFonts();
+ getCurrentTreePanel().repaint();
+ }
+ }
+ else if ( o == _medium_fonts_mi ) {
+ if ( getCurrentTreePanel() != null ) {
+ getCurrentTreePanel().setMediumFonts();
+ getCurrentTreePanel().repaint();
+ }
+ }
+ else if ( o == _large_fonts_mi ) {
+ if ( getCurrentTreePanel() != null ) {
+ getCurrentTreePanel().setLargeFonts();
+ getCurrentTreePanel().repaint();
+ }
+ }
+ else if ( o == _choose_font_mi ) {
+ chooseFont();
+ }
+ else if ( o == _choose_minimal_confidence_mi ) {
+ chooseMinimalConfidence();
+ }
+ else if ( o == _choose_node_size_mi ) {
+ MainFrame.chooseNodeSize( getOptions(), this );
+ }
+ else if ( o == _overview_placment_mi ) {
+ MainFrame.cycleOverview( getOptions(), getCurrentTreePanel() );
+ }
+ else if ( o == _cycle_node_fill_mi ) {
+ MainFrame.cycleNodeFill( getOptions() );
+ }
+ else if ( o == _cycle_node_shape_mi ) {
+ MainFrame.cycleNodeShape( getOptions() );
+ }
+ else if ( o == _non_lined_up_cladograms_rbmi ) {
+ updateOptions( getOptions() );
+ _mainpanel.getControlPanel().showWhole();
+ }
+ else if ( o == _ext_node_dependent_cladogram_rbmi ) {
+ updateOptions( getOptions() );
+ _mainpanel.getControlPanel().showWhole();
+ }
+ else if ( o == _search_case_senstive_cbmi ) {
+ updateOptions( getOptions() );
+ getMainPanel().getControlPanel().search0();
+ getMainPanel().getControlPanel().search1();
+ }
+ else if ( o == _search_whole_words_only_cbmi ) {
+ if ( ( _search_with_regex_cbmi != null ) && _search_whole_words_only_cbmi.isSelected() ) {
+ _search_with_regex_cbmi.setSelected( false );
+ }
+ updateOptions( getOptions() );
+ getMainPanel().getControlPanel().search0();
+ getMainPanel().getControlPanel().search1();
+ }
+ else if ( o == _inverse_search_result_cbmi ) {
+ updateOptions( getOptions() );
+ getMainPanel().getControlPanel().search0();
+ getMainPanel().getControlPanel().search1();
+ }
+ else if ( o == _search_with_regex_cbmi ) {
+ if ( ( _search_whole_words_only_cbmi != null ) && _search_with_regex_cbmi.isSelected() ) {
+ _search_whole_words_only_cbmi.setSelected( false );
+ }
+ if ( ( _search_case_senstive_cbmi != null ) && _search_with_regex_cbmi.isSelected() ) {
+ _search_case_senstive_cbmi.setSelected( true );
+ }
+ updateOptions( getOptions() );
+ getMainPanel().getControlPanel().search0();
+ getMainPanel().getControlPanel().search1();
+ }
+ else if ( o == _show_scale_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _show_confidence_stddev_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _label_direction_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _abbreviate_scientific_names ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _show_overview_cbmi ) {
+ updateOptions( getOptions() );
+ if ( getCurrentTreePanel() != null ) {
+ getCurrentTreePanel().updateOvSizes();
+ }
+ }
+ else if ( ( o == _rectangular_type_cbmi ) || ( o == _triangular_type_cbmi ) || ( o == _curved_type_cbmi )
+ || ( o == _convex_type_cbmi ) || ( o == _rounded_type_cbmi ) || ( o == _euro_type_cbmi )
+ || ( o == _unrooted_type_cbmi ) || ( o == _circular_type_cbmi ) ) {
+ typeChanged( o );
+ }
+ else if ( o == _screen_antialias_cbmi ) {
+ updateOptions( getOptions() );
+ setupScreenTextAntialias( getMainPanel().getTreePanels(), isScreenAntialias() );
+ }
+ else if ( o == _background_gradient_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _show_domain_labels ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _color_labels_same_as_parent_branch ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _show_default_node_shapes_internal_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _show_default_node_shapes_external_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _about_item ) {
+ getMainPanel().getMainFrame().about();
+ }
+ else if ( o == _help_item ) {
+ try {
+ AptxUtil.openWebsite( AptxConstants.APTX_DOC_SITE, true, this );
+ }
+ catch ( final IOException e1 ) {
+ ForesterUtil.printErrorMessage( AptxConstants.PRG_NAME, e1.toString() );
+ }
+ }
+ else if ( o == _website_item ) {
+ try {
+ AptxUtil.openWebsite( AptxConstants.APTX_WEB_SITE, true, this );
+ }
+ catch ( final IOException e1 ) {
+ ForesterUtil.printErrorMessage( AptxConstants.PRG_NAME, e1.toString() );
+ }
+ }
+ else if ( o == _phyloxml_website_item ) {
+ try {
+ AptxUtil.openWebsite( AptxConstants.PHYLOXML_WEB_SITE, true, this );
+ }
+ catch ( final IOException e1 ) {
+ ForesterUtil.printErrorMessage( AptxConstants.PRG_NAME, e1.toString() );
+ }
+ }
+ else if ( o == _aptx_ref_item ) {
+ try {
+ AptxUtil.openWebsite( AptxConstants.APTX_REFERENCE_URL, true, this );
+ }
+ catch ( final IOException e1 ) {
+ ForesterUtil.printErrorMessage( AptxConstants.PRG_NAME, e1.toString() );
+ }
+ }
+ else if ( o == _phyloxml_ref_item ) {
+ try {
+ AptxUtil.openWebsite( AptxConstants.PHYLOXML_REFERENCE_URL, true, this );
+ }
+ catch ( final IOException e1 ) {
+ ForesterUtil.printErrorMessage( AptxConstants.PRG_NAME, e1.toString() );
+ }
+ }
+ else if ( o == _color_by_taxonomic_group_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _line_up_renderable_data_cbmi ) {
+ if ( !_line_up_renderable_data_cbmi.isSelected() ) {
+ _right_line_up_domains_cbmi.setSelected( false );
+ }
+ updateOptions( getOptions() );
+ }
+ else if ( o == _right_line_up_domains_cbmi ) {
+ if ( _right_line_up_domains_cbmi.isSelected() ) {
+ _line_up_renderable_data_cbmi.setSelected( true );
+ }
+ updateOptions( getOptions() );
+ }
+ else if ( o == _write_to_pdf_item ) {
+ final File curr_dir = MainFrame.writeToPdf( _mainpanel.getCurrentPhylogeny(),
+ getMainPanel(),
+ _writetopdf_filechooser,
+ _current_dir,
+ getContentPane(),
+ this );
+ if ( curr_dir != null ) {
+ setCurrentDir( curr_dir );
+ }
+ }
+ else if ( o == _write_to_jpg_item ) {
+ final File curr_dir = MainFrame.writeToGraphicsFile( _mainpanel.getCurrentPhylogeny(),
+ GraphicsExportType.JPG,
+ _mainpanel,
+ _writetographics_filechooser,
+ this,
+ getContentPane(),
+ _current_dir );
+ if ( curr_dir != null ) {
+ setCurrentDir( curr_dir );
+ }
+ }
+ else if ( o == _write_to_gif_item ) {
+ final File curr_dir = MainFrame.writeToGraphicsFile( _mainpanel.getCurrentPhylogeny(),
+ GraphicsExportType.GIF,
+ _mainpanel,
+ _writetographics_filechooser,
+ this,
+ getContentPane(),
+ _current_dir );
+ if ( curr_dir != null ) {
+ setCurrentDir( curr_dir );
+ }
+ }
+ else if ( o == _write_to_tif_item ) {
+ final File curr_dir = MainFrame.writeToGraphicsFile( _mainpanel.getCurrentPhylogeny(),
+ GraphicsExportType.TIFF,
+ _mainpanel,
+ _writetographics_filechooser,
+ this,
+ getContentPane(),
+ _current_dir );
+ if ( curr_dir != null ) {
+ setCurrentDir( curr_dir );
+ }
+ }
+ else if ( o == _write_to_bmp_item ) {
+ final File curr_dir = MainFrame.writeToGraphicsFile( _mainpanel.getCurrentPhylogeny(),
+ GraphicsExportType.BMP,
+ _mainpanel,
+ _writetographics_filechooser,
+ this,
+ getContentPane(),
+ _current_dir );
+ if ( curr_dir != null ) {
+ setCurrentDir( curr_dir );
+ }
+ }
+ else if ( o == _write_to_png_item ) {
+ final File curr_dir = MainFrame.writeToGraphicsFile( _mainpanel.getCurrentPhylogeny(),
+ GraphicsExportType.PNG,
+ _mainpanel,
+ _writetographics_filechooser,
+ this,
+ getContentPane(),
+ _current_dir );
+ if ( curr_dir != null ) {
+ setCurrentDir( curr_dir );
+ }
+ }
+ else if ( o == _print_item ) {
+ MainFrame.print( getCurrentTreePanel(), getOptions(), this );
+ }
+ else if ( o == _save_item ) {
+ final File new_dir = MainFrame.writeToFile( _mainpanel.getCurrentPhylogeny(),
+ getMainPanel(),
+ _save_filechooser,
+ _current_dir,
+ getContentPane(),
+ this );
+ if ( new_dir != null ) {
+ setCurrentDir( new_dir );
+ }
+ }
+ else if ( o == _graphics_export_visible_only_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _antialias_print_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _print_black_and_white_cbmi ) {
+ updateOptions( getOptions() );
+ }
+ else if ( o == _choose_pdf_width_mi ) {
+ choosePdfWidth();
+ }
+ repaint();
+ }
+
+ @Override
+ public void destroy() {
+ AptxUtil.printAppletMessage( NAME, "going to be destroyed " );
+ removeAllTextFrames();
+ if ( getMainPanel() != null ) {
+ getMainPanel().terminate();
+ }
+ }
+
+ /**
+ * This method returns the current external node data which
+ * has been selected by the user by clicking the "Return ..."
+ * menu item. This method is expected to be called from Javascript or
+ * something like it.
+ *
+ * @return current external node data as String
+ */
+ public String getCurrentExternalNodesDataBuffer() {
+ return getCurrentTreePanel().getCurrentExternalNodesDataBufferAsString();
+ }
+
+ public int getCurrentExternalNodesDataBufferChangeCounter() {
+ return getCurrentTreePanel().getCurrentExternalNodesDataBufferChangeCounter();
+ }
+
+ public int getCurrentExternalNodesDataBufferLength() {
+ return getCurrentTreePanel().getCurrentExternalNodesDataBufferAsString().length();
+ }
+
+ /**
+ * This method returns the current phylogeny as a string in the chosen format
+ *
+ * @param format must be NH, NHX, NEXUS or PHYLOXML
+ * @return the phylogeny string
+ * @author Herve Menager
+ */
+ public String getCurrentPhylogeny( final String format ) {
+ removeAllTextFrames();
+ if ( ( getMainPanel().getCurrentPhylogeny() == null ) || getMainPanel().getCurrentPhylogeny().isEmpty()
+ || ( getMainPanel().getCurrentPhylogeny().getNumberOfExternalNodes() > 10000 ) ) {
+ return new String();
+ }
+ switch ( ForesterConstants.PhylogeneticTreeFormats.valueOf( format ) ) {
+ case NH:
+ return getMainPanel().getCurrentPhylogeny().toNewHampshire();
+ case NHX:
+ return getMainPanel().getCurrentPhylogeny().toNewHampshireX();
+ case NEXUS:
+ return getMainPanel().getCurrentPhylogeny().toNexus();
+ case PHYLOXML:
+ return getMainPanel().getCurrentPhylogeny().toPhyloXML( -1 );
+ default:
+ break;
+ }
+ return new String();
+ }
+
+ /**
+ * This method returns a view of the current phylogeny in a chosen
+ * graphics format, base64-encoded in a string so that in can be used
+ * from javascript.
+ *
+ * @param format must be GraphicsExportType (gif, jpg, pdf, png, tif, bmp)
+ * @return the phylogeny string
+ * @author Herve Menager
+ */
+ public String getCurrentPhylogenyGraphicsAsBase64EncodedString( final String format ) {
+ final ByteArrayOutputStream baos = new ByteArrayOutputStream();
+ try {
+ AptxUtil.writePhylogenyToGraphicsByteArrayOutputStream( baos,
+ _mainpanel.getWidth(),
+ _mainpanel.getHeight(),
+ getCurrentTreePanel(),
+ getCurrentTreePanel().getControlPanel(),
+ GraphicsExportType.valueOf( format ),
+ getOptions() );
+ }
+ catch ( final IOException ioe ) {
+ ForesterUtil.printErrorMessage( NAME, ioe.toString() );
+ ioe.printStackTrace();
+ JOptionPane.showMessageDialog( this,
+ NAME + ": Failed to generate graphics: " + "\nException: " + ioe,
+ "Failed to generate graphics",
+ JOptionPane.ERROR_MESSAGE );
+ return null;
+ }
+ final byte[] bytes = baos.toByteArray();
+ final String dataImg = Base64.encodeBase64String( bytes );
+ return dataImg;
+ }
+
+ public Options getOptions() {
+ return _options;
+ }
+
+ @Override
+ public void init() {
+ _writetopdf_filechooser = new JFileChooser();
+ _writetopdf_filechooser.setMultiSelectionEnabled( false );
+ _writetopdf_filechooser.addChoosableFileFilter( MainFrame.pdffilter );
+ _writetographics_filechooser = new JFileChooser();
+ _writetographics_filechooser.setMultiSelectionEnabled( false );
+ _writetographics_filechooser.addChoosableFileFilter( MainFrame.graphicsfilefilter );
+ _save_filechooser = new JFileChooser();
+ _save_filechooser.setMultiSelectionEnabled( false );
+ _save_filechooser.setFileFilter( MainFrame.xmlfilter );
+ _save_filechooser.addChoosableFileFilter( MainFrame.nhfilter );
+ _save_filechooser.addChoosableFileFilter( MainFrame.nexusfilter );
+ _save_filechooser.addChoosableFileFilter( _save_filechooser.getAcceptAllFileFilter() );
+ try {
+ final String home_dir = System.getProperty( "user.home" );
+ _save_filechooser.setCurrentDirectory( new File( home_dir ) );
+ _writetopdf_filechooser.setCurrentDirectory( new File( home_dir ) );
+ _writetographics_filechooser.setCurrentDirectory( new File( home_dir ) );
+ }
+ catch ( final Exception e ) {
+ e.printStackTrace();
+ // Do nothing. Not important.
+ }
+ final String config_filename = getParameter( AptxConstants.APPLET_PARAM_NAME_FOR_CONFIG_FILE_URL );
+ AptxUtil.printAppletMessage( NAME, "URL for configuration file is: " + config_filename );
+ final Configuration configuration = new Configuration( config_filename, true, true, true );
+ setConfiguration( configuration );
+ setOptions( Options.createInstance( configuration ) );
+ setupUI();
+ final String tree_url_str = getParameter( AptxConstants.APPLET_PARAM_NAME_FOR_URL_OF_TREE_TO_LOAD );
+ if ( ForesterUtil.isEmpty( tree_url_str ) ) {
+ ForesterUtil.printErrorMessage( NAME, "could not get tree URL from "
+ + AptxConstants.APPLET_PARAM_NAME_FOR_URL_OF_TREE_TO_LOAD );
+ JOptionPane.showMessageDialog( this, NAME + ": could not get tree URL from "
+ + AptxConstants.APPLET_PARAM_NAME_FOR_URL_OF_TREE_TO_LOAD, "Failed get URL", JOptionPane.ERROR_MESSAGE );
+ return;
+ }
+ AptxUtil.printAppletMessage( NAME, "URL for phylogenies is " + tree_url_str );
+ // Get URL to tree file
+ URL phys_url = null;
+ try {
+ phys_url = new URL( tree_url_str );
+ }
+ catch ( final Exception e ) {
+ ForesterUtil.printErrorMessage( NAME, "error: " + e );
+ e.printStackTrace();
+ JOptionPane.showMessageDialog( this, NAME + ": Could not create URL from: \"" + tree_url_str
+ + "\"\nException: " + e, "Failed to create URL", JOptionPane.ERROR_MESSAGE );
+ }
+ if ( phys_url == null ) {
+ ForesterUtil.printErrorMessage( NAME, "failed to get tree URL from "
+ + AptxConstants.APPLET_PARAM_NAME_FOR_URL_OF_TREE_TO_LOAD );
+ JOptionPane.showMessageDialog( this,
+ NAME + ": Could not create URL from: \"" + tree_url_str,
+ "Failed to create URL",
+ JOptionPane.ERROR_MESSAGE );
+ return;
+ }
+ // Load the tree from URL
+ Phylogeny[] phys = null;
+ try {
+ phys = AptxUtil.readPhylogeniesFromUrl( phys_url,
+ getConfiguration().isValidatePhyloXmlAgainstSchema(),
+ getConfiguration().isReplaceUnderscoresInNhParsing(),
+ getConfiguration().isInternalNumberAreConfidenceForNhParsing(),
+ getConfiguration().getTaxonomyExtraction(),
+ getConfiguration().isMidpointReroot() );
+ }
+ catch ( final Exception e ) {
+ ForesterUtil.printErrorMessage( NAME, e.toString() );
+ e.printStackTrace();
+ JOptionPane.showMessageDialog( this,
+ NAME + ": Failed to read phylogenies: " + "\nException: " + e,
+ "Failed to read phylogenies",
+ JOptionPane.ERROR_MESSAGE );
+ }
+ if ( phys == null ) {
+ ForesterUtil.printErrorMessage( NAME, "phylogenies from [" + phys_url + "] are null" );
+ JOptionPane.showMessageDialog( this,
+ NAME + ": phylogenies from [" + phys_url + "] are null",
+ "Failed to read phylogenies",
+ JOptionPane.ERROR_MESSAGE );
+ return;
+ }
+ else if ( phys.length < 1 ) {
+ ForesterUtil.printErrorMessage( NAME, "phylogenies from [" + phys_url + "] are empty" );
+ JOptionPane.showMessageDialog( this,
+ NAME + ": phylogenies from [" + phys_url + "] are empty",
+ "Failed to read phylogenies",
+ JOptionPane.ERROR_MESSAGE );
+ return;
+ }
+ else {
+ AptxUtil.printAppletMessage( NAME, "loaded " + phys.length + " phylogenies from: " + phys_url );
+ }
+ //
+ final String species_tree_url_str = getParameter( AptxConstants.APPLET_PARAM_NAME_FOR_URL_OF_SPECIES_TREE_TO_LOAD );
+ if ( !ForesterUtil.isEmpty( species_tree_url_str ) ) {
+ AptxUtil.printAppletMessage( NAME, "URL of species tree to load: \"" + species_tree_url_str + "\"" );
+ Phylogeny[] species_trees = null;
+ try {
+ final URL species_tree_url = new URL( species_tree_url_str );
+ species_trees = AptxUtil.readPhylogeniesFromUrl( species_tree_url,
+ configuration.isValidatePhyloXmlAgainstSchema(),
+ configuration.isReplaceUnderscoresInNhParsing(),
+ false,
+ TAXONOMY_EXTRACTION.NO,
+ false );
+ }
+ catch ( final IOException e ) {
+ ForesterUtil.printErrorMessage( NAME, "could not read species tree from [" + species_tree_url_str
+ + "]" );
+ JOptionPane.showMessageDialog( this, NAME + ": could not read species tree from ["
+ + species_tree_url_str + "]", "Failed to read species tree", JOptionPane.ERROR_MESSAGE );
+ }
+ if ( ( species_trees != null ) && ( species_trees.length > 0 ) ) {
+ AptxUtil.printAppletMessage( NAME, "successfully read species tree" );
+ if ( species_trees[ 0 ].isEmpty() ) {
+ ForesterUtil.printErrorMessage( NAME, "species tree is empty" );
+ }
+ else if ( !species_trees[ 0 ].isRooted() ) {
+ ForesterUtil.printErrorMessage( NAME, "species tree is not rooted" );
+ }
+ else {
+ setSpeciesTree( species_trees[ 0 ] );
+ AptxUtil.printAppletMessage( NAME, "species tree OK" );
+ }
+ }
+ }
+ try {
+ setVisible( false );
+ setMainPanel( new MainPanelApplets( getConfiguration(), this ) );
+ _jmenubar = new JMenuBar();
+ if ( !getConfiguration().isHideControlPanelAndMenubar() ) {
+ buildFileMenu();
+ if ( !getConfiguration().isUseNativeUI() ) {
+ _jmenubar.setBackground( getConfiguration().getGuiMenuBackgroundColor() );
+ }
+ if ( getSpeciesTree() != null ) {
+ buildAnalysisMenu();
+ }
+ buildToolsMenu();
+ buildViewMenu();
+ buildFontSizeMenu();
+ buildOptionsMenu();
+ buildTypeMenu();
+ buildHelpMenu();
+ setJMenuBar( _jmenubar );
+ }
+ final Container contentpane = getContentPane();
+ contentpane.setLayout( new BorderLayout() );
+ contentpane.add( getMainPanel(), BorderLayout.CENTER );
+ addComponentListener( new ComponentAdapter() {
+
+ @Override
+ public void componentResized( final ComponentEvent e ) {
+ if ( getMainPanel().getCurrentTreePanel() != null ) {
+ getMainPanel().getCurrentTreePanel().calcParametersForPainting( getMainPanel()
+ .getCurrentTreePanel()
+ .getWidth(),
+ getMainPanel()
+ .getCurrentTreePanel()
+ .getHeight() );
+ }
+ }
+ } );
+ if ( getConfiguration().isUseTabbedDisplay() ) {
+ try {
+ AptxUtil.printAppletMessage( NAME, "using tabbed display" );
+ AptxUtil.addPhylogeniesToTabs( phys,
+ new File( phys_url.getFile() ).getName(),
+ phys_url.toString(),
+ getConfiguration(),
+ getMainPanel() );
+ }
+ catch ( final Exception e ) {
+ ForesterUtil.printErrorMessage( NAME, e.toString() );
+ e.printStackTrace();
+ }
+ }
+ else {
+ AptxUtil.printAppletMessage( NAME, "not using tabbed display" );
+ if ( getSpeciesTree() != null ) {
+ AptxUtil.printAppletMessage( NAME,
+ "Warning: gsdi (gene duplication inference) only available tabbed display" );
+ }
+ AptxUtil.addPhylogenyToPanel( phys, getConfiguration(), getMainPanel() );
+ }
+ validate();
+ setName( NAME );
+ getMainPanel().getControlPanel().showWholeAll();
+ getMainPanel().getControlPanel().showWhole();
+ /* GUILHEM_BEG */
+ getCurrentTreePanel().getControlPanel().getSequenceRelationTypeBox().removeAllItems();
+ for( final SequenceRelation.SEQUENCE_RELATION_TYPE type : getMainPanel().getCurrentPhylogeny()
+ .getRelevantSequenceRelationTypes() ) {
+ getCurrentTreePanel().getControlPanel().getSequenceRelationTypeBox().addItem( type );
+ }
+ final String default_relation = getParameter( AptxConstants.APPLET_PARAM_NAME_FOR_DEFAULT_SEQUENCE_RELATION_TYPE );
+ if ( default_relation != null ) {
+ getCurrentTreePanel().getControlPanel().getSequenceRelationTypeBox().setSelectedItem( default_relation );
+ }
+ final String default_sequence = getParameter( AptxConstants.APPLET_PARAM_NAME_FOR_DEFAULT_QUERY_SEQUENCE );
+ if ( default_sequence != null ) {
+ getCurrentTreePanel().getControlPanel().getSequenceRelationBox().setSelectedItem( default_sequence );
+ }
+ /* GUILHEM_END */
+ System.gc();
+ AptxUtil.printAppletMessage( NAME, "successfully initialized" );
+ setVisible( true );
+ }
+ catch ( final Exception e ) {
+ ForesterUtil.printErrorMessage( NAME, e.toString() );
+ e.printStackTrace();
+ }
+ }
+
+ public void showTextFrame( final String s, final String title ) {
+ checkTextFrames();
+ _textframes.addLast( TextFrame.instantiate( s, title, _textframes ) );
+ }
+
+ @Override
+ public void start() {
+ if ( getMainPanel() != null ) {
+ getMainPanel().validate();
+ }
+ requestFocus();
+ requestFocusInWindow();
+ requestFocus();
+ AptxUtil.printAppletMessage( NAME, "started" );
+ }
+
+ private void chooseFont() {
+ final FontChooser fc = new FontChooser();
+ fc.setFont( getMainPanel().getTreeFontSet().getLargeFont() );
+ fc.showDialog( this, "Select the Base Font" );
+ getMainPanel().getTreeFontSet().setBaseFont( fc.getFont() );
+ }
+
+ private void chooseMinimalConfidence() {
+ final String s = ( String ) JOptionPane
+ .showInputDialog( this,
+ "Please the minimum for confidence values to be displayed.\n" + "[current value: "
+ + getOptions().getMinConfidenceValue() + "]\n",
+ "Minimal Confidence Value",
+ JOptionPane.QUESTION_MESSAGE,
+ null,
+ null,
+ getOptions().getMinConfidenceValue() );
+ if ( !ForesterUtil.isEmpty( s ) ) {
+ boolean success = true;
+ double m = 0.0;
+ final String m_str = s.trim();
+ if ( !ForesterUtil.isEmpty( m_str ) ) {
+ try {
+ m = Double.parseDouble( m_str );
+ }
+ catch ( final Exception ex ) {
+ success = false;
+ }
+ }
+ else {
+ success = false;
+ }
+ if ( success && ( m >= 0.0 ) ) {
+ getOptions().setMinConfidenceValue( m );
+ }
+ }
+ }
+
+ private void choosePdfWidth() {
+ final String s = ( String ) JOptionPane.showInputDialog( this,
+ "Please enter the default line width for PDF export.\n"
+ + "[current value: "
+ + getOptions().getPrintLineWidth() + "]\n",
+ "Line Width for PDF Export",
+ JOptionPane.QUESTION_MESSAGE,
+ null,
+ null,
+ getOptions().getPrintLineWidth() );
+ if ( !ForesterUtil.isEmpty( s ) ) {
+ boolean success = true;
+ float f = 0.0f;
+ final String m_str = s.trim();
+ if ( !ForesterUtil.isEmpty( m_str ) ) {
+ try {
+ f = Float.parseFloat( m_str );
+ }
+ catch ( final Exception ex ) {
+ success = false;
+ }
+ }
+ else {
+ success = false;
+ }
+ if ( success && ( f > 0.0 ) ) {
+ getOptions().setPrintLineWidth( f );
+ }
+ }
+ }
+
+ private void customizeRadioButtonMenuItem( final JRadioButtonMenuItem item, final boolean is_selected ) {
+ if ( item != null ) {
+ item.setFont( MainFrame.menu_font );
+ if ( !getConfiguration().isUseNativeUI() ) {
+ item.setBackground( getConfiguration().getGuiMenuBackgroundColor() );
+ item.setForeground( getConfiguration().getGuiMenuTextColor() );
+ }
+ item.setSelected( is_selected );
+ item.addActionListener( this );
+ }
+ }
+
+ private Phylogeny getSpeciesTree() {
+ return _species_tree;
+ }
+
+ private boolean isScreenAntialias() {
+ return true;
+ }
+
+ private void removeBranchColors() {
+ if ( getMainPanel().getCurrentPhylogeny() != null ) {
+ AptxUtil.removeBranchColors( getMainPanel().getCurrentPhylogeny() );
+ }
+ }
+
+ private void removeVisualStyles() {
+ if ( getMainPanel().getCurrentPhylogeny() != null ) {
+ AptxUtil.removeVisualStyles( getMainPanel().getCurrentPhylogeny() );
+ }
+ }
+
+ private void setMainPanel( final MainPanelApplets main_panel ) {
+ _mainpanel = main_panel;
+ }
+
+ private void setSpeciesTree( final Phylogeny species_tree ) {
+ _species_tree = species_tree;
+ }
+
+ private void setupUI() {
+ try {
+ if ( getConfiguration().isUseNativeUI() ) {
+ UIManager.setLookAndFeel( UIManager.getSystemLookAndFeelClassName() );
+ }
+ else {
+ UIManager.setLookAndFeel( UIManager.getCrossPlatformLookAndFeelClassName() );
+ }
+ }
+ catch ( final UnsupportedLookAndFeelException e ) {
+ AptxUtil.dieWithSystemError( "UnsupportedLookAndFeelException: " + e.toString() );
+ }
+ catch ( final ClassNotFoundException e ) {
+ AptxUtil.dieWithSystemError( "ClassNotFoundException: " + e.toString() );
+ }
+ catch ( final InstantiationException e ) {
+ AptxUtil.dieWithSystemError( "InstantiationException: " + e.toString() );
+ }
+ catch ( final IllegalAccessException e ) {
+ AptxUtil.dieWithSystemError( "IllegalAccessException: " + e.toString() );
+ }
+ catch ( final Exception e ) {
+ AptxUtil.dieWithSystemError( e.toString() );
+ }
+ }
+
+ void buildAnalysisMenu() {
+ _analysis_menu = MainFrame.createMenu( "Analysis", getConfiguration() );
+ _analysis_menu.add( _gsdi_item = new JMenuItem( "GSDI (Generalized Speciation Duplication Inference)" ) );
+ _analysis_menu.add( _gsdir_item = new JMenuItem( "GSDIR (GSDI with re-rooting)" ) );
+ customizeJMenuItem( _gsdi_item );
+ customizeJMenuItem( _gsdir_item );
+ _analysis_menu.addSeparator();
+ _jmenubar.add( _analysis_menu );
+ }
+
+ void buildFileMenu() {
+ _file_jmenu = MainFrame.createMenu( "File", getConfiguration() );
+ _file_jmenu.add( _save_item = new JMenuItem( "Save Tree As..." ) );
+ _file_jmenu.addSeparator();
+ _file_jmenu.add( _write_to_pdf_item = new JMenuItem( "Export to PDF file ..." ) );
+ if ( AptxUtil.canWriteFormat( "tif" ) || AptxUtil.canWriteFormat( "tiff" ) || AptxUtil.canWriteFormat( "TIF" ) ) {
+ _file_jmenu.add( _write_to_tif_item = new JMenuItem( "Export to TIFF file..." ) );
+ }
+ _file_jmenu.add( _write_to_png_item = new JMenuItem( "Export to PNG file..." ) );
+ _file_jmenu.add( _write_to_jpg_item = new JMenuItem( "Export to JPG file..." ) );
+ if ( AptxUtil.canWriteFormat( "gif" ) ) {
+ _file_jmenu.add( _write_to_gif_item = new JMenuItem( "Export to GIF file..." ) );
+ }
+ if ( AptxUtil.canWriteFormat( "bmp" ) ) {
+ _file_jmenu.add( _write_to_bmp_item = new JMenuItem( "Export to BMP file..." ) );
+ }
+ _file_jmenu.addSeparator();
+ _file_jmenu.add( _print_item = new JMenuItem( "Print..." ) );
+ customizeJMenuItem( _save_item );
+ customizeJMenuItem( _write_to_pdf_item );
+ customizeJMenuItem( _write_to_png_item );
+ customizeJMenuItem( _write_to_jpg_item );
+ customizeJMenuItem( _write_to_gif_item );
+ customizeJMenuItem( _write_to_tif_item );
+ customizeJMenuItem( _write_to_bmp_item );
+ customizeJMenuItem( _print_item );
+ _jmenubar.add( _file_jmenu );
+ }
+
+ void buildFontSizeMenu() {
+ _font_size_menu = MainFrame.createMenu( MainFrame.FONT_SIZE_MENU_LABEL, getConfiguration() );
+ _font_size_menu.add( _super_tiny_fonts_mi = new JMenuItem( "Super tiny fonts" ) );
+ _font_size_menu.add( _tiny_fonts_mi = new JMenuItem( "Tiny fonts" ) );
+ _font_size_menu.add( _small_fonts_mi = new JMenuItem( "Small fonts" ) );
+ _font_size_menu.add( _medium_fonts_mi = new JMenuItem( "Medium fonts" ) );
+ _font_size_menu.add( _large_fonts_mi = new JMenuItem( "Large fonts" ) );
+ customizeJMenuItem( _super_tiny_fonts_mi );
+ customizeJMenuItem( _tiny_fonts_mi );
+ customizeJMenuItem( _small_fonts_mi );
+ customizeJMenuItem( _medium_fonts_mi );
+ customizeJMenuItem( _large_fonts_mi );
+ _jmenubar.add( _font_size_menu );
+ }
+
+ void buildHelpMenu() {
+ _help_jmenu = MainFrame.createMenu( "Help", getConfiguration() );
+ _help_jmenu.add( _help_item = new JMenuItem( "Documentation" ) );
+ _help_jmenu.addSeparator();
+ _help_jmenu.add( _website_item = new JMenuItem( "Archaeopteryx Home" ) );
+ _aptx_ref_item = new JMenuItem( "Archaeopteryx Reference" );
+ _help_jmenu.add( _phyloxml_website_item = new JMenuItem( "phyloXML Home" ) );
+ _help_jmenu.add( _phyloxml_ref_item = new JMenuItem( "phyloXML Reference" ) );
+ _help_jmenu.addSeparator();
+ _help_jmenu.add( _about_item = new JMenuItem( "About" ) );
+ customizeJMenuItem( _help_item );
+ customizeJMenuItem( _website_item );
+ customizeJMenuItem( _phyloxml_website_item );
+ customizeJMenuItem( _aptx_ref_item );
+ customizeJMenuItem( _phyloxml_ref_item );
+ customizeJMenuItem( _about_item );
+ _phyloxml_ref_item.setToolTipText( MainFrame.PHYLOXML_REF_TOOL_TIP );
+ _aptx_ref_item.setToolTipText( MainFrame.APTX_REF_TOOL_TIP );
+ _jmenubar.add( _help_jmenu );
+ }
+
+ void buildOptionsMenu() {
+ _options_jmenu = MainFrame.createMenu( MainFrame.OPTIONS_HEADER, getConfiguration() );
+ _options_jmenu.addChangeListener( new ChangeListener() {
+
+ @Override
+ public void stateChanged( final ChangeEvent e ) {
+ MainFrame.setOvPlacementColorChooseMenuItem( _overview_placment_mi, getOptions() );
+ MainFrame.setTextColorChooseMenuItem( _switch_colors_mi, getCurrentTreePanel() );
+ MainFrame
+ .setTextMinSupportMenuItem( _choose_minimal_confidence_mi, getOptions(), getCurrentTreePanel() );
+ MainFrame.setTextForFontChooserMenuItem( _choose_font_mi, MainFrame
+ .createCurrentFontDesc( getMainPanel().getTreeFontSet() ) );
+ setTextForPdfLineWidthChooserMenuItem( _choose_pdf_width_mi, getOptions() );
+ MainFrame.setCycleNodeFillMenuItem( _cycle_node_fill_mi, getOptions() );
+ MainFrame.setCycleNodeShapeMenuItem( _cycle_node_shape_mi, getOptions() );
+ MainFrame.setTextNodeSizeMenuItem( _choose_node_size_mi, getOptions() );
+ try {
+ getMainPanel().getControlPanel().setVisibilityOfDomainStrucureCB();
+ getMainPanel().getControlPanel().setVisibilityOfX();
+ }
+ catch ( final Exception ignore ) {
+ // do nothing, not important.
+ }
+ }
+ } );
+ _options_jmenu.add( MainFrame.customizeMenuItemAsLabel( new JMenuItem( MainFrame.DISPLAY_SUBHEADER ),
+ getConfiguration() ) );
+ _options_jmenu
+ .add( _ext_node_dependent_cladogram_rbmi = new JRadioButtonMenuItem( MainFrame.NONUNIFORM_CLADOGRAMS_LABEL ) );
+ _options_jmenu
+ .add( _non_lined_up_cladograms_rbmi = new JRadioButtonMenuItem( MainFrame.NON_LINED_UP_CLADOGRAMS_LABEL ) );
+ _radio_group_1 = new ButtonGroup();
+ _radio_group_1.add( _ext_node_dependent_cladogram_rbmi );
+ _radio_group_1.add( _non_lined_up_cladograms_rbmi );
+ _options_jmenu.add( _show_overview_cbmi = new JCheckBoxMenuItem( MainFrame.SHOW_OVERVIEW_LABEL ) );
+ _options_jmenu.add( _show_scale_cbmi = new JCheckBoxMenuItem( MainFrame.DISPLAY_SCALE_LABEL ) );
+ _options_jmenu
+ .add( _show_default_node_shapes_internal_cbmi = new JCheckBoxMenuItem( MainFrame.DISPLAY_NODE_BOXES_LABEL_INT ) );
+ _options_jmenu
+ .add( _show_default_node_shapes_external_cbmi = new JCheckBoxMenuItem( MainFrame.DISPLAY_NODE_BOXES_LABEL_EXT ) );
+ _options_jmenu
+ .add( _show_default_node_shapes_for_marked_cbmi = new JCheckBoxMenuItem( MainFrame.DISPLAY_NODE_BOXES_LABEL_MARKED ) );
+ _options_jmenu.add( _line_up_renderable_data_cbmi = new JCheckBoxMenuItem( MainFrame.LINE_UP_RENDERABLE_DATA ) );
+ if ( getConfiguration().doDisplayOption( Configuration.show_domain_architectures ) ) {
+ _options_jmenu.add( _right_line_up_domains_cbmi = new JCheckBoxMenuItem( MainFrame.RIGHT_LINE_UP_DOMAINS ) );
+ _options_jmenu.add( _show_domain_labels = new JCheckBoxMenuItem( MainFrame.SHOW_DOMAIN_LABELS_LABEL ) );
+ }
+ _options_jmenu.add( _show_annotation_ref_source = new JCheckBoxMenuItem( MainFrame.SHOW_ANN_REF_SOURCE_LABEL ) );
+ _options_jmenu.add( _show_confidence_stddev_cbmi = new JCheckBoxMenuItem( MainFrame.SHOW_CONF_STDDEV_LABEL ) );
+ _options_jmenu
+ .add( _color_by_taxonomic_group_cbmi = new JCheckBoxMenuItem( MainFrame.COLOR_BY_TAXONOMIC_GROUP ) );
+ _options_jmenu
+ .add( _color_labels_same_as_parent_branch = new JCheckBoxMenuItem( MainFrame.COLOR_LABELS_LABEL ) );
+ _color_labels_same_as_parent_branch.setToolTipText( MainFrame.COLOR_LABELS_TIP );
+ _options_jmenu.add( _abbreviate_scientific_names = new JCheckBoxMenuItem( MainFrame.ABBREV_SN_LABEL ) );
+ _options_jmenu.add( _label_direction_cbmi = new JCheckBoxMenuItem( MainFrame.LABEL_DIRECTION_LABEL ) );
+ _label_direction_cbmi.setToolTipText( MainFrame.LABEL_DIRECTION_TIP );
+ _options_jmenu.add( _screen_antialias_cbmi = new JCheckBoxMenuItem( MainFrame.SCREEN_ANTIALIAS_LABEL ) );
+ _options_jmenu.add( _background_gradient_cbmi = new JCheckBoxMenuItem( MainFrame.BG_GRAD_LABEL ) );
+ _options_jmenu.add( _cycle_node_shape_mi = new JMenuItem( MainFrame.CYCLE_NODE_SHAPE_LABEL ) );
+ _options_jmenu.add( _cycle_node_fill_mi = new JMenuItem( MainFrame.CYCLE_NODE_FILL_LABEL ) );
+ _options_jmenu.add( _choose_node_size_mi = new JMenuItem( MainFrame.CHOOSE_NODE_SIZE_LABEL ) );
+ _options_jmenu.add( _choose_minimal_confidence_mi = new JMenuItem( "" ) );
+ _options_jmenu.add( _overview_placment_mi = new JMenuItem( "" ) );
+ _options_jmenu.add( _switch_colors_mi = new JMenuItem( "" ) );
+ _options_jmenu.add( _choose_font_mi = new JMenuItem( "" ) );
+ _options_jmenu.addSeparator();
+ _options_jmenu.add( MainFrame.customizeMenuItemAsLabel( new JMenuItem( MainFrame.SEARCH_SUBHEADER ),
+ getConfiguration() ) );
+ _options_jmenu
+ .add( _search_case_senstive_cbmi = new JCheckBoxMenuItem( MainFrame.SEARCH_CASE_SENSITIVE_LABEL ) );
+ _options_jmenu.add( _search_whole_words_only_cbmi = new JCheckBoxMenuItem( MainFrame.SEARCH_TERMS_ONLY_LABEL ) );
+ _options_jmenu.add( _search_with_regex_cbmi = new JCheckBoxMenuItem( MainFrame.SEARCH_REGEX_LABEL ) );
+ _search_with_regex_cbmi.setToolTipText( MainFrame.SEARCH_WITH_REGEX_TIP );
+ _options_jmenu
+ .add( _inverse_search_result_cbmi = new JCheckBoxMenuItem( MainFrame.INVERSE_SEARCH_RESULT_LABEL ) );
+ //
+ _options_jmenu.addSeparator();
+ _options_jmenu.add( MainFrame.customizeMenuItemAsLabel( new JMenuItem( "Graphics Export & Printing:" ),
+ getConfiguration() ) );
+ _options_jmenu.add( _antialias_print_cbmi = new JCheckBoxMenuItem( "Antialias" ) );
+ _options_jmenu.add( _print_black_and_white_cbmi = new JCheckBoxMenuItem( "Export in Black and White" ) );
+ _options_jmenu
+ .add( _graphics_export_visible_only_cbmi = new JCheckBoxMenuItem( "Limit to Visible ('Screenshot') for PNG, JPG, and GIF export" ) );
+ _options_jmenu.add( _choose_pdf_width_mi = new JMenuItem( "" ) );
+ //
+ customizeCheckBoxMenuItem( _antialias_print_cbmi, getOptions().isAntialiasPrint() );
+ customizeCheckBoxMenuItem( _print_black_and_white_cbmi, getOptions().isPrintBlackAndWhite() );
+ customizeCheckBoxMenuItem( _graphics_export_visible_only_cbmi, getOptions().isGraphicsExportVisibleOnly() );
+ customizeJMenuItem( _choose_pdf_width_mi );
+ //
+ customizeJMenuItem( _choose_font_mi );
+ customizeJMenuItem( _choose_minimal_confidence_mi );
+ customizeJMenuItem( _switch_colors_mi );
+ customizeJMenuItem( _overview_placment_mi );
+ customizeCheckBoxMenuItem( _color_by_taxonomic_group_cbmi, getOptions().isColorByTaxonomicGroup() );
+ customizeCheckBoxMenuItem( _label_direction_cbmi,
+ getOptions().getNodeLabelDirection() == NODE_LABEL_DIRECTION.RADIAL );
+ customizeCheckBoxMenuItem( _screen_antialias_cbmi, getOptions().isAntialiasScreen() );
+ customizeCheckBoxMenuItem( _background_gradient_cbmi, getOptions().isBackgroundColorGradient() );
+ customizeCheckBoxMenuItem( _show_domain_labels, getOptions().isShowDomainLabels() );
+ customizeCheckBoxMenuItem( _show_annotation_ref_source, getOptions().isShowAnnotationRefSource() );
+ customizeCheckBoxMenuItem( _abbreviate_scientific_names, getOptions().isAbbreviateScientificTaxonNames() );
+ customizeCheckBoxMenuItem( _show_default_node_shapes_external_cbmi, getOptions()
+ .isShowDefaultNodeShapesExternal() );
+ customizeCheckBoxMenuItem( _show_default_node_shapes_internal_cbmi, getOptions()
+ .isShowDefaultNodeShapesInternal() );
+ customizeCheckBoxMenuItem( _show_default_node_shapes_for_marked_cbmi, getOptions()
+ .isShowDefaultNodeShapesForMarkedNodes() );
+ customizeJMenuItem( _cycle_node_shape_mi );
+ customizeJMenuItem( _cycle_node_fill_mi );
+ customizeJMenuItem( _choose_node_size_mi );
+ customizeCheckBoxMenuItem( _color_labels_same_as_parent_branch, getOptions().isColorLabelsSameAsParentBranch() );
+ customizeCheckBoxMenuItem( _search_case_senstive_cbmi, getOptions().isSearchCaseSensitive() );
+ customizeCheckBoxMenuItem( _show_scale_cbmi, getOptions().isShowScale() );
+ customizeRadioButtonMenuItem( _non_lined_up_cladograms_rbmi,
+ getOptions().getCladogramType() == CLADOGRAM_TYPE.NON_LINED_UP );
+ customizeRadioButtonMenuItem( _ext_node_dependent_cladogram_rbmi,
+ getOptions().getCladogramType() == CLADOGRAM_TYPE.LINED_UP );
+ customizeCheckBoxMenuItem( _show_overview_cbmi, getOptions().isShowOverview() );
+ customizeCheckBoxMenuItem( _search_with_regex_cbmi, getOptions().isSearchWithRegex() );
+ customizeCheckBoxMenuItem( _search_whole_words_only_cbmi, getOptions().isMatchWholeTermsOnly() );
+ customizeCheckBoxMenuItem( _inverse_search_result_cbmi, getOptions().isInverseSearchResult() );
+ customizeCheckBoxMenuItem( _show_confidence_stddev_cbmi, getOptions().isShowConfidenceStddev() );
+ customizeCheckBoxMenuItem( _line_up_renderable_data_cbmi, getOptions().isLineUpRendarableNodeData() );
+ customizeCheckBoxMenuItem( _right_line_up_domains_cbmi, getOptions().isRightLineUpDomains() );
+ _jmenubar.add( _options_jmenu );
+ }
+
+ void buildToolsMenu() {
+ _tools_menu = MainFrame.createMenu( "Tools", getConfiguration() );
+ _tools_menu.add( _confcolor_item = new JMenuItem( "Colorize Branches Depending on Confidence" ) );
+ customizeJMenuItem( _confcolor_item );
+ _tools_menu.add( _taxcolor_item = new JMenuItem( "Taxonomy Colorize Branches" ) );
+ customizeJMenuItem( _taxcolor_item );
+ _tools_menu.addSeparator();
+ _tools_menu.add( _remove_visual_styles_item = new JMenuItem( "Delete All Visual Styles From Nodes" ) );
+ _remove_visual_styles_item
+ .setToolTipText( "To remove all node visual styles (fonts, colors) from the current phylogeny." );
+ customizeJMenuItem( _remove_visual_styles_item );
+ _tools_menu.add( _remove_branch_color_item = new JMenuItem( "Delete All Colors From Branches" ) );
+ _remove_branch_color_item.setToolTipText( "To remove all branch color values from the current phylogeny." );
+ customizeJMenuItem( _remove_branch_color_item );
+ _tools_menu.addSeparator();
+ _tools_menu.add( _midpoint_root_item = new JMenuItem( "Midpoint-Root" ) );
+ customizeJMenuItem( _midpoint_root_item );
+ _tools_menu.addSeparator();
+ _tools_menu.add( _collapse_species_specific_subtrees = new JMenuItem( "Collapse Species-Specific Subtrees" ) );
+ customizeJMenuItem( _collapse_species_specific_subtrees );
+ _jmenubar.add( _tools_menu );
+ }
+
+ void buildTypeMenu() {
+ _type_menu = MainFrame.createMenu( MainFrame.TYPE_MENU_HEADER, getConfiguration() );
+ _type_menu.add( _rectangular_type_cbmi = new JCheckBoxMenuItem( MainFrame.RECTANGULAR_TYPE_CBMI_LABEL ) );
+ _type_menu.add( _euro_type_cbmi = new JCheckBoxMenuItem( MainFrame.EURO_TYPE_CBMI_LABEL ) );
+ _type_menu.add( _rounded_type_cbmi = new JCheckBoxMenuItem( MainFrame.ROUNDED_TYPE_CBMI_LABEL ) );
+ _type_menu.add( _curved_type_cbmi = new JCheckBoxMenuItem( MainFrame.CURVED_TYPE_CBMI_LABEL ) );
+ _type_menu.add( _triangular_type_cbmi = new JCheckBoxMenuItem( MainFrame.TRIANGULAR_TYPE_CBMI_LABEL ) );
+ _type_menu.add( _convex_type_cbmi = new JCheckBoxMenuItem( MainFrame.CONVEX_TYPE_CBMI_LABEL ) );
+ _type_menu.add( _unrooted_type_cbmi = new JCheckBoxMenuItem( MainFrame.UNROOTED_TYPE_CBMI_LABEL ) );
+ _type_menu.add( _circular_type_cbmi = new JCheckBoxMenuItem( MainFrame.CIRCULAR_TYPE_CBMI_LABEL ) );
+ customizeCheckBoxMenuItem( _rectangular_type_cbmi, false );
+ customizeCheckBoxMenuItem( _triangular_type_cbmi, false );
+ customizeCheckBoxMenuItem( _euro_type_cbmi, false );
+ customizeCheckBoxMenuItem( _rounded_type_cbmi, false );
+ customizeCheckBoxMenuItem( _curved_type_cbmi, false );
+ customizeCheckBoxMenuItem( _convex_type_cbmi, false );
+ customizeCheckBoxMenuItem( _unrooted_type_cbmi, false );
+ customizeCheckBoxMenuItem( _circular_type_cbmi, false );
+ _unrooted_type_cbmi.setToolTipText( MainFrame.USE_MOUSEWHEEL_SHIFT_TO_ROTATE );
+ _circular_type_cbmi.setToolTipText( MainFrame.USE_MOUSEWHEEL_SHIFT_TO_ROTATE );
+ initializeTypeMenu( getOptions() );
+ _jmenubar.add( _type_menu );
+ }
+
+ void buildViewMenu() {
+ _view_jmenu = MainFrame.createMenu( "View", getConfiguration() );
+ _view_jmenu
+ .add( _display_basic_information_item = new JMenuItem( MainFrame.SHOW_BASIC_TREE_INFORMATION_LABEL ) );
+ _view_jmenu.addSeparator();
+ _view_jmenu.add( _view_as_XML_item = new JMenuItem( "as phyloXML" ) );
+ _view_jmenu.add( _view_as_NH_item = new JMenuItem( "as Newick" ) );
+ _view_jmenu.add( _view_as_nexus_item = new JMenuItem( "as Nexus" ) );
+ customizeJMenuItem( _display_basic_information_item );
+ customizeJMenuItem( _view_as_NH_item );
+ customizeJMenuItem( _view_as_XML_item );
+ customizeJMenuItem( _view_as_nexus_item );
+ _jmenubar.add( _view_jmenu );
+ }
+
+ void checkTextFrames() {
+ if ( _textframes.size() > 5 ) {
+ try {
+ if ( _textframes.getFirst() != null ) {
+ _textframes.getFirst().removeMe();
+ }
+ else {
+ _textframes.removeFirst();
+ }
+ }
+ catch ( final NoSuchElementException e ) {
+ // Ignore.
+ }
+ }
+ }
+
+ void clearCurrentExternalNodesDataBuffer() {
+ getCurrentTreePanel().clearCurrentExternalNodesDataBuffer();
+ }
+
+ void customizeCheckBoxMenuItem( final JCheckBoxMenuItem item, final boolean is_selected ) {
+ if ( item != null ) {
+ item.setFont( MainFrame.menu_font );
+ if ( !getConfiguration().isUseNativeUI() ) {
+ item.setBackground( getConfiguration().getGuiMenuBackgroundColor() );
+ item.setForeground( getConfiguration().getGuiMenuTextColor() );
+ }
+ item.setSelected( is_selected );
+ item.addActionListener( this );
+ }
+ }
+
+ void customizeJMenuItem( final JMenuItem jmi ) {
+ if ( jmi != null ) {
+ jmi.setFont( MainFrame.menu_font );
+ if ( !getConfiguration().isUseNativeUI() ) {
+ jmi.setBackground( getConfiguration().getGuiMenuBackgroundColor() );
+ jmi.setForeground( getConfiguration().getGuiMenuTextColor() );
+ }
+ jmi.addActionListener( this );
+ }
+ }
+
+ void displayBasicInformation() {
+ if ( ( getMainPanel() != null ) && ( getMainPanel().getCurrentPhylogeny() != null )
+ && !getMainPanel().getCurrentPhylogeny().isEmpty() ) {
+ String title = "Basic Information";
+ if ( !ForesterUtil.isEmpty( getMainPanel().getCurrentPhylogeny().getName() ) ) {
+ title = title + " for \"" + _mainpanel.getCurrentPhylogeny().getName() + "\"";
+ }
+ showTextFrame( AptxUtil.createBasicInformation( getMainPanel().getCurrentPhylogeny(), null ), title );
+ }
+ }
+
+ void executeGSDI() {
+ if ( !isOKforSDI( false, true ) ) {
+ return;
+ }
+ if ( !_mainpanel.getCurrentPhylogeny().isRooted() ) {
+ JOptionPane.showMessageDialog( this,
+ "Gene tree is not rooted.",
+ "Cannot execute GSDI",
+ JOptionPane.ERROR_MESSAGE );
+ return;
+ }
+ final Phylogeny gene_tree = _mainpanel.getCurrentPhylogeny().copy();
+ gene_tree.setAllNodesToNotCollapse();
+ gene_tree.recalculateNumberOfExternalDescendants( false );
+ GSDI gsdi = null;
+ final Phylogeny species_tree = _species_tree.copy();
+ try {
+ gsdi = new GSDI( gene_tree, species_tree, false, true, true, true );
+ }
+ catch ( final SDIException e ) {
+ JOptionPane.showMessageDialog( this,
+ e.getLocalizedMessage(),
+ "Error during GSDI",
+ JOptionPane.ERROR_MESSAGE );
+ return;
+ }
+ catch ( final Exception e ) {
+ AptxUtil.unexpectedException( e );
+ return;
+ }
+ gene_tree.setRerootable( false );
+ gene_tree.clearHashIdToNodeMap();
+ gene_tree.recalculateNumberOfExternalDescendants( true );
+ _mainpanel.addPhylogenyInNewTab( gene_tree, getConfiguration(), "gene tree", null );
+ getMainPanel().getControlPanel().setShowEvents( true );
+ showWhole();
+ final int selected = _mainpanel.getTabbedPane().getSelectedIndex();
+ _mainpanel.addPhylogenyInNewTab( species_tree, getConfiguration(), "species tree", null );
+ showWhole();
+ _mainpanel.getTabbedPane().setSelectedIndex( selected );
+ showWhole();
+ _mainpanel.getCurrentTreePanel().setEdited( true );
+ final int poly = PhylogenyMethods.countNumberOfPolytomies( species_tree );
+ if ( gsdi.getStrippedExternalGeneTreeNodes().size() > 0 ) {
+ JOptionPane.showMessageDialog( this,
+ "Duplications: " + gsdi.getDuplicationsSum() + "\n"
+ + "Potential duplications: "
+ + gsdi.getSpeciationOrDuplicationEventsSum() + "\n"
+ + "Speciations: " + gsdi.getSpeciationsSum() + "\n"
+ + "Stripped gene tree nodes: "
+ + gsdi.getStrippedExternalGeneTreeNodes().size() + "\n"
+ + "Taxonomy linkage based on: " + gsdi.getTaxCompBase() + "\n"
+ + "Number of polytomies in species tree used: " + poly + "\n",
+ "GSDI successfully completed",
+ JOptionPane.WARNING_MESSAGE );
+ }
+ else {
+ JOptionPane.showMessageDialog( this,
+ "Duplications: " + gsdi.getDuplicationsSum() + "\n"
+ + "Potential duplications: "
+ + gsdi.getSpeciationOrDuplicationEventsSum() + "\n"
+ + "Speciations: " + gsdi.getSpeciationsSum() + "\n"
+ + "Stripped gene tree nodes: "
+ + gsdi.getStrippedExternalGeneTreeNodes().size() + "\n"
+ + "Taxonomy linkage based on: " + gsdi.getTaxCompBase() + "\n"
+ + "Number of polytomies in species tree used: " + poly + "\n",
+ "GSDI successfully completed",
+ JOptionPane.INFORMATION_MESSAGE );
+ }
+ }
+
+ void executeGSDIR() {
+ if ( !isOKforSDI( false, false ) ) {
+ return;
+ }
+ final int p = PhylogenyMethods.countNumberOfPolytomies( _mainpanel.getCurrentPhylogeny() );
+ if ( ( p > 0 )
+ && !( ( p == 1 ) && ( _mainpanel.getCurrentPhylogeny().getRoot().getNumberOfDescendants() == 3 ) ) ) {
+ JOptionPane.showMessageDialog( this,
+ "Gene tree is not completely binary",
+ "Cannot execute GSDI",
+ JOptionPane.ERROR_MESSAGE );
+ return;
+ }
+ final Phylogeny gene_tree = _mainpanel.getCurrentPhylogeny().copy();
+ gene_tree.setAllNodesToNotCollapse();
+ gene_tree.recalculateNumberOfExternalDescendants( false );
+ GSDIR gsdir = null;
+ final Phylogeny species_tree = _species_tree.copy();
+ try {
+ gsdir = new GSDIR( gene_tree, species_tree, true, true, true );
+ }
+ catch ( final SDIException e ) {
+ JOptionPane.showMessageDialog( this,
+ e.getLocalizedMessage(),
+ "Error during GSDIR",
+ JOptionPane.ERROR_MESSAGE );
+ return;
+ }
+ catch ( final Exception e ) {
+ AptxUtil.unexpectedException( e );
+ return;
+ }
+ final Phylogeny result_gene_tree = gsdir.getMinDuplicationsSumGeneTree();
+ result_gene_tree.setRerootable( false );
+ result_gene_tree.clearHashIdToNodeMap();
+ result_gene_tree.recalculateNumberOfExternalDescendants( true );
+ PhylogenyMethods.orderAppearance( result_gene_tree.getRoot(), true, true, DESCENDANT_SORT_PRIORITY.NODE_NAME );
+ _mainpanel.addPhylogenyInNewTab( result_gene_tree, getConfiguration(), "gene tree", null );
+ getMainPanel().getControlPanel().setShowEvents( true );
+ showWhole();
+ final int selected = _mainpanel.getTabbedPane().getSelectedIndex();
+ _mainpanel.addPhylogenyInNewTab( species_tree, getConfiguration(), "species tree", null );
+ showWhole();
+ _mainpanel.getTabbedPane().setSelectedIndex( selected );
+ showWhole();
+ _mainpanel.getCurrentTreePanel().setEdited( true );
+ final int poly = PhylogenyMethods.countNumberOfPolytomies( species_tree );
+ if ( gsdir.getStrippedExternalGeneTreeNodes().size() > 0 ) {
+ JOptionPane.showMessageDialog( this,
+ "Minimal duplications: " + gsdir.getMinDuplicationsSum() + "\n"
+ + "Speciations: " + gsdir.getSpeciationsSum() + "\n"
+ + "Stripped gene tree nodes: "
+ + gsdir.getStrippedExternalGeneTreeNodes().size() + "\n"
+ + "Taxonomy linkage based on: " + gsdir.getTaxCompBase() + "\n"
+ + "Number of polytomies in species tree used: " + poly + "\n",
+ "GSDIR successfully completed",
+ JOptionPane.WARNING_MESSAGE );
+ }
+ else {
+ JOptionPane.showMessageDialog( this,
+ "Minimal duplications: " + gsdir.getMinDuplicationsSum() + "\n"
+ + "Speciations: " + gsdir.getSpeciationsSum() + "\n"
+ + "Stripped gene tree nodes: "
+ + gsdir.getStrippedExternalGeneTreeNodes().size() + "\n"
+ + "Taxonomy linkage based on: " + gsdir.getTaxCompBase() + "\n"
+ + "Number of polytomies in species tree used: " + poly + "\n",
+ "GSDIR successfully completed",
+ JOptionPane.INFORMATION_MESSAGE );
+ }
+ }
+
+ Configuration getConfiguration() {
+ return _configuration;
+ }
+
+ File getCurrentDir() {
+ if ( ( _current_dir == null ) || !_current_dir.canRead() ) {
+ if ( ForesterUtil.isWindows() ) {
+ try {
+ _current_dir = new File( WindowsUtils.getCurrentUserDesktopPath() );
+ }
+ catch ( final Exception e ) {
+ _current_dir = null;
+ }
+ }
+ }
+ if ( ( _current_dir == null ) || !_current_dir.canRead() ) {
+ if ( System.getProperty( "user.home" ) != null ) {
+ _current_dir = new File( System.getProperty( "user.home" ) );
+ }
+ else if ( System.getProperty( "user.dir" ) != null ) {
+ _current_dir = new File( System.getProperty( "user.dir" ) );
+ }
+ }
+ return _current_dir;
+ }
+
+ TreePanel getCurrentTreePanel() {
+ return getMainPanel().getCurrentTreePanel();
+ }
+
+ JCheckBoxMenuItem getlabelDirectionCbmi() {
+ return _label_direction_cbmi;
+ }
+
+ MainPanel getMainPanel() {
+ return _mainpanel;
+ }
+
+ Options getOtions() {
+ return _options;
+ }
+
+ void initializeTypeMenu( final Options options ) {
+ setTypeMenuToAllUnselected();
+ try {
+ switch ( options.getPhylogenyGraphicsType() ) {
+ case CONVEX:
+ _convex_type_cbmi.setSelected( true );
+ break;
+ case CURVED:
+ _curved_type_cbmi.setSelected( true );
+ break;
+ case EURO_STYLE:
+ _euro_type_cbmi.setSelected( true );
+ break;
+ case ROUNDED:
+ _rounded_type_cbmi.setSelected( true );
+ break;
+ case TRIANGULAR:
+ _triangular_type_cbmi.setSelected( true );
+ break;
+ case UNROOTED:
+ _unrooted_type_cbmi.setSelected( true );
+ break;
+ case CIRCULAR:
+ _circular_type_cbmi.setSelected( true );
+ break;
+ default:
+ _rectangular_type_cbmi.setSelected( true );
+ break;
+ }
+ }
+ catch ( final NullPointerException np ) {
+ // In all likelihood, this is caused by menu-less display.
+ }
+ }
+
+ boolean isOKforSDI( final boolean species_tree_has_to_binary, final boolean gene_tree_has_to_binary ) {
+ if ( ( _mainpanel.getCurrentPhylogeny() == null ) || _mainpanel.getCurrentPhylogeny().isEmpty() ) {
+ return false;
+ }
+ else if ( ( _species_tree == null ) || _species_tree.isEmpty() ) {
+ JOptionPane.showMessageDialog( this,
+ "No species tree loaded",
+ "Cannot execute GSDI",
+ JOptionPane.ERROR_MESSAGE );
+ return false;
+ }
+ else if ( species_tree_has_to_binary && !_species_tree.isCompletelyBinary() ) {
+ JOptionPane.showMessageDialog( this,
+ "Species tree is not completely binary",
+ "Cannot execute GSDI",
+ JOptionPane.ERROR_MESSAGE );
+ return false;
+ }
+ else if ( gene_tree_has_to_binary && !_mainpanel.getCurrentPhylogeny().isCompletelyBinary() ) {
+ JOptionPane.showMessageDialog( this,
+ "Gene tree is not completely binary",
+ "Cannot execute GSDI",
+ JOptionPane.ERROR_MESSAGE );
+ return false;
+ }
+ else {
+ return true;
+ }
+ }
+
+ boolean isSubtreeDisplayed() {
+ if ( getCurrentTreePanel() != null ) {
+ if ( getCurrentTreePanel().isCurrentTreeIsSubtree() ) {
+ JOptionPane
+ .showMessageDialog( this,
+ "This operation can only be performed on a complete tree, not on the currently displayed sub-tree only.",
+ "Operation can not be exectuted on a sub-tree",
+ JOptionPane.WARNING_MESSAGE );
+ return true;
+ }
+ }
+ return false;
+ }
+
+ void removeAllTextFrames() {
+ for( final TextFrame tf : _textframes ) {
+ if ( tf != null ) {
+ tf.close();
+ }
+ }
+ _textframes.clear();
+ }
+
+ void setConfiguration( final Configuration configuration ) {
+ _configuration = configuration;
+ }
+
+ void setCurrentDir( final File current_dir ) {
+ _current_dir = current_dir;
+ }
+
+ void setOptions( final Options options ) {
+ _options = options;
+ }
+
+ void setSelectedTypeInTypeMenu( final PHYLOGENY_GRAPHICS_TYPE type ) {
+ setTypeMenuToAllUnselected();
+ try {
+ switch ( type ) {
+ case CIRCULAR:
+ _circular_type_cbmi.setSelected( true );
+ break;
+ case CONVEX:
+ _convex_type_cbmi.setSelected( true );
+ break;
+ case CURVED:
+ _curved_type_cbmi.setSelected( true );
+ break;
+ case EURO_STYLE:
+ _euro_type_cbmi.setSelected( true );
+ break;
+ case ROUNDED:
+ _rounded_type_cbmi.setSelected( true );
+ break;
+ case RECTANGULAR:
+ _rectangular_type_cbmi.setSelected( true );
+ break;
+ case TRIANGULAR:
+ _triangular_type_cbmi.setSelected( true );
+ break;
+ case UNROOTED:
+ _unrooted_type_cbmi.setSelected( true );
+ break;
+ default:
+ throw new IllegalArgumentException( "unknown type: " + type );
+ }
+ }
+ catch ( final NullPointerException np ) {
+ // In all likelihood, this is caused by menu-less display.
+ }
+ }
+
+ void setTypeMenuToAllUnselected() {
+ if ( _convex_type_cbmi != null ) {
+ _convex_type_cbmi.setSelected( false );
+ }
+ if ( _curved_type_cbmi != null ) {
+ _curved_type_cbmi.setSelected( false );
+ }
+ if ( _euro_type_cbmi != null ) {
+ _euro_type_cbmi.setSelected( false );
+ }
+ if ( _rounded_type_cbmi != null ) {
+ _rounded_type_cbmi.setSelected( false );
+ }
+ if ( _triangular_type_cbmi != null ) {
+ _triangular_type_cbmi.setSelected( false );
+ }
+ if ( _rectangular_type_cbmi != null ) {
+ _rectangular_type_cbmi.setSelected( false );
+ }
+ if ( _unrooted_type_cbmi != null ) {
+ _unrooted_type_cbmi.setSelected( false );
+ }
+ if ( _circular_type_cbmi != null ) {
+ _circular_type_cbmi.setSelected( false );
+ }
+ }
+
+ void showWhole() {
+ _mainpanel.getControlPanel().showWhole();
+ }
+
+ void switchColors() {
+ final TreeColorSet colorset = getMainPanel().getCurrentTreePanel().getTreeColorSet();
+ final ColorSchemeChooser csc = new ColorSchemeChooser( getMainPanel(), colorset );
+ csc.setVisible( true );
+ getMainPanel().setTreeColorSet( colorset );
+ }
+
+ void typeChanged( final Object o ) {
+ updateTypeCheckboxes( getOptions(), o );
+ updateOptions( getOptions() );
+ if ( getCurrentTreePanel() != null ) {
+ final PHYLOGENY_GRAPHICS_TYPE previous_type = getCurrentTreePanel().getPhylogenyGraphicsType();
+ final PHYLOGENY_GRAPHICS_TYPE new_type = getOptions().getPhylogenyGraphicsType();
+ if ( ( ( previous_type == PHYLOGENY_GRAPHICS_TYPE.UNROOTED ) && ( new_type != PHYLOGENY_GRAPHICS_TYPE.UNROOTED ) )
+ || ( ( previous_type == PHYLOGENY_GRAPHICS_TYPE.CIRCULAR ) && ( new_type != PHYLOGENY_GRAPHICS_TYPE.CIRCULAR ) )
+ || ( ( previous_type != PHYLOGENY_GRAPHICS_TYPE.UNROOTED ) && ( new_type == PHYLOGENY_GRAPHICS_TYPE.UNROOTED ) )
+ || ( ( previous_type != PHYLOGENY_GRAPHICS_TYPE.CIRCULAR ) && ( new_type == PHYLOGENY_GRAPHICS_TYPE.CIRCULAR ) ) ) {
+ getCurrentTreePanel().getControlPanel().showWhole();
+ }
+ if ( getCurrentTreePanel().isPhyHasBranchLengths() && ( new_type != PHYLOGENY_GRAPHICS_TYPE.CIRCULAR ) ) {
+ getCurrentTreePanel().getControlPanel().setDrawPhylogramEnabled( true );
+ }
+ else {
+ getCurrentTreePanel().getControlPanel().setDrawPhylogramEnabled( false );
+ }
+ getCurrentTreePanel().setPhylogenyGraphicsType( getOptions().getPhylogenyGraphicsType() );
+ MainFrame.updateScreenTextAntialias( getMainPanel().getTreePanels() );
+ }
+ }
+
+ void updateOptions( final Options options ) {
+ options.setAntialiasScreen( ( _screen_antialias_cbmi != null ) && _screen_antialias_cbmi.isSelected() );
+ options.setBackgroundColorGradient( ( _background_gradient_cbmi != null )
+ && _background_gradient_cbmi.isSelected() );
+ options.setShowDomainLabels( ( _show_domain_labels != null ) && _show_domain_labels.isSelected() );
+ options.setShowAnnotationRefSource( ( _show_annotation_ref_source != null )
+ && _show_annotation_ref_source.isSelected() );
+ options.setAbbreviateScientificTaxonNames( ( _abbreviate_scientific_names != null )
+ && _abbreviate_scientific_names.isSelected() );
+ options.setColorLabelsSameAsParentBranch( ( _color_labels_same_as_parent_branch != null )
+ && _color_labels_same_as_parent_branch.isSelected() );
+ options.setShowDefaultNodeShapesInternal( ( _show_default_node_shapes_internal_cbmi != null )
+ && _show_default_node_shapes_internal_cbmi.isSelected() );
+ options.setShowDefaultNodeShapesExternal( ( _show_default_node_shapes_external_cbmi != null )
+ && _show_default_node_shapes_external_cbmi.isSelected() );
+ options.setShowDefaultNodeShapesForMarkedNodes( ( _show_default_node_shapes_for_marked_cbmi != null )
+ && _show_default_node_shapes_for_marked_cbmi.isSelected() );
+ if ( ( _non_lined_up_cladograms_rbmi != null ) && ( _non_lined_up_cladograms_rbmi.isSelected() ) ) {
+ options.setCladogramType( CLADOGRAM_TYPE.NON_LINED_UP );
+ }
+
+ else if ( ( _ext_node_dependent_cladogram_rbmi != null ) && ( _ext_node_dependent_cladogram_rbmi.isSelected() ) ) {
+ options.setCladogramType( CLADOGRAM_TYPE.LINED_UP );
+ }
+ options.setSearchCaseSensitive( ( _search_case_senstive_cbmi != null )
+ && _search_case_senstive_cbmi.isSelected() );
+ if ( ( _show_scale_cbmi != null ) && _show_scale_cbmi.isEnabled() ) {
+ options.setShowScale( _show_scale_cbmi.isSelected() );
+ }
+ if ( _label_direction_cbmi != null ) {
+ if ( _label_direction_cbmi.isSelected() ) {
+ options.setNodeLabelDirection( NODE_LABEL_DIRECTION.RADIAL );
+ }
+ else {
+ options.setNodeLabelDirection( NODE_LABEL_DIRECTION.HORIZONTAL );
+ }
+ }
+ options.setShowOverview( ( _show_overview_cbmi != null ) && _show_overview_cbmi.isSelected() );
+ options.setShowConfidenceStddev( ( _show_confidence_stddev_cbmi != null )
+ && _show_confidence_stddev_cbmi.isSelected() );
+ options.setMatchWholeTermsOnly( ( _search_whole_words_only_cbmi != null )
+ && _search_whole_words_only_cbmi.isSelected() );
+ options.setSearchWithRegex( ( _search_with_regex_cbmi != null ) && _search_with_regex_cbmi.isSelected() );
+ options.setInverseSearchResult( ( _inverse_search_result_cbmi != null )
+ && _inverse_search_result_cbmi.isSelected() );
+ options.setAntialiasPrint( ( _antialias_print_cbmi != null ) && _antialias_print_cbmi.isSelected() );
+ options.setPrintBlackAndWhite( ( _print_black_and_white_cbmi != null )
+ && _print_black_and_white_cbmi.isSelected() );
+ if ( ( _rectangular_type_cbmi != null ) && _rectangular_type_cbmi.isSelected() ) {
+ options.setPhylogenyGraphicsType( PHYLOGENY_GRAPHICS_TYPE.RECTANGULAR );
+ }
+ else if ( ( _triangular_type_cbmi != null ) && _triangular_type_cbmi.isSelected() ) {
+ options.setPhylogenyGraphicsType( PHYLOGENY_GRAPHICS_TYPE.TRIANGULAR );
+ }
+ else if ( ( _curved_type_cbmi != null ) && _curved_type_cbmi.isSelected() ) {
+ options.setPhylogenyGraphicsType( PHYLOGENY_GRAPHICS_TYPE.CURVED );
+ }
+ else if ( ( _convex_type_cbmi != null ) && _convex_type_cbmi.isSelected() ) {
+ options.setPhylogenyGraphicsType( PHYLOGENY_GRAPHICS_TYPE.CONVEX );
+ }
+ else if ( ( _euro_type_cbmi != null ) && _euro_type_cbmi.isSelected() ) {
+ options.setPhylogenyGraphicsType( PHYLOGENY_GRAPHICS_TYPE.EURO_STYLE );
+ }
+ else if ( ( _rounded_type_cbmi != null ) && _rounded_type_cbmi.isSelected() ) {
+ options.setPhylogenyGraphicsType( PHYLOGENY_GRAPHICS_TYPE.ROUNDED );
+ }
+ else if ( ( _unrooted_type_cbmi != null ) && _unrooted_type_cbmi.isSelected() ) {
+ options.setPhylogenyGraphicsType( PHYLOGENY_GRAPHICS_TYPE.UNROOTED );
+ }
+ else if ( ( _circular_type_cbmi != null ) && _circular_type_cbmi.isSelected() ) {
+ options.setPhylogenyGraphicsType( PHYLOGENY_GRAPHICS_TYPE.CIRCULAR );
+ }
+ if ( ( _color_by_taxonomic_group_cbmi != null ) && _color_by_taxonomic_group_cbmi.isEnabled() ) {
+ options.setColorByTaxonomicGroup( _color_by_taxonomic_group_cbmi.isSelected() );
+ }
+ if ( ( _right_line_up_domains_cbmi != null ) && _right_line_up_domains_cbmi.isEnabled() ) {
+ options.setRightLineUpDomains( _right_line_up_domains_cbmi.isSelected() );
+ }
+ if ( ( _line_up_renderable_data_cbmi != null ) && _line_up_renderable_data_cbmi.isEnabled() ) {
+ options.setLineUpRendarableNodeData( _line_up_renderable_data_cbmi.isSelected() );
+ }
+ if ( _graphics_export_visible_only_cbmi != null ) {
+ options.setGraphicsExportVisibleOnly( _graphics_export_visible_only_cbmi.isSelected() );
+ }
+ }
+
+ void updateTypeCheckboxes( final Options options, final Object o ) {
+ setTypeMenuToAllUnselected();
+ ( ( JCheckBoxMenuItem ) o ).setSelected( true );
+ }
+
+ void viewAsNexus() {
+ if ( ( getMainPanel().getCurrentPhylogeny() != null ) && !getMainPanel().getCurrentPhylogeny().isEmpty() ) {
+ String title = "Nexus";
+ if ( !ForesterUtil.isEmpty( getMainPanel().getCurrentPhylogeny().getName() ) ) {
+ title = "\"" + getMainPanel().getCurrentPhylogeny().getName() + "\" in " + title;
+ }
+ showTextFrame( getMainPanel().getCurrentPhylogeny().toNexus( getOptions()
+ .getNhConversionSupportValueStyle() ),
+ title );
+ }
+ }
+
+ void viewAsNH() {
+ if ( ( getMainPanel().getCurrentPhylogeny() != null ) && !getMainPanel().getCurrentPhylogeny().isEmpty() ) {
+ String title = "New Hampshire";
+ if ( !ForesterUtil.isEmpty( getMainPanel().getCurrentPhylogeny().getName() ) ) {
+ title = "\"" + getMainPanel().getCurrentPhylogeny().getName() + "\" in " + title;
+ }
+ showTextFrame( getMainPanel().getCurrentPhylogeny().toNewHampshire( getOptions()
+ .getNhConversionSupportValueStyle() ),
+ title );
+ }
+ }
+
+ void viewAsXML() {
+ if ( ( getMainPanel().getCurrentPhylogeny() != null ) && !getMainPanel().getCurrentPhylogeny().isEmpty() ) {
+ String title = "phyloXML";
+ if ( !ForesterUtil.isEmpty( getMainPanel().getCurrentPhylogeny().getName() ) ) {
+ title = "\"" + getMainPanel().getCurrentPhylogeny().getName() + "\" in " + title;
+ }
+ showTextFrame( getMainPanel().getCurrentPhylogeny().toPhyloXML( 0 ), title );
+ }
+ }
+
+ static void setTextForPdfLineWidthChooserMenuItem( final JMenuItem mi, final Options o ) {
+ mi.setText( "Enter Default Line Width for PDF Export... (current: " + o.getPrintLineWidth() + ")" );
+ }
+
+ static void setupScreenTextAntialias( final List<TreePanel> treepanels, final boolean antialias ) {
+ for( final TreePanel tree_panel : treepanels ) {
+ tree_panel.setTextAntialias();
+ }
+ }
+}
\ No newline at end of file
--- /dev/null
+// $Id:
+// FORESTER -- software libraries and applications
+// for evolutionary biology research and applications.
+//
+// Copyright (C) 2008-2009 Christian M. Zmasek
+// Copyright (C) 2008-2009 Burnham Institute for Medical Research
+// Copyright (C) 2000-2001 Washington University School of Medicine
+// and Howard Hughes Medical Institute
+// Copyright (C) 2003-2007 Ethalinda K.S. Cannon
+// All rights reserved
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library 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
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
+//
+// Contact: phylosoft @ gmail . com
+// WWW: https://sites.google.com/site/cmzmasek/home/software/forester
+
+package org.forester.archaeopteryx;
+
+import java.awt.BorderLayout;
+import java.awt.event.ComponentAdapter;
+import java.awt.event.ComponentEvent;
+import java.awt.event.WindowAdapter;
+import java.awt.event.WindowEvent;
+import java.io.FileNotFoundException;
+import java.io.IOException;
+import java.net.MalformedURLException;
+import java.net.URL;
+
+import javax.swing.ButtonGroup;
+import javax.swing.JApplet;
+import javax.swing.JCheckBoxMenuItem;
+import javax.swing.JMenuBar;
+import javax.swing.JMenuItem;
+import javax.swing.JRadioButtonMenuItem;
+import javax.swing.event.ChangeEvent;
+import javax.swing.event.ChangeListener;
+
+import org.forester.archaeopteryx.Options.CLADOGRAM_TYPE;
+import org.forester.archaeopteryx.Options.NODE_LABEL_DIRECTION;
+import org.forester.io.parsers.nhx.NHXParser.TAXONOMY_EXTRACTION;
+import org.forester.phylogeny.Phylogeny;
+import org.forester.util.ForesterUtil;
+
+public final class MainFrameApplet extends MainFrame {
+
+ private static final long serialVersionUID = 1941019292746717053L;
+ private final static int DEFAULT_FRAME_X_SIZE = 640;
+ private final static int DEFAULT_FRAME_Y_SIZE = 580;
+ private final ArchaeopteryxA _applet;
+ private ButtonGroup _radio_group_1;
+
+ MainFrameApplet( final ArchaeopteryxA parent_applet,
+ final Configuration configuration,
+ final String species_tree_url_str ) {
+ setTitle( ArchaeopteryxA.NAME );
+ _applet = parent_applet;
+ setConfiguration( configuration );
+ setOptions( Options.createInstance( configuration ) );
+ _mainpanel = new MainPanelApplets( _configuration, this );
+ if ( !ForesterUtil.isEmpty( species_tree_url_str ) ) {
+ try {
+ readSpeciesTree( configuration, species_tree_url_str );
+ }
+ catch ( final Exception e ) {
+ ForesterUtil.printErrorMessage( ArchaeopteryxA.NAME, "failed to read species tree from "
+ + species_tree_url_str );
+ ForesterUtil.printErrorMessage( ArchaeopteryxA.NAME, e.toString() );
+ }
+ }
+ // build the menu bar
+ _jmenubar = new JMenuBar();
+ buildFileMenu();
+ if ( !_configuration.isUseNativeUI() ) {
+ _jmenubar.setBackground( _configuration.getGuiMenuBackgroundColor() );
+ }
+ buildAnalysisMenu();
+ buildToolsMenu();
+ buildViewMenu();
+ buildFontSizeMenu();
+ buildOptionsMenu();
+ buildTypeMenu();
+ buildHelpMenu();
+ setJMenuBar( _jmenubar );
+ _contentpane = getContentPane();
+ _contentpane.setLayout( new BorderLayout() );
+ _contentpane.add( _mainpanel, BorderLayout.CENTER );
+ setSize( getConfiguration().getFrameXSize() > 40 ? getConfiguration().getFrameXSize() : DEFAULT_FRAME_X_SIZE,
+ getConfiguration().getFrameYSize() > 40 ? getConfiguration().getFrameYSize() : DEFAULT_FRAME_Y_SIZE );
+ addWindowListener( new WindowAdapter() {
+
+ @Override
+ public void windowClosing( final WindowEvent e ) {
+ close();
+ }
+ } );
+ addComponentListener( new ComponentAdapter() {
+
+ @Override
+ public void componentResized( final ComponentEvent e ) {
+ if ( _mainpanel.getCurrentTreePanel() != null ) {
+ _mainpanel.getCurrentTreePanel().calcParametersForPainting( _mainpanel.getCurrentTreePanel()
+ .getWidth(),
+ _mainpanel.getCurrentTreePanel()
+ .getHeight() );
+ }
+ }
+ } );
+ setFocusable( true );
+ requestFocus();
+ requestFocusInWindow();
+ setVisible( true );
+ System.gc();
+ }
+
+ @Override
+ public MainPanel getMainPanel() {
+ return _mainpanel;
+ }
+
+ private void readSpeciesTree( final Configuration configuration, final String species_tree_url_str )
+ throws MalformedURLException, FileNotFoundException, IOException {
+ final URL species_tree_url = new URL( species_tree_url_str );
+ final Phylogeny[] species_trees = AptxUtil.readPhylogeniesFromUrl( species_tree_url,
+ configuration
+ .isValidatePhyloXmlAgainstSchema(),
+ configuration
+ .isReplaceUnderscoresInNhParsing(),
+ false,
+ TAXONOMY_EXTRACTION.NO,
+ false );
+ if ( ( species_trees != null ) && ( species_trees.length > 0 ) ) {
+ AptxUtil.printAppletMessage( ArchaeopteryxA.NAME, "successfully read species tree" );
+ if ( species_trees[ 0 ].isEmpty() ) {
+ ForesterUtil.printErrorMessage( ArchaeopteryxA.NAME, "species tree is empty" );
+ }
+ else if ( !species_trees[ 0 ].isRooted() ) {
+ ForesterUtil.printErrorMessage( ArchaeopteryxA.NAME, "species tree is not rooted" );
+ }
+ else {
+ setSpeciesTree( species_trees[ 0 ] );
+ AptxUtil.printAppletMessage( ArchaeopteryxA.NAME, "species tree OK" );
+ }
+ }
+ else {
+ ForesterUtil.printErrorMessage( ArchaeopteryxA.NAME, "failed to read species tree from "
+ + species_tree_url_str );
+ }
+ }
+
+ void buildAnalysisMenu() {
+ _analysis_menu = MainFrame.createMenu( "Analysis", getConfiguration() );
+ if ( getSpeciesTree() != null ) {
+ _analysis_menu.add( _gsdi_item = new JMenuItem( "GSDI (Generalized Speciation Duplication Inference)" ) );
+ _analysis_menu.add( _gsdir_item = new JMenuItem( "GSDIR (GSDI with re-rooting)" ) );
+ customizeJMenuItem( _gsdi_item );
+ customizeJMenuItem( _gsdir_item );
+ _analysis_menu.addSeparator();
+ }
+ _analysis_menu.add( _lineage_inference = new JMenuItem( INFER_ANCESTOR_TAXONOMIES ) );
+ customizeJMenuItem( _lineage_inference );
+ _lineage_inference.setToolTipText( "Inference of ancestor taxonomies/lineages" );
+ _jmenubar.add( _analysis_menu );
+ }
+
+ void buildOptionsMenu() {
+ _options_jmenu = MainFrame.createMenu( MainFrame.OPTIONS_HEADER, getConfiguration() );
+ _options_jmenu.addChangeListener( new ChangeListener() {
+
+ @Override
+ public void stateChanged( final ChangeEvent e ) {
+ MainFrame.setOvPlacementColorChooseMenuItem( _overview_placment_mi, getOptions() );
+ MainFrame.setTextColorChooseMenuItem( _switch_colors_mi, getCurrentTreePanel() );
+ MainFrame
+ .setTextMinSupportMenuItem( _choose_minimal_confidence_mi, getOptions(), getCurrentTreePanel() );
+ MainFrame.setTextForFontChooserMenuItem( _choose_font_mi, createCurrentFontDesc( getMainPanel()
+ .getTreeFontSet() ) );
+ // setTextForGraphicsSizeChooserMenuItem( _print_size_mi, getOptions() );
+ setTextForPdfLineWidthChooserMenuItem( _choose_pdf_width_mi, getOptions() );
+ MainFrame.setCycleNodeFillMenuItem( _cycle_node_fill_mi, getOptions() );
+ MainFrame.setCycleNodeShapeMenuItem( _cycle_node_shape_mi, getOptions() );
+ MainFrame.setTextNodeSizeMenuItem( _choose_node_size_mi, getOptions() );
+ try {
+ getMainPanel().getControlPanel().setVisibilityOfDomainStrucureCB();
+ getMainPanel().getControlPanel().setVisibilityOfX();
+ }
+ catch ( final Exception ignore ) {
+ // do nothing, not important.
+ }
+ }
+ } );
+ _options_jmenu.add( MainFrame.customizeMenuItemAsLabel( new JMenuItem( MainFrame.DISPLAY_SUBHEADER ),
+ getConfiguration() ) );
+ _options_jmenu
+ .add( _ext_node_dependent_cladogram_rbmi = new JRadioButtonMenuItem( MainFrame.NONUNIFORM_CLADOGRAMS_LABEL ) );
+ _options_jmenu.add( _non_lined_up_cladograms_rbmi = new JRadioButtonMenuItem( NON_LINED_UP_CLADOGRAMS_LABEL ) );
+ _radio_group_1 = new ButtonGroup();
+ _radio_group_1.add( _ext_node_dependent_cladogram_rbmi );
+ _radio_group_1.add( _non_lined_up_cladograms_rbmi );
+ _options_jmenu.add( _show_overview_cbmi = new JCheckBoxMenuItem( MainFrame.SHOW_OVERVIEW_LABEL ) );
+ _options_jmenu.add( _show_scale_cbmi = new JCheckBoxMenuItem( MainFrame.DISPLAY_SCALE_LABEL ) );
+ _options_jmenu
+ .add( _show_default_node_shapes_internal_cbmi = new JCheckBoxMenuItem( MainFrame.DISPLAY_NODE_BOXES_LABEL_INT ) );
+ _options_jmenu
+ .add( _show_default_node_shapes_external_cbmi = new JCheckBoxMenuItem( MainFrame.DISPLAY_NODE_BOXES_LABEL_EXT ) );
+ _options_jmenu
+ .add( _show_default_node_shapes_for_marked_cbmi = new JCheckBoxMenuItem( MainFrame.DISPLAY_NODE_BOXES_LABEL_MARKED ) );
+ _options_jmenu.add( _line_up_renderable_data_cbmi = new JCheckBoxMenuItem( MainFrame.LINE_UP_RENDERABLE_DATA ) );
+ if ( getConfiguration().doDisplayOption( Configuration.show_domain_architectures ) ) {
+ _options_jmenu.add( _right_line_up_domains_cbmi = new JCheckBoxMenuItem( MainFrame.RIGHT_LINE_UP_DOMAINS ) );
+ _options_jmenu.add( _show_domain_labels = new JCheckBoxMenuItem( MainFrame.SHOW_DOMAIN_LABELS_LABEL ) );
+ }
+ _options_jmenu.add( _show_annotation_ref_source = new JCheckBoxMenuItem( MainFrame.SHOW_ANN_REF_SOURCE_LABEL ) );
+ _options_jmenu.add( _show_confidence_stddev_cbmi = new JCheckBoxMenuItem( MainFrame.SHOW_CONF_STDDEV_LABEL ) );
+ _options_jmenu
+ .add( _color_by_taxonomic_group_cbmi = new JCheckBoxMenuItem( MainFrame.COLOR_BY_TAXONOMIC_GROUP ) );
+ _options_jmenu
+ .add( _color_labels_same_as_parent_branch = new JCheckBoxMenuItem( MainFrame.COLOR_LABELS_LABEL ) );
+ _color_labels_same_as_parent_branch.setToolTipText( MainFrame.COLOR_LABELS_TIP );
+ _options_jmenu.add( _abbreviate_scientific_names = new JCheckBoxMenuItem( MainFrame.ABBREV_SN_LABEL ) );
+ _options_jmenu.add( _label_direction_cbmi = new JCheckBoxMenuItem( MainFrame.LABEL_DIRECTION_LABEL ) );
+ _label_direction_cbmi.setToolTipText( MainFrame.LABEL_DIRECTION_TIP );
+ _options_jmenu.add( _screen_antialias_cbmi = new JCheckBoxMenuItem( MainFrame.SCREEN_ANTIALIAS_LABEL ) );
+ _options_jmenu.add( _background_gradient_cbmi = new JCheckBoxMenuItem( MainFrame.BG_GRAD_LABEL ) );
+ _options_jmenu.add( _cycle_node_shape_mi = new JMenuItem( MainFrame.CYCLE_NODE_SHAPE_LABEL ) );
+ _options_jmenu.add( _cycle_node_fill_mi = new JMenuItem( MainFrame.CYCLE_NODE_FILL_LABEL ) );
+ _options_jmenu.add( _choose_node_size_mi = new JMenuItem( MainFrame.CHOOSE_NODE_SIZE_LABEL ) );
+ _options_jmenu.add( _choose_minimal_confidence_mi = new JMenuItem( "" ) );
+ _options_jmenu.add( _overview_placment_mi = new JMenuItem( "" ) );
+ _options_jmenu.add( _switch_colors_mi = new JMenuItem( "" ) );
+ _options_jmenu.add( _choose_font_mi = new JMenuItem( "" ) );
+ _options_jmenu.addSeparator();
+ _options_jmenu.add( MainFrame.customizeMenuItemAsLabel( new JMenuItem( MainFrame.SEARCH_SUBHEADER ),
+ getConfiguration() ) );
+ _options_jmenu
+ .add( _search_case_senstive_cbmi = new JCheckBoxMenuItem( MainFrame.SEARCH_CASE_SENSITIVE_LABEL ) );
+ _options_jmenu.add( _search_whole_words_only_cbmi = new JCheckBoxMenuItem( MainFrame.SEARCH_TERMS_ONLY_LABEL ) );
+ _options_jmenu.add( _search_with_regex_cbmi = new JCheckBoxMenuItem( MainFrame.SEARCH_REGEX_LABEL ) );
+ _search_with_regex_cbmi.setToolTipText( MainFrame.SEARCH_WITH_REGEX_TIP );
+ _options_jmenu.add( _inverse_search_result_cbmi = new JCheckBoxMenuItem( INVERSE_SEARCH_RESULT_LABEL ) );
+
+ _options_jmenu.addSeparator();
+ _options_jmenu.add( customizeMenuItemAsLabel( new JMenuItem( "Graphics Export & Printing:" ),
+ getConfiguration() ) );
+ _options_jmenu.add( _antialias_print_cbmi = new JCheckBoxMenuItem( "Antialias" ) );
+ _options_jmenu.add( _print_black_and_white_cbmi = new JCheckBoxMenuItem( "Export in Black and White" ) );
+ _options_jmenu
+ .add( _graphics_export_visible_only_cbmi = new JCheckBoxMenuItem( "Limit to Visible ('Screenshot') for PNG, JPG, and GIF export" ) );
+ _options_jmenu.add( _choose_pdf_width_mi = new JMenuItem( "" ) );
+
+ customizeCheckBoxMenuItem( _antialias_print_cbmi, getOptions().isAntialiasPrint() );
+ customizeCheckBoxMenuItem( _print_black_and_white_cbmi, getOptions().isPrintBlackAndWhite() );
+ customizeJMenuItem( _choose_pdf_width_mi );
+
+ customizeJMenuItem( _choose_font_mi );
+ customizeJMenuItem( _switch_colors_mi );
+ customizeJMenuItem( _choose_minimal_confidence_mi );
+ customizeJMenuItem( _overview_placment_mi );
+ customizeCheckBoxMenuItem( _show_default_node_shapes_internal_cbmi, getOptions()
+ .isShowDefaultNodeShapesInternal() );
+ customizeCheckBoxMenuItem( _show_default_node_shapes_external_cbmi, getOptions()
+ .isShowDefaultNodeShapesExternal() );
+ customizeCheckBoxMenuItem( _show_default_node_shapes_for_marked_cbmi, getOptions()
+ .isShowDefaultNodeShapesForMarkedNodes() );
+ customizeJMenuItem( _cycle_node_shape_mi );
+ customizeJMenuItem( _cycle_node_fill_mi );
+ customizeJMenuItem( _choose_node_size_mi );
+ customizeCheckBoxMenuItem( _color_by_taxonomic_group_cbmi, getOptions().isColorByTaxonomicGroup() );
+ customizeCheckBoxMenuItem( _color_labels_same_as_parent_branch, getOptions().isColorLabelsSameAsParentBranch() );
+ customizeCheckBoxMenuItem( _screen_antialias_cbmi, getOptions().isAntialiasScreen() );
+ customizeCheckBoxMenuItem( _background_gradient_cbmi, getOptions().isBackgroundColorGradient() );
+ customizeCheckBoxMenuItem( _show_domain_labels, getOptions().isShowDomainLabels() );
+ customizeCheckBoxMenuItem( _show_annotation_ref_source, getOptions().isShowAnnotationRefSource() );
+ customizeCheckBoxMenuItem( _abbreviate_scientific_names, getOptions().isAbbreviateScientificTaxonNames() );
+ customizeCheckBoxMenuItem( _search_case_senstive_cbmi, getOptions().isSearchCaseSensitive() );
+ customizeCheckBoxMenuItem( _show_scale_cbmi, getOptions().isShowScale() );
+ customizeRadioButtonMenuItem( _non_lined_up_cladograms_rbmi,
+ getOptions().getCladogramType() == CLADOGRAM_TYPE.NON_LINED_UP );
+ customizeRadioButtonMenuItem( _ext_node_dependent_cladogram_rbmi,
+ getOptions().getCladogramType() == CLADOGRAM_TYPE.LINED_UP );
+ customizeCheckBoxMenuItem( _show_overview_cbmi, getOptions().isShowOverview() );
+ customizeCheckBoxMenuItem( _label_direction_cbmi,
+ getOptions().getNodeLabelDirection() == NODE_LABEL_DIRECTION.RADIAL );
+ customizeCheckBoxMenuItem( _search_with_regex_cbmi, getOptions().isSearchWithRegex() );
+ customizeCheckBoxMenuItem( _search_whole_words_only_cbmi, getOptions().isMatchWholeTermsOnly() );
+ customizeCheckBoxMenuItem( _inverse_search_result_cbmi, getOptions().isInverseSearchResult() );
+ customizeCheckBoxMenuItem( _show_confidence_stddev_cbmi, getOptions().isShowConfidenceStddev() );
+ customizeCheckBoxMenuItem( _line_up_renderable_data_cbmi, getOptions().isLineUpRendarableNodeData() );
+ customizeCheckBoxMenuItem( _right_line_up_domains_cbmi, getOptions().isRightLineUpDomains() );
+ _jmenubar.add( _options_jmenu );
+ }
+
+ void buildToolsMenu() {
+ _tools_menu = MainFrame.createMenu( "Tools", getConfiguration() );
+ _tools_menu.add( _confcolor_item = new JMenuItem( "Colorize Branches Depending on Confidence" ) );
+ customizeJMenuItem( _confcolor_item );
+ _tools_menu.add( _taxcolor_item = new JMenuItem( "Taxonomy Colorize Branches" ) );
+ customizeJMenuItem( _taxcolor_item );
+ _tools_menu.addSeparator();
+ _tools_menu.add( _remove_visual_styles_item = new JMenuItem( "Delete All Visual Styles From Nodes" ) );
+ _remove_visual_styles_item
+ .setToolTipText( "To remove all node visual styles (fonts, colors) from the current phylogeny." );
+ customizeJMenuItem( _remove_visual_styles_item );
+ _tools_menu.add( _remove_branch_color_item = new JMenuItem( "Delete All Colors From Branches" ) );
+ _remove_branch_color_item.setToolTipText( "To remove all branch color values from the current phylogeny." );
+ customizeJMenuItem( _remove_branch_color_item );
+ _tools_menu.addSeparator();
+ _tools_menu.add( _midpoint_root_item = new JMenuItem( "Midpoint-Root" ) );
+ customizeJMenuItem( _midpoint_root_item );
+ _tools_menu.addSeparator();
+ _tools_menu.add( _collapse_species_specific_subtrees = new JMenuItem( "Collapse Species-Specific Subtrees" ) );
+ customizeJMenuItem( _collapse_species_specific_subtrees );
+ _jmenubar.add( _tools_menu );
+ }
+
+ JApplet getApplet() {
+ return _applet;
+ }
+}