File: MyChild.h

package info (click to toggle)
gentle 1.9%2Bcvs20100605%2Bdfsg1-5
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 12,224 kB
  • ctags: 6,214
  • sloc: cpp: 41,569; ansic: 3,978; sh: 1,420; makefile: 243
file content (132 lines) | stat: -rwxr-xr-x 7,787 bytes parent folder | download | duplicates (7)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
/** \file
	\brief Contains the MyChild class, as well as the MySplitter helper class
*/
#ifndef _MYCHILD_H_
#define _MYCHILD_H_

#include "main.h"
#include "ChildBase.h"
#include <wx/clipbrd.h>
#include <wx/splitter.h>

class PlasmidCanvas ;
class SequenceCanvas ;
class TVector ;
class TVectorTree ;
class TMainTree ;
class TMainTreeItem ;
class MyChild ;
class TURLtext ;
class TRestrictionEditor ;
class TVirtualGel ;

/**	\brief Specialized class based on wxSplitterWindow; used in MyChild to separate the different parts of the module
*/
class MySplitter : public wxSplitterWindow
    {
    public :
    MySplitter ( wxWindow *win , int id , MyChild *child ) ; ///< Constructor
    void OnChanged ( wxSplitterEvent &ev ) ; ///< Drag event handler
    MyChild *c ; ///< The calling MyChild

    DECLARE_EVENT_TABLE()
    } ;

/** \brief The very, very, *very* important module to handle DNA in all its beauty!
*/
class MyChild: public ChildBase
{
public:
    MyChild(wxWindow *parent, const wxString& title, const wxPoint& pos, const wxSize& size, const long style); ///< Constructor
    ~MyChild(); ///< Destructor

    virtual void OnAA_none(wxCommandEvent& event); ///< "Display no amino acids" event handler
    virtual void OnAA_known(wxCommandEvent& event); ///< "Display only known amino acids" event handler
    virtual void OnAA_all(wxCommandEvent& event); ///< "Display amino acids for all reading frames" event handler
    virtual void OnAA_three(wxCommandEvent& event); ///< "Display three-letter amino acids" event handler
    virtual void OnAA_one(wxCommandEvent& event); ///< "Display one-letter amino acids" event handler
    virtual void OnAA_three_1(wxCommandEvent& event); ///< "Display amino acids, reading frame 1" event handler
    virtual void OnAA_three_2(wxCommandEvent& event); ///< "Display amino acids, reading frame 2" event handler
    virtual void OnAA_three_3(wxCommandEvent& event); ///< "Display amino acids, reading frame 3" event handler
    virtual void OnAA_three_M1(wxCommandEvent& event); ///< "Display amino acids, reading frame -1" event handler
    virtual void OnAA_three_M2(wxCommandEvent& event); ///< "Display amino acids, reading frame -2" event handler
    virtual void OnAA_three_M3(wxCommandEvent& event); ///< "Display amino acids, reading frame -3" event handler
    virtual void OnAA_setit(int mode); ///< Sets the amino acid display mode (called by the OnAA_ event handlers)

    virtual void OnActivate(wxActivateEvent& event); ///< Activation event handler
    virtual void Undo(wxCommandEvent& event); ///< Undo event handler
    virtual void Redo(wxCommandEvent& event); ///< Redo event handler (not implemented)
    virtual void updateUndoMenu () ; ///< Updates the undo menu item
    
    virtual void OnMarkAll(wxCommandEvent& event); ///< "Mark all" (Ctrl-A) event handler
    virtual void OnTransformSequence(wxCommandEvent& event); ///< "Transform sequence" event handler
    virtual void OnExtractAA(wxCommandEvent& event); ///< "Extract amino acids" event handler
    virtual void OnFind(wxCommandEvent& event); ///< "Find" event handler
    virtual void OnFileSave(wxCommandEvent& WXUNUSED(event) ) ; ///< "Save"/"Store" event handler
    virtual void OnQuit(wxCommandEvent& event); ///< "Quit" event handler
    virtual void OnCut(wxCommandEvent& event); ///< Cut event handler
    virtual void OnCopy(wxCommandEvent& event); ///< Copy event handler
    virtual void OnPaste(wxCommandEvent& event); ///< Paste event handler
    virtual void OnViewMode(wxCommandEvent& event); ///< Switch to fullscreen plasmid map event handler
    virtual void OnEditMode(wxCommandEvent& event); ///< Sqitch to edit mode event handler
    virtual void OnCircularLinear(wxCommandEvent& event); ///< Toggle circular/linear event handler
//    virtual void OnLigation(wxCommandEvent& event); ///< Ligation event handler
    virtual void OnCopyToNew(wxCommandEvent& event); ///< "Copy as new sequence" event handler
    virtual void OnAsNewFeature(wxCommandEvent& event); ///< "Selection as new feature" event handler
    virtual void OnPrintImage(wxCommandEvent& event); ///< Print image event handler
    virtual void OnPrintRestrictionList(wxCommandEvent& event); ///< Print restriction list event handler
    virtual void OnRestriction(wxCommandEvent& event); ///< Restriction event handler
    virtual void OnHelp(wxCommandEvent& event); ///< Help event handler
    virtual void OnORFs(wxCommandEvent& event); ///< "Show/hide open reading frames" event handler
    virtual void OnEditORFs(wxCommandEvent& event); ///< Change open reading frame settings event handler
    virtual void OnSeqPrint(wxCommandEvent& event); ///< Print sequence event handler
    virtual void OnPrintReport(wxCommandEvent& event); ///< "Print report" event handler
    virtual void OnToggleFeatures(wxCommandEvent& event); ///< Feature display on/off event handler
    virtual void OnToggleRestriction(wxCommandEvent& event); ///< "Restriction enzymes in sequence on/off" event handler
    virtual void OnToggleIDNA(wxCommandEvent& event); ///< Inverse DNA display event handler
    virtual void OnRunPCR(wxCommandEvent& event); ///< PCR event handler
    virtual void OnZoom ( wxCommandEvent &ev ) ; ///< Zoom event handler
    virtual void OnUpdateRefresh(wxUpdateUIEvent& event); ///< Update/Refresh event handler
    virtual void OnSequencingPrimer(wxCommandEvent& WXUNUSED(event)); ///< "Find sequencing primers" event handler
    virtual void OnRemoveSequencingPrimers(wxCommandEvent& WXUNUSED(event)); ///< "Remove sequencing primers" event handler
    virtual void OnAutoAnnotate(wxCommandEvent& WXUNUSED(event)); ///< Automatic annotation event handler
    virtual void OnSpeak(wxCommandEvent& WXUNUSED(event)); ///< Speak sequence event handler
    virtual void OnSiRNA(wxCommandEvent& WXUNUSED(event)); ///< siRNA event handler
    virtual void OnFontsize(wxCommandEvent& event); ///< Fontsize event handler
    virtual void OnDummy(wxCommandEvent& WXUNUSED(event)){}; ///< Dummy event handler (to catch weird messages)

    virtual void initme () ; ///< Initializes the module
    virtual void initPanels () ; ///< Initializes the panels
    virtual wxString getName () ; ///< Returns the module name
    virtual void EnforceRefesh () ; ///< Force display refresh
    virtual void updateSequenceCanvas ( bool remember = false ) ; ///< Refresh the sequence display
    virtual wxString doExtractAA ( bool coding = true ) ; ///< Extract amino acid sequence from DNA
    virtual bool runRestriction ( wxString s ) ; ///< Run the restriction
    virtual void addFragmentsToGel ( wxString title , wxArrayInt &cuts , TVirtualGel *gel , TRestrictionEditor &ed , bool partial ) ; ///< Add restriction fragments to gel
    virtual MyChild *doTransformSequence ( bool inNewVector , bool complement , bool invers ) ; ///< Transform the sequence
    virtual bool HasUndoData () ;
    
    TVectorTree *treeBox ; ///< Pointer to the sequence properties tree structure
    TURLtext *propBox ; ///< Pointer to the properties text box
    PlasmidCanvas *cPlasmid; ///< Pointer to the plasmid canvas
    MySplitter *sw , *swu , *swl ;

    bool showORFs , viewMode ;
    int sp1 , sp2 , aa_offset , ly ;
    int aa_state , aa_disp , orf_mode ;
    
    protected :
    virtual void updateToolbar () ; ///< Set the toolbar of this module
    virtual void initToolbar () ; ///< Setup the toolbar for this module
    virtual void initMenus () ; ///< Initialize the menus
    
    void add_siRNA ( int item ) ;
    int add_siRNA_sub ( wxString s , int pos ) ;

    wxChoice *fontsize ;
    
    DECLARE_EVENT_TABLE()
};

#endif