X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Fjalview%2Frenderer%2Fseqfeatures%2FFeatureColourFinder.java;h=57366b9abe13424f23f4dd838c923981291ac5f9;hb=eb190489441b102c7dce1ee0121df7efd3e74b1a;hp=a2ce35bac39bb7acfdbccb605955e797203b1bc8;hpb=08b87509ada06ac8614424247346daef4054b41a;p=jalview.git diff --git a/src/jalview/renderer/seqfeatures/FeatureColourFinder.java b/src/jalview/renderer/seqfeatures/FeatureColourFinder.java index a2ce35b..57366b9 100644 --- a/src/jalview/renderer/seqfeatures/FeatureColourFinder.java +++ b/src/jalview/renderer/seqfeatures/FeatureColourFinder.java @@ -23,6 +23,7 @@ package jalview.renderer.seqfeatures; import jalview.api.FeatureRenderer; import jalview.api.FeaturesDisplayedI; import jalview.datamodel.SequenceI; +import jalview.util.Platform; import jalview.viewmodel.seqfeatures.FeatureRendererModel; import java.awt.Color; @@ -98,10 +99,16 @@ public class FeatureColourFinder if (featureRenderer.getTransparency() != 1f) { g = goff; - if (defaultColour != null) + Color c = (defaultColour == null ? Color.white : defaultColour); + if (Platform.isJS()) { - offscreenImage.setRGB(0, 0, defaultColour.getRGB()); + // Clear the HTML5 canvas color. + // otherwise we get a smearing. + // For whatever reason, this is necessary BH 2019.10.01. + g.setColor(c); + g.fillRect(0, 0, 1, 1); } + offscreenImage.setRGB(0, 0, c.getRGB()); } Color c = featureRenderer.findFeatureColour(seq, column + 1, g); @@ -112,41 +119,20 @@ public class FeatureColourFinder if (g != null) { - c = new Color(offscreenImage.getRGB(0, 0)); - } - return c; - } - - public int findFeatureColourInt(int defaultColour, SequenceI seq, - int column) - { - Graphics g = null; - - /* - * if transparency applies, provide a notional 1x1 graphics context - * that has been primed with the default colour - */ - if (featureRenderer.getTransparency() != 1f) - { - g = goff; - if (defaultColour != 0) + if (Platform.isJS()) { - offscreenImage.setRGB(0, 0, defaultColour); + /* + * for JavaScript the pixel itself + * is a resource that needs to be recreated in getRGB(0,0) + */ + offscreenImage.flush(); } + c = new Color(offscreenImage.getRGB(0, 0)); } - Color c = featureRenderer.findFeatureColour(seq, column + 1, g); - if (c == null) - { - return defaultColour; - } - - if (g != null) - { - return offscreenImage.getRGB(0, 0); - } - return c.getRGB(); + return c; } + /** * Answers true if feature display is turned off, or there are no features * configured to be visible