2 * Jalview - A Sequence Alignment Editor and Viewer (Version 2.6)
3 * Copyright (C) 2010 J Procter, AM Waterhouse, G Barton, M Clamp, S Searle
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 of the License, or (at your option) any later version.
11 * Jalview is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty
13 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR
14 * PURPOSE. See the GNU General Public License for more details.
16 * You should have received a copy of the GNU General Public License along with Jalview. If not, see <http://www.gnu.org/licenses/>.
23 import javax.swing.event.*;
25 import java.awt.event.*;
28 import jalview.api.SequenceStructureBinding;
29 import jalview.bin.Cache;
30 import jalview.datamodel.*;
31 import jalview.gui.ViewSelectionMenu.ViewSetProvider;
32 import jalview.structure.*;
34 import jalview.schemes.*;
35 import fr.orsay.lri.varna.VARNAPanel;
36 import fr.orsay.lri.varna.exceptions.ExceptionFileFormatOrSyntax;
37 import fr.orsay.lri.varna.exceptions.ExceptionNonEqualLength;
38 import fr.orsay.lri.varna.exceptions.ExceptionUnmatchedClosingParentheses;
39 import fr.orsay.lri.varna.interfaces.InterfaceVARNAListener;
40 import fr.orsay.lri.varna.models.VARNAConfig;
41 import fr.orsay.lri.varna.models.rna.RNA;
44 public class AppVarna extends JInternalFrame implements InterfaceVARNAListener// implements Runnable,SequenceStructureBinding, ViewSetProvider
49 VARNAPanel varnaPanel;
54 vab = new AppVarnaBinding();
58 public AppVarna(String seq,String struc,String name){
59 ArrayList<RNA> rnaList = new ArrayList<RNA>();
60 RNA rna1 = new RNA(name);
62 rna1.setRNA(seq,struc);
63 } catch (ExceptionUnmatchedClosingParentheses e2) {
65 } catch (ExceptionFileFormatOrSyntax e3) {
69 rnaList.add(trimRNA(rna1));
71 vab = new AppVarnaBinding(rnaList);
72 //vab = new AppVarnaBinding(seq,struc);
73 //System.out.println("Hallo: "+name);
78 public void initVarna(){
79 //vab.setFinishedInit(false);
80 varnaPanel=vab.get_varnaPanel();
81 setBackground(Color.white);
82 JSplitPane split = new JSplitPane(JSplitPane.HORIZONTAL_SPLIT,true,vab.getListPanel(),varnaPanel);
83 getContentPane().setLayout(new BorderLayout());
84 getContentPane().add(split, BorderLayout.CENTER);
85 //getContentPane().add(vab.getTools(), BorderLayout.NORTH);
86 varnaPanel.addVARNAListener(this);
87 jalview.gui.Desktop.addInternalFrame(this,"VARNA -"+name,getBounds().width, getBounds().height);
92 public RNA trimRNA(RNA rna){
93 RNA rnaTrim = new RNA(rna.getName()+"_trim");
94 String seq=rna.getSeq();
95 String struc=rna.getStructDBN();
98 for(int i=0;i<seq.length();i++){
99 if(seq.substring(i, i+1).compareTo("-")!=0){
100 newSeq=newSeq+seq.substring(i, i+1);
101 newStruc=newStruc+struc.substring(i,i+1);
105 rnaTrim.setRNA(newSeq,newStruc);
106 } catch (ExceptionUnmatchedClosingParentheses e) {
107 // TODO Auto-generated catch block
109 } catch (ExceptionFileFormatOrSyntax e) {
110 // TODO Auto-generated catch block
113 //System.out.println(newSeq+"\t"+newStruc);
117 public void showPanel(boolean show){
118 this.setVisible(show);
121 private boolean _started = false;
129 } catch (OutOfMemoryError oomerror)
131 new OOMWarning("When trying to open the Varna viewer!", oomerror);
132 } catch (Exception ex)
134 Cache.log.error("Couldn't open Varna viewer!", ex);
139 public void onLayoutChanged() {
140 // TODO Auto-generated method stub
145 public void onUINewStructure(VARNAConfig v, RNA r) {
146 //TODO _rnaList.add(v, r,"",true);
147 // TODO Auto-generated method stub
152 public void onWarningEmitted(String s) {
153 // TODO Auto-generated method stub