X-Git-Url: http://source.jalview.org/gitweb/?a=blobdiff_plain;f=src%2Fjalview%2Fdatamodel%2FContactMatrixI.java;h=1d20987117ba409ebb79782c9453ca51acf03f19;hb=d4271d32477e99e9fbbfa5db3e11f1b79324e60d;hp=2b7b4ec0110c20d098988a029e3d2470e3f3c9d7;hpb=c3d17bf8cd43fe710f94a1111e845a0c435bb0c9;p=jalview.git diff --git a/src/jalview/datamodel/ContactMatrixI.java b/src/jalview/datamodel/ContactMatrixI.java index 2b7b4ec..1d20987 100644 --- a/src/jalview/datamodel/ContactMatrixI.java +++ b/src/jalview/datamodel/ContactMatrixI.java @@ -1,5 +1,10 @@ package jalview.datamodel; +import java.awt.Color; +import java.util.Arrays; +import java.util.BitSet; +import java.util.List; + public interface ContactMatrixI { @@ -9,4 +14,112 @@ public interface ContactMatrixI float getMax(); + String getAnnotDescr(); + + String getAnnotLabel(); + + /** + * string indicating how the contactMatrix should be rendered - stored in + * calcId + * + * @return + */ + String getType(); + + int getWidth(); + int getHeight(); + public GroupSetI getGroupSet(); + + /// proxy methods to simplify use of the interface + /// Mappable contact matrices can override these to perform mapping + + default public boolean hasGroupSet() + { + return getGroupSet() != null; + } + + default boolean hasGroups() + { + return hasGroupSet() && getGroupSet().hasGroups(); + } + + default BitSet getGroupsFor(int column) + { + if (!hasGroupSet()) + { + BitSet colbitset = new BitSet(); + colbitset.set(column); + return colbitset; + } + return getGroupSet().getGroupsFor(column); + } + + default List getGroups() + { + if (!hasGroupSet()) + { + return Arrays.asList(); + } + return getGroupSet().getGroups(); + } + + default boolean hasTree() + { + return hasGroupSet() ? getGroupSet().hasTree() : false; + } + + /** + * Newick representation of clustered matrix + * + * @return null unless hasTree is true + */ + default String getNewick() + { + return hasGroupSet() ? getGroupSet().getNewick() : null; + } + + default String getTreeMethod() + { + return hasGroupSet() ? getGroupSet().getTreeMethod() : null; + } + + default boolean hasCutHeight() + { + return hasGroupSet() ? getGroupSet().hasCutHeight() : false; + } + + default double getCutHeight() + { + return hasGroupSet() ? getGroupSet().getCutHeight() : 0; + } + + default void updateGroups(List colGroups) + { + if (hasGroupSet()) + { + getGroupSet().updateGroups(colGroups); + } + } + + default void setColorForGroup(BitSet bs, Color color) + { + if (hasGroupSet()) + { + getGroupSet().setColorForGroup(bs, color); + } + } + + default Color getColourForGroup(BitSet bs) + { + if (hasGroupSet()) + { + return getGroupSet().getColourForGroup(bs); + } + else + { + return Color.white; + } + } + + void setGroupSet(GroupSet makeGroups); }