private float _last_drag_point_y = 0;
private final Line2D _line = new Line2D.Float();
private int _longest_ext_node_info = 0;
+ private PhylogenyNode _ext_node_with_longest_txt_info = null;
private MainPanel _main_panel = null;
private double _max_distance_to_root = -1;
private Popup _node_desc_popup;
private final StringBuilder _sb = new StringBuilder();
private double _scale_distance = 0.0;
private String _scale_label = null;
- // expression values menu:
private DescriptiveStatistics _statistics_for_vector_data;
private final Phylogeny[] _sub_phylogenies = new Phylogeny[ TreePanel.MAX_SUBTREES ];
private final PhylogenyNode[] _sub_phylogenies_temp_roots = new PhylogenyNode[ TreePanel.MAX_SUBTREES ];
private float _x_correction_factor = 0.0f;
private float _x_distance = 0.0f;
private float _y_distance = 0.0f;
+ private int _length_of_longest_text;
+ private int _longest_domain;
// private Image offscreenImage;
// private Graphics offscreenGraphics;
// private Dimension offscreenDimension;
}
}
}
+ _length_of_longest_text = calcLengthOfLongestText();
}
int ext_nodes = _phylogeny.getRoot().getNumberOfExternalNodes();
final int max_depth = PhylogenyMethods.calculateMaxDepth( _phylogeny );
max_length = 40;
}
int longest = 30;
+ int longest_txt = 0;
+ _longest_domain = 0;
+ PhylogenyNode longest_txt_node = _phylogeny.getFirstExternalNode();
for( final PhylogenyNode node : _phylogeny.getExternalNodes() ) {
int sum = 0;
if ( node.isCollapse() ) {
if ( node.getNodeData().isHasTaxonomy() ) {
nodeTaxonomyDataAsSB( node.getNodeData().getTaxonomy(), sb );
}
+ final int txt = sb.length();
+ if ( txt > longest_txt ) {
+ longest_txt = txt;
+ longest_txt_node = node;
+ }
boolean use_vis = false;
final Graphics2D g = ( Graphics2D ) getGraphics();
if ( getControlPanel().isUseVisualStyles() ) {
}
if ( getControlPanel().isShowDomainArchitectures() && node.getNodeData().isHasSequence()
&& ( node.getNodeData().getSequence().getDomainArchitecture() != null ) ) {
- // FIXME
+ // FIXME
// TODO this might need some clean up
final DomainArchitecture d = node.getNodeData().getSequence().getDomainArchitecture();
- sum += ( ( _domain_structure_width / ( ( RenderableDomainArchitecture ) d ).getOriginalSize().getWidth() ) * d.getTotalLength() ) + 10;
+ sum += ( ( _domain_structure_width / ( ( RenderableDomainArchitecture ) d ).getOriginalSize()
+ .getWidth() ) * d.getTotalLength() ) + 10;
+ if ( d.getTotalLength() > _longest_domain ) {
+ _longest_domain = d.getTotalLength();
+ }
}
if ( sum >= max_length ) {
- setLongestExtNodeInfo( max_length );
+ _longest_ext_node_info = max_length;
return;
}
if ( sum > longest ) {
longest = sum;
}
}
+ _ext_node_with_longest_txt_info = longest_txt_node;
if ( longest >= max_length ) {
- setLongestExtNodeInfo( max_length );
+ _longest_ext_node_info = max_length;
}
else {
- setLongestExtNodeInfo( longest );
+ _longest_ext_node_info = longest;
}
}
}
if ( c == null ) {
if ( !ForesterUtil.isEmpty( tax.getTaxonomyCode() ) ) {
- c = TreePanelUtil.calculateColorFromString( tax.getTaxonomyCode(), true );
+ c = AptxUtil.calculateColorFromString( tax.getTaxonomyCode(), true );
getControlPanel().getSpeciesColors().put( tax.getTaxonomyCode(), c );
}
else {
- c = TreePanelUtil.calculateColorFromString( tax.getScientificName(), true );
+ c = AptxUtil.calculateColorFromString( tax.getScientificName(), true );
getControlPanel().getSpeciesColors().put( tax.getScientificName(), c );
}
}
final String seq_name = seq.getName();
c = getControlPanel().getSequenceColors().get( seq_name );
if ( c == null ) {
- c = TreePanelUtil.calculateColorFromString( seq_name, false );
+ c = AptxUtil.calculateColorFromString( seq_name, false );
getControlPanel().getSequenceColors().put( seq_name, c );
}
return c;
_control_panel.getColorAccSpeciesCb().setSelected( false );
}
_options.setColorLabelsSameAsParentBranch( true );
+ if ( getMainPanel().getMainFrame()._color_labels_same_as_parent_branch != null ) {
+ getMainPanel().getMainFrame()._color_labels_same_as_parent_branch.setSelected( true );
+ }
_control_panel.repaint();
}
setArrowCursor();
return getTreeColorSet().getSequenceColor();
}
- /**
- * @return pointer to colorset for tree drawing
- */
- final TreeColorSet getTreeColorSet() {
+ public final TreeColorSet getTreeColorSet() {
return getMainPanel().getTreeColorSet();
}
if ( ( _phylogeny == null ) || _phylogeny.isEmpty() ) {
return;
}
- double max_original_domain_structure_width = 0.0;
+ double _max_original_domain_structure_width = 0.0;
for( final PhylogenyNode node : _phylogeny.getExternalNodes() ) {
if ( node.getNodeData().isHasSequence()
&& ( node.getNodeData().getSequence().getDomainArchitecture() != null ) ) {
RenderableDomainArchitecture rds = null;
if ( !( node.getNodeData().getSequence().getDomainArchitecture() instanceof RenderableDomainArchitecture ) ) {
- rds = new RenderableDomainArchitecture( node.getNodeData().getSequence().getDomainArchitecture(),
- getConfiguration() );
+ rds = new RenderableDomainArchitecture( node.getNodeData().getSequence().getDomainArchitecture() );
node.getNodeData().getSequence().setDomainArchitecture( rds );
}
else {
}
if ( getControlPanel().isShowDomainArchitectures() ) {
final double dsw = rds.getOriginalSize().getWidth();
- if ( dsw > max_original_domain_structure_width ) {
- max_original_domain_structure_width = dsw;
+ if ( dsw > _max_original_domain_structure_width ) {
+ _max_original_domain_structure_width = dsw;
}
}
}
}
if ( getControlPanel().isShowDomainArchitectures() ) {
- final double ds_factor_width = _domain_structure_width / max_original_domain_structure_width;
+ final double ds_factor_width = _domain_structure_width / _max_original_domain_structure_width;
for( final PhylogenyNode node : _phylogeny.getExternalNodes() ) {
if ( node.getNodeData().isHasSequence()
&& ( node.getNodeData().getSequence().getDomainArchitecture() != null ) ) {
_last_drag_point_y = y;
}
- final void setLongestExtNodeInfo( final int i ) {
- _longest_ext_node_info = i;
- }
-
final void setMediumFonts() {
getTreeFontSet().mediumFonts();
}
if ( !ForesterUtil.isEmpty( ann_str ) ) {
c = getControlPanel().getAnnotationColors().get( ann_str );
if ( c == null ) {
- c = TreePanelUtil.calculateColorFromString( ann_str, false );
+ c = AptxUtil.calculateColorFromString( ann_str, false );
getControlPanel().getAnnotationColors().put( ann_str, c );
}
if ( c == null ) {
final boolean disallow_shortcutting = ( dynamic_hiding_factor < 40 );
float min_dist = 1.5f;
if ( !disallow_shortcutting ) {
- // System.out.println( dynamic_hiding_factor );
if ( dynamic_hiding_factor > 4000 ) {
min_dist = 4;
}
if ( getControlPanel().isShowDomainArchitectures() && node.getNodeData().isHasSequence()
&& ( node.getNodeData().getSequence().getDomainArchitecture() != null ) ) {
RenderableDomainArchitecture rds = null;
- if ( node.getNodeData().getSequence().getDomainArchitecture() instanceof RenderableDomainArchitecture ) {
- try {
- rds = ( RenderableDomainArchitecture ) node.getNodeData().getSequence().getDomainArchitecture();
- }
- catch ( final ClassCastException cce ) {
- cce.printStackTrace();
+ try {
+ rds = ( RenderableDomainArchitecture ) node.getNodeData().getSequence().getDomainArchitecture();
+ }
+ catch ( final ClassCastException cce ) {
+ cce.printStackTrace();
+ }
+ if ( rds != null ) {
+ final int default_height = 7;
+ float y = getYdistance();
+ if ( getControlPanel().isDynamicallyHideData() ) {
+ y = getTreeFontSet().getFontMetricsLarge().getHeight();
+ }
+ final int h = y < default_height ? ForesterUtil.roundToInt( y ) : default_height;
+ rds.setRenderingHeight( h > 1 ? h : 2 );
+ if ( getControlPanel().isDrawPhylogram() ) {
+ if ( getOptions().isLineUpRendarableNodeData() ) {
+ if ( getOptions().isRightLineUpDomains() ) {
+ rds.render( getMaxDistanceToRoot() * getXcorrectionFactor() + _length_of_longest_text
+ + ( _longest_domain - rds.getTotalLength() )
+ * rds.getRenderingFactorWidth(),
+ node.getYcoord() - ( h / 2 ),
+ g,
+ this,
+ to_pdf );
+ }
+ else {
+ rds.render( getMaxDistanceToRoot() * getXcorrectionFactor() + _length_of_longest_text,
+ node.getYcoord() - ( h / 2 ),
+ g,
+ this,
+ to_pdf );
+ }
+ }
+ else {
+ rds.render( node.getXcoord() + x, node.getYcoord() - ( h / 2 ), g, this, to_pdf );
+ }
}
- if ( rds != null ) {
- rds.setRenderingHeight( 6 );
- if ( getControlPanel().isDrawPhylogram() ) {
- rds.render( node.getXcoord() + x, node.getYcoord() - 3, g, this, to_pdf );
+ else {
+ if ( getOptions().isRightLineUpDomains() ) {
+ rds.render( getPhylogeny().getFirstExternalNode().getXcoord() + _length_of_longest_text
+ - 20 + ( _longest_domain - rds.getTotalLength() )
+ * rds.getRenderingFactorWidth(),
+ node.getYcoord() - ( h / 2 ),
+ g,
+ this,
+ to_pdf );
}
else {
- int xx = 0;
- PhylogenyNode my_node = node;
- if ( !getControlPanel().isDrawPhylogram() ) {
- my_node = getPhylogeny().getFirstExternalNode();
- }
- if ( getControlPanel().isShowTaxonomyCode()
- && ( PhylogenyMethods.getSpecies( my_node ).length() > 0 ) ) {
- xx += getFontMetricsForLargeDefaultFont()
- .stringWidth( PhylogenyMethods.getSpecies( my_node ) + " " );
- }
- if ( getControlPanel().isShowNodeNames() && ( my_node.getName().length() > 0 ) ) {
- xx += getFontMetricsForLargeDefaultFont().stringWidth( my_node.getName() + " " );
- }
- //
- rds.render( my_node.getXcoord() + xx, node.getYcoord() - 3, g, this, to_pdf );
+ rds.render( getPhylogeny().getFirstExternalNode().getXcoord() + _length_of_longest_text,
+ node.getYcoord() - ( h / 2 ),
+ g,
+ this,
+ to_pdf );
}
}
}
}
- //////////////
if ( getControlPanel().isShowVectorData() && ( node.getNodeData().getVector() != null )
&& ( node.getNodeData().getVector().size() > 0 ) && ( getStatisticsForExpressionValues() != null ) ) {
final RenderableVector rv = RenderableVector.createInstance( node.getNodeData().getVector(),
getStatisticsForExpressionValues(),
getConfiguration() );
if ( rv != null ) {
- int xx = 0;
- PhylogenyNode my_node = node;
- if ( !getControlPanel().isDrawPhylogram() ) {
- my_node = getPhylogeny().getFirstExternalNode();
+ double domain_add = 0;
+ if ( getControlPanel().isShowDomainArchitectures() && node.getNodeData().isHasSequence()
+ && ( node.getNodeData().getSequence().getDomainArchitecture() != null ) ) {
+ domain_add = _domain_structure_width + 10;
}
- if ( getControlPanel().isShowTaxonomyCode() && ( PhylogenyMethods.getSpecies( my_node ).length() > 0 ) ) {
- xx += getFontMetricsForLargeDefaultFont()
- .stringWidth( PhylogenyMethods.getSpecies( my_node ) + " " );
+ if ( getControlPanel().isDrawPhylogram() ) {
+ rv.render( node.getXcoord() + x + domain_add, node.getYcoord() - 3, g, this, to_pdf );
}
- if ( getControlPanel().isShowNodeNames() && ( my_node.getName().length() > 0 ) ) {
- xx += getFontMetricsForLargeDefaultFont().stringWidth( my_node.getName() + " " );
+ else {
+ rv.render( getPhylogeny().getFirstExternalNode().getXcoord() + _length_of_longest_text + domain_add,
+ node.getYcoord() - 3,
+ g,
+ this,
+ to_pdf );
}
- rv.render( my_node.getXcoord() + xx, node.getYcoord() - 5, g, this, to_pdf );
}
}
- //////////////
+ }
+
+ final private int calcLengthOfLongestText() {
+ final StringBuilder sb = new StringBuilder();
+ nodeDataAsSB( _ext_node_with_longest_txt_info, sb );
+ if ( _ext_node_with_longest_txt_info.getNodeData().isHasTaxonomy() ) {
+ nodeTaxonomyDataAsSB( _ext_node_with_longest_txt_info.getNodeData().getTaxonomy(), sb );
+ }
+ return getFontMetricsForLargeDefaultFont().stringWidth( sb.toString() );
}
final private void paintOvRectangle( final Graphics2D g ) {