2 * Jalview - A Sequence Alignment Editor and Viewer ($$Version-Rel$$)
3 * Copyright (C) $$Year-Rel$$ The Jalview Authors
5 * This file is part of Jalview.
7 * Jalview is free software: you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation, either version 3
10 * of the License, or (at your option) any later version.
12 * Jalview is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty
14 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with Jalview. If not, see <http://www.gnu.org/licenses/>.
19 * The Jalview Authors are detailed in the 'AUTHORS' file.
23 import java.util.List;
26 * prototype abstract controller for a Jalview alignment view
30 * All operations should return true if the view has changed as a result
33 * The controller holds methods that operate on an alignment view,
34 * modifying its state in some way that may result in side effects
35 * reflected in an associated GUI
38 public interface AlignViewControllerI
41 public boolean makeGroupsFromSelection();
43 public boolean createGroup();
45 public boolean unGroup();
47 public boolean deleteGroups();
49 public void setViewportAndAlignmentPanel(AlignViewportI viewport,
50 AlignmentViewPanel alignPanel);
53 * Mark columns in the current column selection according to positions of
57 * - when set, mark all but columns containing given type
58 * @param extendCurrent
59 * - when set, do not clear existing column selection
61 * - rather than explicitly set, toggle selection state
63 * - feature type string
64 * @return true if operation affected state
66 boolean markColumnsContainingFeatures(boolean invert,
67 boolean extendCurrent, boolean toggle, String featureType);
70 * sort the alignment or current selection by average score over the given set
74 * list of feature names or null to use currently displayed features
76 void sortAlignmentByFeatureScore(List<String> typ);
79 * sort the alignment or current selection by distribution of the given set of
83 * list of feature names or null to use currently displayed features
85 void sortAlignmentByFeatureDensity(List<String> typ);
88 * add a features file of some kind to the current view
92 * @param relaxedIdMatching
93 * if true, try harder to match up IDs with local sequence data
94 * @return true if parsing resulted in something being imported to the view or
97 public boolean parseFeaturesFile(String file, String protocol,
98 boolean relaxedIdMatching);