- catch ( final Exception ignore ) {\r
- // do nothing, not important.\r
- }\r
- }\r
- } );\r
- _options_jmenu.add( customizeMenuItemAsLabel( new JMenuItem( DISPLAY_SUBHEADER ), getConfiguration() ) );\r
- _options_jmenu\r
- .add( _ext_node_dependent_cladogram_rbmi = new JRadioButtonMenuItem( MainFrame.NONUNIFORM_CLADOGRAMS_LABEL ) );\r
- _options_jmenu.add( _uniform_cladograms_rbmi = new JRadioButtonMenuItem( MainFrame.UNIFORM_CLADOGRAMS_LABEL ) );\r
- _options_jmenu.add( _non_lined_up_cladograms_rbmi = new JRadioButtonMenuItem( NON_LINED_UP_CLADOGRAMS_LABEL ) );\r
- _radio_group_1 = new ButtonGroup();\r
- _radio_group_1.add( _ext_node_dependent_cladogram_rbmi );\r
- _radio_group_1.add( _uniform_cladograms_rbmi );\r
- _radio_group_1.add( _non_lined_up_cladograms_rbmi );\r
- ///////\r
- _options_jmenu.add( _show_overview_cbmi = new JCheckBoxMenuItem( SHOW_OVERVIEW_LABEL ) );\r
- _options_jmenu.add( _show_scale_cbmi = new JCheckBoxMenuItem( DISPLAY_SCALE_LABEL ) );\r
- _options_jmenu\r
- .add( _show_default_node_shapes_internal_cbmi = new JCheckBoxMenuItem( DISPLAY_NODE_BOXES_LABEL_INT ) );\r
- _options_jmenu\r
- .add( _show_default_node_shapes_external_cbmi = new JCheckBoxMenuItem( DISPLAY_NODE_BOXES_LABEL_EXT ) );\r
- _options_jmenu.add( _line_up_renderable_data_cbmi = new JCheckBoxMenuItem( MainFrame.LINE_UP_RENDERABLE_DATA ) );\r
- if ( getConfiguration().doDisplayOption( Configuration.show_domain_architectures ) ) {\r
- _options_jmenu.add( _right_line_up_domains_cbmi = new JCheckBoxMenuItem( MainFrame.RIGHT_LINE_UP_DOMAINS ) );\r
- _options_jmenu.add( _show_domain_labels = new JCheckBoxMenuItem( MainFrame.SHOW_DOMAIN_LABELS_LABEL ) );\r
- }\r
- _options_jmenu.add( _show_annotation_ref_source = new JCheckBoxMenuItem( SHOW_ANN_REF_SOURCE_LABEL ) );\r
- _options_jmenu.add( _show_confidence_stddev_cbmi = new JCheckBoxMenuItem( SHOW_CONF_STDDEV_LABEL ) );\r
- _options_jmenu.add( _color_by_taxonomic_group_cbmi = new JCheckBoxMenuItem( COLOR_BY_TAXONOMIC_GROUP ) );\r
- _options_jmenu.add( _color_labels_same_as_parent_branch = new JCheckBoxMenuItem( COLOR_LABELS_LABEL ) );\r
- _color_labels_same_as_parent_branch.setToolTipText( MainFrame.COLOR_LABELS_TIP );\r
- _options_jmenu.add( _abbreviate_scientific_names = new JCheckBoxMenuItem( ABBREV_SN_LABEL ) );\r
- _options_jmenu.add( _label_direction_cbmi = new JCheckBoxMenuItem( LABEL_DIRECTION_LABEL ) );\r
- _label_direction_cbmi.setToolTipText( LABEL_DIRECTION_TIP );\r
- _options_jmenu.add( _screen_antialias_cbmi = new JCheckBoxMenuItem( SCREEN_ANTIALIAS_LABEL ) );\r
- _options_jmenu.add( _background_gradient_cbmi = new JCheckBoxMenuItem( BG_GRAD_LABEL ) );\r
- _options_jmenu.add( _cycle_node_shape_mi = new JMenuItem( MainFrame.CYCLE_NODE_SHAPE_LABEL ) );\r
- _options_jmenu.add( _cycle_node_fill_mi = new JMenuItem( MainFrame.CYCLE_NODE_FILL_LABEL ) );\r
- _options_jmenu.add( _choose_node_size_mi = new JMenuItem( MainFrame.CHOOSE_NODE_SIZE_LABEL ) );\r
- _options_jmenu.add( _choose_minimal_confidence_mi = new JMenuItem( "" ) );\r
- _options_jmenu.add( _overview_placment_mi = new JMenuItem( "" ) );\r
- _options_jmenu.add( _switch_colors_mi = new JMenuItem( "" ) );\r
- _options_jmenu.add( _choose_font_mi = new JMenuItem( "" ) );\r
- ///////\r
- _options_jmenu.addSeparator();\r
- _options_jmenu.add( customizeMenuItemAsLabel( new JMenuItem( SEARCH_SUBHEADER ), getConfiguration() ) );\r
- _options_jmenu.add( _search_case_senstive_cbmi = new JCheckBoxMenuItem( SEARCH_CASE_SENSITIVE_LABEL ) );\r
- _options_jmenu.add( _search_whole_words_only_cbmi = new JCheckBoxMenuItem( SEARCH_TERMS_ONLY_LABEL ) );\r
- _options_jmenu.add( _inverse_search_result_cbmi = new JCheckBoxMenuItem( INVERSE_SEARCH_RESULT_LABEL ) );\r
- _options_jmenu.addSeparator();\r
- _options_jmenu.add( customizeMenuItemAsLabel( new JMenuItem( "Graphics Export & Printing:" ),\r
- getConfiguration() ) );\r
- _options_jmenu.add( _antialias_print_cbmi = new JCheckBoxMenuItem( "Antialias" ) );\r
- _options_jmenu.add( _print_black_and_white_cbmi = new JCheckBoxMenuItem( "Export in Black and White" ) );\r
- _options_jmenu\r
- .add( _print_using_actual_size_cbmi = new JCheckBoxMenuItem( "Use Current Image Size for PDF export and Printing" ) );\r
- _options_jmenu\r
- .add( _graphics_export_using_actual_size_cbmi = new JCheckBoxMenuItem( "Use Current Image Size for PNG, JPG, and GIF export" ) );\r
- _options_jmenu\r
- .add( _graphics_export_visible_only_cbmi = new JCheckBoxMenuItem( "Limit to Visible ('Screenshot') for PNG, JPG, and GIF export" ) );\r
- _options_jmenu.add( _print_size_mi = new JMenuItem( "" ) );\r
- _options_jmenu.add( _choose_pdf_width_mi = new JMenuItem( "" ) );\r
- _options_jmenu.addSeparator();\r
- _options_jmenu.add( customizeMenuItemAsLabel( new JMenuItem( "Newick/NHX/Nexus Input:" ), getConfiguration() ) );\r
- _options_jmenu\r
- .add( _internal_number_are_confidence_for_nh_parsing_cbmi = new JCheckBoxMenuItem( "Internal Node Names are Confidence Values" ) );\r
- _options_jmenu.add( _replace_underscores_cbmi = new JCheckBoxMenuItem( "Replace Underscores with Spaces" ) );\r
- _options_jmenu\r
- .add( _allow_errors_in_distance_to_parent_cbmi = new JCheckBoxMenuItem( "Ignore Distance Values Format Errors" ) );\r
- //\r
- _options_jmenu.add( _extract_taxonomy_no_rbmi = new JRadioButtonMenuItem( "No Taxonomy Extraction" ) );\r
- _options_jmenu\r
- .add( _extract_taxonomy_pfam_strict_rbmi = new JRadioButtonMenuItem( "Extract Taxonomy Codes/Ids from Pfam-style Node Names" ) );\r
- _options_jmenu\r
- .add( _extract_taxonomy_pfam_relaxed_rbmi = new JRadioButtonMenuItem( "Extract Taxonomy Codes/Ids from Pfam-style like Node Names" ) );\r
- _options_jmenu\r
- .add( _extract_taxonomy_agressive_rbmi = new JRadioButtonMenuItem( "Extract Taxonomy Codes/Ids/Scientific Names from Node Names" ) );\r
- _extract_taxonomy_pfam_strict_rbmi\r
- .setToolTipText( "To extract taxonomy codes/ids from node names in the form of e.g. \"BCL2_MOUSE/123-304\" or \"BCL2_10090/123-304\"" );\r
- _extract_taxonomy_pfam_relaxed_rbmi\r
- .setToolTipText( "To extract taxonomy codes/ids from node names in the form of e.g. \"bax_MOUSE\" or \"bax_10090\"" );\r
- _extract_taxonomy_agressive_rbmi\r
- .setToolTipText( "To extract taxonomy codes/ids or scientific names from node names in the form of e.g. \"MOUSE\" or \"10090\" or \"xyz_Nematostella_vectensis\"" );\r
- _radio_group_2 = new ButtonGroup();\r
- _radio_group_2.add( _extract_taxonomy_no_rbmi );\r
- _radio_group_2.add( _extract_taxonomy_pfam_strict_rbmi );\r
- _radio_group_2.add( _extract_taxonomy_pfam_relaxed_rbmi );\r
- _radio_group_2.add( _extract_taxonomy_agressive_rbmi );\r
- // \r
- _options_jmenu.add( customizeMenuItemAsLabel( new JMenuItem( "Newick/Nexus Output:" ), getConfiguration() ) );\r
- _options_jmenu\r
- .add( _use_brackets_for_conf_in_nh_export_cbmi = new JCheckBoxMenuItem( USE_BRACKETS_FOR_CONF_IN_NH_LABEL ) );\r
- _use_brackets_for_conf_in_nh_export_cbmi\r
- .setToolTipText( "e.g. \"0.1[90]\" for a branch with support 90 and a length of 0.1" );\r
- _options_jmenu\r
- .add( _use_internal_names_for_conf_in_nh_export_cbmi = new JCheckBoxMenuItem( USE_INTERNAL_NAMES_FOR_CONF_IN_NH_LABEL ) );\r
- customizeJMenuItem( _choose_font_mi );\r
- customizeJMenuItem( _choose_minimal_confidence_mi );\r
- customizeJMenuItem( _switch_colors_mi );\r
- customizeJMenuItem( _print_size_mi );\r
- customizeJMenuItem( _choose_pdf_width_mi );\r
- customizeJMenuItem( _overview_placment_mi );\r
- customizeCheckBoxMenuItem( _show_default_node_shapes_external_cbmi, getOptions()\r
- .isShowDefaultNodeShapesExternal() );\r
- customizeCheckBoxMenuItem( _show_default_node_shapes_internal_cbmi, getOptions()\r
- .isShowDefaultNodeShapesInternal() );\r
- customizeJMenuItem( _cycle_node_shape_mi );\r
- customizeJMenuItem( _cycle_node_fill_mi );\r
- customizeJMenuItem( _choose_node_size_mi );\r
- customizeCheckBoxMenuItem( _color_labels_same_as_parent_branch, getOptions().isColorLabelsSameAsParentBranch() );\r
- customizeCheckBoxMenuItem( _color_by_taxonomic_group_cbmi, getOptions().isColorByTaxonomicGroup() );\r
- customizeCheckBoxMenuItem( _screen_antialias_cbmi, getOptions().isAntialiasScreen() );\r
- customizeCheckBoxMenuItem( _background_gradient_cbmi, getOptions().isBackgroundColorGradient() );\r
- customizeCheckBoxMenuItem( _show_domain_labels, getOptions().isShowDomainLabels() );\r
- customizeCheckBoxMenuItem( _show_annotation_ref_source, getOptions().isShowAnnotationRefSource() );\r
- customizeCheckBoxMenuItem( _abbreviate_scientific_names, getOptions().isAbbreviateScientificTaxonNames() );\r
- customizeCheckBoxMenuItem( _search_case_senstive_cbmi, getOptions().isSearchCaseSensitive() );\r
- customizeCheckBoxMenuItem( _show_scale_cbmi, getOptions().isShowScale() );\r
- customizeRadioButtonMenuItem( _non_lined_up_cladograms_rbmi,\r
- getOptions().getCladogramType() == CLADOGRAM_TYPE.NON_LINED_UP );\r
- customizeRadioButtonMenuItem( _uniform_cladograms_rbmi,\r
- getOptions().getCladogramType() == CLADOGRAM_TYPE.TOTAL_NODE_SUM_DEP );\r
- customizeRadioButtonMenuItem( _ext_node_dependent_cladogram_rbmi,\r
- getOptions().getCladogramType() == CLADOGRAM_TYPE.EXT_NODE_SUM_DEP );\r
- customizeCheckBoxMenuItem( _show_overview_cbmi, getOptions().isShowOverview() );\r
- customizeCheckBoxMenuItem( _label_direction_cbmi,\r
- getOptions().getNodeLabelDirection() == NODE_LABEL_DIRECTION.RADIAL );\r
- customizeCheckBoxMenuItem( _antialias_print_cbmi, getOptions().isAntialiasPrint() );\r
- customizeCheckBoxMenuItem( _print_black_and_white_cbmi, getOptions().isPrintBlackAndWhite() );\r
- customizeCheckBoxMenuItem( _internal_number_are_confidence_for_nh_parsing_cbmi, getOptions()\r
- .isInternalNumberAreConfidenceForNhParsing() );\r
- customizeRadioButtonMenuItem( _extract_taxonomy_no_rbmi,\r
- getOptions().getTaxonomyExtraction() == TAXONOMY_EXTRACTION.NO );\r
- customizeRadioButtonMenuItem( _extract_taxonomy_pfam_strict_rbmi,\r
- getOptions().getTaxonomyExtraction() == TAXONOMY_EXTRACTION.PFAM_STYLE_STRICT );\r
- customizeRadioButtonMenuItem( _extract_taxonomy_pfam_relaxed_rbmi,\r
- getOptions().getTaxonomyExtraction() == TAXONOMY_EXTRACTION.PFAM_STYLE_RELAXED );\r
- customizeRadioButtonMenuItem( _extract_taxonomy_agressive_rbmi,\r
- getOptions().getTaxonomyExtraction() == TAXONOMY_EXTRACTION.AGGRESSIVE );\r
- customizeCheckBoxMenuItem( _replace_underscores_cbmi, getOptions().isReplaceUnderscoresInNhParsing() );\r
- customizeCheckBoxMenuItem( _allow_errors_in_distance_to_parent_cbmi, getOptions()\r
- .isReplaceUnderscoresInNhParsing() );\r
- customizeCheckBoxMenuItem( _search_whole_words_only_cbmi, getOptions().isMatchWholeTermsOnly() );\r
- customizeCheckBoxMenuItem( _inverse_search_result_cbmi, getOptions().isInverseSearchResult() );\r
- customizeCheckBoxMenuItem( _graphics_export_visible_only_cbmi, getOptions().isGraphicsExportVisibleOnly() );\r
- customizeCheckBoxMenuItem( _print_using_actual_size_cbmi, getOptions().isPrintUsingActualSize() );\r
- customizeCheckBoxMenuItem( _graphics_export_using_actual_size_cbmi, getOptions()\r
- .isGraphicsExportUsingActualSize() );\r
- customizeCheckBoxMenuItem( _show_confidence_stddev_cbmi, getOptions().isShowConfidenceStddev() );\r
- customizeCheckBoxMenuItem( _use_brackets_for_conf_in_nh_export_cbmi, getOptions()\r
- .getNhConversionSupportValueStyle() == NH_CONVERSION_SUPPORT_VALUE_STYLE.IN_SQUARE_BRACKETS );\r
- customizeCheckBoxMenuItem( _use_internal_names_for_conf_in_nh_export_cbmi, getOptions()\r
- .getNhConversionSupportValueStyle() == NH_CONVERSION_SUPPORT_VALUE_STYLE.AS_INTERNAL_NODE_NAMES );\r
- customizeCheckBoxMenuItem( _line_up_renderable_data_cbmi, getOptions().isLineUpRendarableNodeData() );\r
- customizeCheckBoxMenuItem( _right_line_up_domains_cbmi, getOptions().isRightLineUpDomains() );\r
- _jmenubar.add( _options_jmenu );\r
- }\r
-\r
- void buildPhylogeneticInferenceMenu() {\r
- final InferenceManager im = getInferenceManager();\r
- _inference_menu = MainFrame.createMenu( "Inference", getConfiguration() );\r
- _inference_menu.add( _inference_from_msa_item = new JMenuItem( "From Multiple Sequence Alignment..." ) );\r
- customizeJMenuItem( _inference_from_msa_item );\r
- _inference_from_msa_item.setToolTipText( "Basic phylogenetic inference from MSA" );\r
- if ( im.canDoMsa() ) {\r
- _inference_menu.add( _inference_from_seqs_item = new JMenuItem( "From Unaligned Sequences..." ) );\r
- customizeJMenuItem( _inference_from_seqs_item );\r
- _inference_from_seqs_item\r
- .setToolTipText( "Basic phylogenetic inference including multiple sequence alignment" );\r
- }\r
- else {\r
- _inference_menu\r
- .add( _inference_from_seqs_item = new JMenuItem( "From Unaligned Sequences (no program found)" ) );\r
- customizeJMenuItem( _inference_from_seqs_item );\r
- _inference_from_seqs_item.setEnabled( false );\r
- }\r
- _jmenubar.add( _inference_menu );\r
- }\r
-\r
- void buildToolsMenu() {\r
- _tools_menu = createMenu( "Tools", getConfiguration() );\r
- _tools_menu.add( _confcolor_item = new JMenuItem( "Colorize Branches Depending on Confidence" ) );\r
- customizeJMenuItem( _confcolor_item );\r
- _tools_menu.add( _color_rank_jmi = new JMenuItem( "Colorize Subtrees via Taxonomic Rank" ) );\r
- customizeJMenuItem( _color_rank_jmi );\r
- _color_rank_jmi.setToolTipText( "for example, at \"Class\" level, colorize mammal specific subtree red" );\r
- _tools_menu.add( _taxcolor_item = new JMenuItem( "Taxonomy Colorize Branches" ) );\r
- customizeJMenuItem( _taxcolor_item );\r
- _tools_menu.addSeparator();\r
- _tools_menu.add( _remove_visual_styles_item = new JMenuItem( "Delete All Visual Styles From Nodes" ) );\r
- _remove_visual_styles_item\r
- .setToolTipText( "To remove all node visual styles (fonts, colors) from the current phylogeny" );\r
- customizeJMenuItem( _remove_visual_styles_item );\r
- _tools_menu.add( _remove_branch_color_item = new JMenuItem( "Delete All Colors From Branches" ) );\r
- _remove_branch_color_item.setToolTipText( "To remove all branch color values from the current phylogeny" );\r
- customizeJMenuItem( _remove_branch_color_item );\r
- _tools_menu.addSeparator();\r
- _tools_menu.add( _annotate_item = new JMenuItem( "Annotate Sequences of Selected Nodes" ) );\r
- customizeJMenuItem( _annotate_item );\r
- _tools_menu.addSeparator();\r
- _tools_menu.add( _midpoint_root_item = new JMenuItem( "Midpoint-Root" ) );\r
- customizeJMenuItem( _midpoint_root_item );\r
- _tools_menu.addSeparator();\r
- _tools_menu.add( _delete_selected_nodes_item = new JMenuItem( "Delete Selected Nodes" ) );\r
- _delete_selected_nodes_item.setToolTipText( "To delete all selected external nodes" );\r
- customizeJMenuItem( _delete_selected_nodes_item );\r
- _tools_menu.add( _delete_not_selected_nodes_item = new JMenuItem( "Retain Selected Nodes" ) );\r
- _delete_not_selected_nodes_item.setToolTipText( "To delete all not selected external nodes" );\r
- customizeJMenuItem( _delete_not_selected_nodes_item );\r
- _tools_menu.addSeparator();\r
- _tools_menu.add( _collapse_species_specific_subtrees = new JMenuItem( "Collapse Species-Specific Subtrees" ) );\r
- customizeJMenuItem( _collapse_species_specific_subtrees );\r
- _tools_menu\r
- .add( _collapse_below_threshold = new JMenuItem( "Collapse Branches with Confidence Below Threshold into Multifurcations" ) );\r
- customizeJMenuItem( _collapse_below_threshold );\r
- _collapse_below_threshold\r
- .setToolTipText( "To collapse branches with confidence values below a threshold into multifurcations (in the case of multiple confidences per branch: without at least one confidence value above a threshold)" );\r
- _tools_menu.addSeparator();\r
- _tools_menu\r
- .add( _extract_tax_code_from_node_names_jmi = new JMenuItem( "Extract Taxonomic Data from Node Names" ) );\r
- customizeJMenuItem( _extract_tax_code_from_node_names_jmi );\r
- _extract_tax_code_from_node_names_jmi\r
- .setToolTipText( "To extract SwissProt/Uniprot taxonomic codes (mnemonics) from nodes names in the form of 'xyz_CAEEL', Uniprot/NCBI identifiers form of 'xyz_6239', or scientific names form of 'xyz_Caenorhabditis_elegans'" );\r
- _tools_menu\r
- .add( _move_node_names_to_tax_sn_jmi = new JMenuItem( "Transfer Node Names to Taxonomic Scientific Names" ) );\r
- customizeJMenuItem( _move_node_names_to_tax_sn_jmi );\r
- _move_node_names_to_tax_sn_jmi.setToolTipText( "To interpret node names as taxonomic scientific names" );\r
- _tools_menu.add( _move_node_names_to_seq_names_jmi = new JMenuItem( "Transfer Node Names to Sequence Names" ) );\r
- customizeJMenuItem( _move_node_names_to_seq_names_jmi );\r
- _move_node_names_to_seq_names_jmi.setToolTipText( "To interpret node names as sequence (protein, gene) names" );\r
- _tools_menu.addSeparator();\r
- _tools_menu.add( _obtain_seq_information_jmi = new JMenuItem( "Obtain Sequence Information" ) );\r
- customizeJMenuItem( _obtain_seq_information_jmi );\r
- _obtain_seq_information_jmi.setToolTipText( "To add additional sequence information" );\r
- _tools_menu\r
- .add( _obtain_detailed_taxonomic_information_jmi = new JMenuItem( OBTAIN_DETAILED_TAXONOMIC_INFORMATION ) );\r
- customizeJMenuItem( _obtain_detailed_taxonomic_information_jmi );\r
- _obtain_detailed_taxonomic_information_jmi\r
- .setToolTipText( "To add additional taxonomic information (from UniProt Taxonomy)" );\r
- _tools_menu\r
- .add( _obtain_detailed_taxonomic_information_deleting_jmi = new JMenuItem( "Obtain Detailed Taxonomic Information (deletes nodes!)" ) );\r
- customizeJMenuItem( _obtain_detailed_taxonomic_information_deleting_jmi );\r
- _obtain_detailed_taxonomic_information_deleting_jmi\r
- .setToolTipText( "To add additional taxonomic information, deletes nodes for which taxonomy cannot found (from UniProt Taxonomy)" );\r
- _tools_menu.addSeparator();\r
- _tools_menu.add( _read_values_jmi = new JMenuItem( "Attach Vector/Expression Values" ) );\r
- customizeJMenuItem( _read_values_jmi );\r
- _read_values_jmi.setToolTipText( "To attach vector (e.g. gene expression) values to tree nodes (beta)" );\r
- _jmenubar.add( _tools_menu );\r
- _tools_menu.add( _read_seqs_jmi = new JMenuItem( "Attach Molecular Sequences" ) );\r
- customizeJMenuItem( _read_seqs_jmi );\r
- _read_seqs_jmi\r
- .setToolTipText( "To attach molecular sequences to tree nodes (from Fasta-formatted file) (beta)" );\r
- _jmenubar.add( _tools_menu );\r
- }\r
-\r
- @Override\r
- void close() {\r
- if ( isUnsavedDataPresent() ) {\r
- final int r = JOptionPane.showConfirmDialog( this,\r
- "Exit despite potentially unsaved changes?",\r
- "Exit?",\r
- JOptionPane.YES_NO_OPTION );\r
- if ( r != JOptionPane.YES_OPTION ) {\r
- return;\r
- }\r
- }\r
- exit();\r
- }\r
-\r
- void executeLineageInference() {\r
- if ( ( _mainpanel.getCurrentPhylogeny() == null ) || ( _mainpanel.getCurrentPhylogeny().isEmpty() ) ) {\r
- return;\r
- }\r
- if ( !_mainpanel.getCurrentPhylogeny().isRooted() ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Phylogeny is not rooted.",\r
- "Cannot infer ancestral taxonomies",\r
- JOptionPane.ERROR_MESSAGE );\r
- return;\r
- }\r
- final AncestralTaxonomyInferrer inferrer = new AncestralTaxonomyInferrer( this,\r
- _mainpanel.getCurrentTreePanel(),\r
- _mainpanel.getCurrentPhylogeny()\r
- .copy() );\r
- new Thread( inferrer ).start();\r
- }\r
-\r
- void exit() {\r
- removeAllTextFrames();\r
- _mainpanel.terminate();\r
- _contentpane.removeAll();\r
- setVisible( false );\r
- dispose();\r
- System.exit( 0 );\r
- }\r
-\r
- void readPhylogeniesFromURL() {\r
- URL url = null;\r
- Phylogeny[] phys = null;\r
- final String message = "Please enter a complete URL, for example \"http://purl.org/phylo/treebase/phylows/study/TB2:S15480?format=nexus\"";\r
- final String url_string = JOptionPane.showInputDialog( this,\r
- message,\r
- "Use URL/webservice to obtain a phylogeny",\r
- JOptionPane.QUESTION_MESSAGE );\r
- boolean nhx_or_nexus = false;\r
- if ( ( url_string != null ) && ( url_string.length() > 0 ) ) {\r
- try {\r
- url = new URL( url_string );\r
- PhylogenyParser parser = null;\r
- if ( url.getHost().toLowerCase().indexOf( "tolweb" ) >= 0 ) {\r
- parser = new TolParser();\r
- }\r
- else {\r
- parser = ParserUtils.createParserDependingOnUrlContents( url, getConfiguration()\r
- .isValidatePhyloXmlAgainstSchema() );\r
- }\r
- if ( parser instanceof NexusPhylogeniesParser ) {\r
- nhx_or_nexus = true;\r
- }\r
- else if ( parser instanceof NHXParser ) {\r
- nhx_or_nexus = true;\r
- }\r
- if ( _mainpanel.getCurrentTreePanel() != null ) {\r
- _mainpanel.getCurrentTreePanel().setWaitCursor();\r
- }\r
- else {\r
- _mainpanel.setWaitCursor();\r
- }\r
- final PhylogenyFactory factory = ParserBasedPhylogenyFactory.getInstance();\r
- phys = factory.create( url.openStream(), parser );\r
- }\r
- catch ( final MalformedURLException e ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Malformed URL: " + url + "\n" + e.getLocalizedMessage(),\r
- "Malformed URL",\r
- JOptionPane.ERROR_MESSAGE );\r
- }\r
- catch ( final IOException e ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Could not read from " + url + "\n"\r
- + ForesterUtil.wordWrap( e.getLocalizedMessage(), 80 ),\r
- "Failed to read URL",\r
- JOptionPane.ERROR_MESSAGE );\r
- }\r
- catch ( final Exception e ) {\r
- JOptionPane.showMessageDialog( this,\r
- ForesterUtil.wordWrap( e.getLocalizedMessage(), 80 ),\r
- "Unexpected Exception",\r
- JOptionPane.ERROR_MESSAGE );\r
- }\r
- finally {\r
- if ( _mainpanel.getCurrentTreePanel() != null ) {\r
- _mainpanel.getCurrentTreePanel().setArrowCursor();\r
- }\r
- else {\r
- _mainpanel.setArrowCursor();\r
- }\r
- }\r
- if ( ( phys != null ) && ( phys.length > 0 ) ) {\r
- if ( nhx_or_nexus && getOptions().isInternalNumberAreConfidenceForNhParsing() ) {\r
- for( final Phylogeny phy : phys ) {\r
- PhylogenyMethods.transferInternalNodeNamesToConfidence( phy, "" );\r
- }\r
- }\r
- AptxUtil.addPhylogeniesToTabs( phys,\r
- new File( url.getFile() ).getName(),\r
- new File( url.getFile() ).toString(),\r
- getConfiguration(),\r
- getMainPanel() );\r
- _mainpanel.getControlPanel().showWhole();\r
- }\r
- }\r
- activateSaveAllIfNeeded();\r
- System.gc();\r
- }\r
-\r
- void setMsa( final Msa msa ) {\r
- _msa = msa;\r
- }\r
-\r
- void setMsaFile( final File msa_file ) {\r
- _msa_file = msa_file;\r
- }\r
-\r
- void setSeqs( final List<MolecularSequence> seqs ) {\r
- _seqs = seqs;\r
- }\r
-\r
- void setSeqsFile( final File seqs_file ) {\r
- _seqs_file = seqs_file;\r
- }\r
-\r
- void writePhylogenyToGraphicsFile( final String file_name, final GraphicsExportType type ) {\r
- _mainpanel.getCurrentTreePanel().calcParametersForPainting( _mainpanel.getCurrentTreePanel().getWidth(),\r
- _mainpanel.getCurrentTreePanel().getHeight(),\r
- true );\r
- String file_written_to = "";\r
- boolean error = false;\r
- try {\r
- file_written_to = AptxUtil.writePhylogenyToGraphicsFile( file_name,\r
- _mainpanel.getCurrentTreePanel().getWidth(),\r
- _mainpanel.getCurrentTreePanel().getHeight(),\r
- _mainpanel.getCurrentTreePanel(),\r
- _mainpanel.getControlPanel(),\r
- type,\r
- getOptions() );\r
- }\r
- catch ( final IOException e ) {\r
- error = true;\r
- JOptionPane.showMessageDialog( this, e.getMessage(), "Error", JOptionPane.ERROR_MESSAGE );\r
- }\r
- if ( !error ) {\r
- if ( ( file_written_to != null ) && ( file_written_to.length() > 0 ) ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Wrote image to: " + file_written_to,\r
- "Graphics Export",\r
- JOptionPane.INFORMATION_MESSAGE );\r
- }\r
- else {\r
- JOptionPane.showMessageDialog( this,\r
- "There was an unknown problem when attempting to write to an image file: \""\r
- + file_name + "\"",\r
- "Error",\r
- JOptionPane.ERROR_MESSAGE );\r
- }\r
- }\r
- _contentpane.repaint();\r
- }\r
-\r
- private void addExpressionValuesFromFile() {\r
- if ( ( getCurrentTreePanel() == null ) || ( getCurrentTreePanel().getPhylogeny() == null ) ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Need to load evolutionary tree first",\r
- "Can Not Read Expression Values",\r
- JOptionPane.WARNING_MESSAGE );\r
- return;\r
- }\r
- final File my_dir = getCurrentDir();\r
- if ( my_dir != null ) {\r
- _values_filechooser.setCurrentDirectory( my_dir );\r
- }\r
- final int result = _values_filechooser.showOpenDialog( _contentpane );\r
- final File file = _values_filechooser.getSelectedFile();\r
- if ( ( file != null ) && ( file.length() > 0 ) && ( result == JFileChooser.APPROVE_OPTION ) ) {\r
- BasicTable<String> t = null;\r
- try {\r
- t = BasicTableParser.parse( file, '\t' );\r
- if ( t.getNumberOfColumns() < 2 ) {\r
- t = BasicTableParser.parse( file, ',' );\r
- }\r
- if ( t.getNumberOfColumns() < 2 ) {\r
- t = BasicTableParser.parse( file, ' ' );\r
- }\r
- }\r
- catch ( final IOException e ) {\r
- JOptionPane.showMessageDialog( this,\r
- e.getMessage(),\r
- "Could Not Read Expression Value Table",\r
- JOptionPane.ERROR_MESSAGE );\r
- return;\r
- }\r
- if ( t.getNumberOfColumns() < 2 ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Table contains " + t.getNumberOfColumns() + " column(s)",\r
- "Problem with Expression Value Table",\r
- JOptionPane.ERROR_MESSAGE );\r
- return;\r
- }\r
- if ( t.getNumberOfRows() < 1 ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Table contains zero rows",\r
- "Problem with Expression Value Table",\r
- JOptionPane.ERROR_MESSAGE );\r
- return;\r
- }\r
- final Phylogeny phy = getCurrentTreePanel().getPhylogeny();\r
- if ( t.getNumberOfRows() != phy.getNumberOfExternalNodes() ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Table contains " + t.getNumberOfRows() + " rows, but tree contains "\r
- + phy.getNumberOfExternalNodes() + " external nodes",\r
- "Warning",\r
- JOptionPane.WARNING_MESSAGE );\r
- }\r
- final DescriptiveStatistics stats = new BasicDescriptiveStatistics();\r
- int not_found = 0;\r
- for( final PhylogenyNodeIterator iter = phy.iteratorPreorder(); iter.hasNext(); ) {\r
- final PhylogenyNode node = iter.next();\r
- final String node_name = node.getName();\r
- if ( !ForesterUtil.isEmpty( node_name ) ) {\r
- int row = -1;\r
- try {\r
- row = t.findRow( node_name );\r
- }\r
- catch ( final IllegalArgumentException e ) {\r
- JOptionPane\r
- .showMessageDialog( this,\r
- e.getMessage(),\r
- "Error Mapping Node Identifiers to Expression Value Identifiers",\r
- JOptionPane.ERROR_MESSAGE );\r
- return;\r
- }\r
- if ( row < 0 ) {\r
- if ( node.isExternal() ) {\r
- not_found++;\r
- }\r
- continue;\r
- }\r
- final List<Double> l = new ArrayList<Double>();\r
- for( int col = 1; col < t.getNumberOfColumns(); ++col ) {\r
- double d = -100;\r
- try {\r
- d = Double.parseDouble( t.getValueAsString( col, row ) );\r
- }\r
- catch ( final NumberFormatException e ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Could not parse \"" + t.getValueAsString( col, row )\r
- + "\" into a decimal value",\r
- "Issue with Expression Value Table",\r
- JOptionPane.ERROR_MESSAGE );\r
- return;\r
- }\r
- stats.addValue( d );\r
- l.add( d );\r
- }\r
- if ( !l.isEmpty() ) {\r
- if ( node.getNodeData().getProperties() != null ) {\r
- node.getNodeData().getProperties()\r
- .removePropertiesWithGivenReferencePrefix( PhyloXmlUtil.VECTOR_PROPERTY_REF );\r
- }\r
- node.getNodeData().setVector( l );\r
- }\r
- }\r
- }\r
- if ( not_found > 0 ) {\r
- JOptionPane.showMessageDialog( this, "Could not fine expression values for " + not_found\r
- + " external node(s)", "Warning", JOptionPane.WARNING_MESSAGE );\r
- }\r
- getCurrentTreePanel().setStatisticsForExpressionValues( stats );\r
- }\r
- }\r
-\r
- private void addSequencesFromFile() {\r
- if ( ( getCurrentTreePanel() == null ) || ( getCurrentTreePanel().getPhylogeny() == null ) ) {\r
- JOptionPane.showMessageDialog( this,\r
- "Need to load evolutionary tree first",\r
- "Can Not Read Sequences",\r
- JOptionPane.WARNING_MESSAGE );\r
- return;\r
- }\r
- final File my_dir = getCurrentDir();\r
- if ( my_dir != null ) {\r
- _sequences_filechooser.setCurrentDirectory( my_dir );\r
- }\r
- final int result = _sequences_filechooser.showOpenDialog( _contentpane );\r
- final File file = _sequences_filechooser.getSelectedFile();\r
- List<MolecularSequence> seqs = null;\r
- if ( ( file != null ) && !file.isDirectory() && ( result == JFileChooser.APPROVE_OPTION ) ) {\r
- try {\r
- if ( FastaParser.isLikelyFasta( new FileInputStream( file ) ) ) {\r
- seqs = FastaParser.parse( new FileInputStream( file ) );\r
- }\r
- else {\r
- JOptionPane.showMessageDialog( this,\r
- "Format does not appear to be Fasta",\r
- "Multiple sequence file format error",\r
- JOptionPane.ERROR_MESSAGE );\r
- return;\r