+/*
+ VARNA is a tool for the automated drawing, visualization and annotation of the secondary structure of RNA, designed as a companion software for web servers and databases.
+ Copyright (C) 2008 Kevin Darty, Alain Denise and Yann Ponty.
+ electronic mail : Yann.Ponty@lri.fr
+ paper mail : LRI, bat 490 Université Paris-Sud 91405 Orsay Cedex France
+
+ This file is part of VARNA version 3.1.
+ VARNA version 3.1 is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License
+ as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
+
+ VARNA version 3.1 is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
+ without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
+ See the GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License along with VARNA version 3.1.
+ If not, see http://www.gnu.org/licenses.
+ */
+package fr.orsay.lri.varna.applications;
+
+/*
+ VARNA is a Java library for quick automated drawings RNA secondary structure
+ Copyright (C) 2007 Yann Ponty
+
+ This program is free software:you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation, either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+import java.awt.BorderLayout;
+import java.awt.Color;
+import java.awt.Dimension;
+import java.awt.Font;
+import java.awt.GridLayout;
+
+import javax.swing.JApplet;
+import javax.swing.JLabel;
+import javax.swing.JPanel;
+import javax.swing.JTextField;
+
+import fr.orsay.lri.varna.VARNAPanel;
+import fr.orsay.lri.varna.controlers.ControleurDemoTextField;
+import fr.orsay.lri.varna.exceptions.ExceptionNonEqualLength;
+import fr.orsay.lri.varna.models.rna.RNA;
+
+/**
+ * An RNA 2d Panel demo applet
+ *
+ * @author Yann Ponty & Darty Kévin
+ *
+ */
+
+public class VARNAOnlineDemo extends JApplet {
+
+ /**
+ *
+ */
+ private static final long serialVersionUID = -790155708306987257L;
+
+ private static final String DEFAULT_SEQUENCE = "CAGCACGACACUAGCAGUCAGUGUCAGACUGCAIACAGCACGACACUAGCAGUCAGUGUCAGACUGCAIACAGCACGACACUAGCAGUCAGUGUCAGACUGCAIA";
+
+ private static final String DEFAULT_STRUCTURE = "..(((((...(((((...(((((...(((((.....)))))...))))).....(((((...(((((.....)))))...))))).....)))))...)))))..";
+
+ private VARNAPanel _vp;
+
+ private JPanel _tools = new JPanel();
+ private JPanel _input = new JPanel();
+
+ private JPanel _seqPanel = new JPanel();
+ private JPanel _structPanel = new JPanel();
+ private JLabel _info = new JLabel();
+ private JTextField _struct = new JTextField();
+ private JTextField _seq = new JTextField();
+ private JLabel _structLabel = new JLabel(" Str:");
+ private JLabel _seqLabel = new JLabel(" Seq:");
+
+ private static String errorOpt = "error";
+ private boolean _error;
+
+ private Color _backgroundColor = Color.white;
+
+ private int _algoCode;
+
+ public VARNAOnlineDemo() {
+ super();
+ try {
+ _vp = new VARNAPanel(_seq.getText(), _struct.getText());
+ _vp.setErrorsOn(false);
+ } catch (ExceptionNonEqualLength e) {
+ _vp.errorDialog(e);
+ }
+ RNAPanelDemoInit();
+ }
+
+ private void RNAPanelDemoInit() {
+ int marginTools = 40;
+
+ setBackground(_backgroundColor);
+ _vp.setBackground(_backgroundColor);
+
+ try {
+ _vp.getRNA().setRNA(_seq.getText(), _struct.getText());
+ _vp.setErrorsOn(false);
+ } catch (Exception e1) {
+ _vp.errorDialog(e1);
+ }
+
+ Font textFieldsFont = Font.decode("MonoSpaced-PLAIN-12");
+
+ _seqLabel.setHorizontalTextPosition(JLabel.LEFT);
+ _seqLabel.setPreferredSize(new Dimension(marginTools, 15));
+ _seq.setFont(textFieldsFont);
+ _seq.setText(_vp.getRNA().getSeq());
+
+ _seqPanel.setLayout(new BorderLayout());
+ _seqPanel.add(_seqLabel, BorderLayout.WEST);
+ _seqPanel.add(_seq, BorderLayout.CENTER);
+
+ _structLabel.setPreferredSize(new Dimension(marginTools, 15));
+ _structLabel.setHorizontalTextPosition(JLabel.LEFT);
+ _struct.setFont(textFieldsFont);
+ _struct.setText(_vp.getRNA().getStructDBN());
+ _structPanel.setLayout(new BorderLayout());
+ _structPanel.add(_structLabel, BorderLayout.WEST);
+ _structPanel.add(_struct, BorderLayout.CENTER);
+
+ ControleurDemoTextField controleurTextField = new ControleurDemoTextField(this);
+ _seq.addCaretListener(controleurTextField);
+ _struct.addCaretListener(controleurTextField);
+
+ _input.setLayout(new GridLayout(3, 0));
+ _input.add(_seqPanel);
+ _input.add(_structPanel);
+
+ _tools.setLayout(new BorderLayout());
+ _tools.add(_input, BorderLayout.CENTER);
+ _tools.add(_info, BorderLayout.SOUTH);
+
+ getContentPane().setLayout(new BorderLayout());
+ getContentPane().add(_vp, BorderLayout.CENTER);
+ getContentPane().add(_tools, BorderLayout.SOUTH);
+
+ setVisible(true);
+ _vp.getVARNAUI().UIRadiate();
+ }
+
+ public String[][] getParameterInfo() {
+ String[][] info = {
+ // Parameter Name Kind of Value Description,
+ { "sequenceDBN", "String", "A raw RNA sequence" },
+ { "structureDBN", "String",
+ "An RNA structure in dot bracket notation (DBN)" },
+ { errorOpt, "boolean", "To show errors" }, };
+ return info;
+ }
+
+ public void init() {
+ retrieveParametersValues();
+ _vp.setBackground(_backgroundColor);
+ _error = true;
+ }
+
+ private Color getSafeColor(String col, Color def) {
+ Color result;
+ try {
+ result = Color.decode(col);
+ } catch (Exception e) {
+ try {
+ result = Color.getColor(col, def);
+ } catch (Exception e2) {
+ return def;
+ }
+ }
+ return result;
+ }
+
+ private String getParameterValue(String key, String def) {
+ String tmp;
+ tmp = getParameter(key);
+ if (tmp == null) {
+ return def;
+ } else {
+ return tmp;
+ }
+ }
+
+ private void retrieveParametersValues() {
+ _error = Boolean.parseBoolean(getParameterValue(errorOpt, "false"));
+ _vp.setErrorsOn(_error);
+ _backgroundColor = getSafeColor(getParameterValue("background",
+ _backgroundColor.toString()), _backgroundColor);
+ _vp.setBackground(_backgroundColor);
+ _seq.setText(getParameterValue("sequenceDBN", ""));
+ _struct.setText(getParameterValue("structureDBN", ""));
+ String _algo = getParameterValue("algorithm", "radiate");
+ if (_algo.equals("circular"))
+ _algoCode = RNA.DRAW_MODE_CIRCULAR;
+ else if (_algo.equals("naview"))
+ _algoCode = RNA.DRAW_MODE_NAVIEW;
+ else if (_algo.equals("line"))
+ _algoCode = RNA.DRAW_MODE_LINEAR;
+ else
+ _algoCode = RNA.DRAW_MODE_RADIATE;
+ if (_seq.getText().equals("") && _struct.getText().equals("")) {
+ _seq.setText(DEFAULT_SEQUENCE);
+ _struct.setText(DEFAULT_STRUCTURE);
+ }
+ try {
+ _vp.drawRNA(_seq.getText(), _struct.getText(), _algoCode);
+ } catch (ExceptionNonEqualLength e) {
+ e.printStackTrace();
+ }
+
+ }
+
+ public VARNAPanel get_varnaPanel() {
+ return _vp;
+ }
+
+ public void set_varnaPanel(VARNAPanel surface) {
+ _vp = surface;
+ }
+
+ public JTextField get_struct() {
+ return _struct;
+ }
+
+ public void set_struct(JTextField _struct) {
+ this._struct = _struct;
+ }
+
+ public JTextField get_seq() {
+ return _seq;
+ }
+
+ public void set_seq(JTextField _seq) {
+ this._seq = _seq;
+ }
+
+ public JLabel get_info() {
+ return _info;
+ }
+
+ public void set_info(JLabel _info) {
+ this._info = _info;
+ }
+}