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 jalview.io.DataSourceType;
25 import java.util.List;
28 * prototype abstract controller for a Jalview alignment view
32 * All operations should return true if the view has changed as a result
35 * The controller holds methods that operate on an alignment view,
36 * modifying its state in some way that may result in side effects
37 * reflected in an associated GUI
40 public interface AlignViewControllerI
43 public boolean makeGroupsFromSelection();
45 public boolean createGroup();
47 public boolean unGroup();
49 public boolean deleteGroups();
51 public void setViewportAndAlignmentPanel(AlignViewportI viewport,
52 AlignmentViewPanel alignPanel);
55 * Mark columns in the current column selection according to positions of
59 * - when set, mark all but columns containing given type
60 * @param extendCurrent
61 * - when set, do not clear existing column selection
63 * - rather than explicitly set, toggle selection state
65 * - feature type string
66 * @return true if operation affected state
68 boolean markColumnsContainingFeatures(boolean invert,
69 boolean extendCurrent, boolean toggle, String featureType);
72 * sort the alignment or current selection by average score over the given set
76 * list of feature names or null to use currently displayed features
78 void sortAlignmentByFeatureScore(List<String> typ);
81 * sort the alignment or current selection by distribution of the given set of
85 * list of feature names or null to use currently displayed features
87 void sortAlignmentByFeatureDensity(List<String> typ);
90 * add a features file of some kind to the current view
94 * @param relaxedIdMatching
95 * if true, try harder to match up IDs with local sequence data
96 * @return true if parsing resulted in something being imported to the view or
99 public boolean parseFeaturesFile(String file, DataSourceType sourceType,
100 boolean relaxedIdMatching);
103 * mark columns containing highlighted regions (e.g. from search, structure
104 * highlight, or a mouse over event in another viewer)
107 * @param extendCurrent
111 boolean markHighlightedColumns(boolean invert, boolean extendCurrent,