feat_pack.hpp
上传用户:yhdzpy8989
上传日期:2007-06-13
资源大小:13604k
文件大小:6k
源码类别:

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: feat_pack.hpp,v $
  4.  * PRODUCTION Revision 1000.0  2004/06/01 19:54:51  gouriano
  5.  * PRODUCTION PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.4
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. #ifndef GUI_OBJUTILS___FEAT_PACK__HPP
  10. #define GUI_OBJUTILS___FEAT_PACK__HPP
  11. /*  $Id: feat_pack.hpp,v 1000.0 2004/06/01 19:54:51 gouriano Exp $
  12.  * ===========================================================================
  13.  *
  14.  *                            PUBLIC DOMAIN NOTICE
  15.  *               National Center for Biotechnology Information
  16.  *
  17.  *  This software/database is a "United States Government Work" under the
  18.  *  terms of the United States Copyright Act.  It was written as part of
  19.  *  the author's official duties as a United States Government employee and
  20.  *  thus cannot be copyrighted.  This software/database is freely available
  21.  *  to the public for use. The National Library of Medicine and the U.S.
  22.  *  Government have not placed any restriction on its use or reproduction.
  23.  *
  24.  *  Although all reasonable efforts have been taken to ensure the accuracy
  25.  *  and reliability of the software and data, the NLM and the U.S.
  26.  *  Government do not and cannot warrant the performance or results that
  27.  *  may be obtained by using this software or data. The NLM and the U.S.
  28.  *  Government disclaim all warranties, express or implied, including
  29.  *  warranties of performance, merchantability or fitness for any particular
  30.  *  purpose.
  31.  *
  32.  *  Please cite the author in any work or product based on this material.
  33.  *
  34.  * ===========================================================================
  35.  *
  36.  * Authors:  Vlad Lebedev
  37.  *
  38.  * File Description:
  39.  *    CLayoutFeatPack -- utility class for having sets of features in graphical layouts. 
  40.  *     (multiple features on a single line). Different feature types is fine.
  41.  */
  42. #include <corelib/ncbiobj.hpp>
  43. #include <gui/objutils/layout.hpp>
  44. #include <gui/objutils/feature.hpp>
  45. #include <objects/seqloc/Seq_interval.hpp>
  46. /** @addtogroup GUI_OBJUTILS
  47.  *
  48.  * @{
  49.  */
  50. BEGIN_NCBI_SCOPE
  51. class NCBI_GUIOBJUTILS_EXPORT CLayoutFeatPack : public CLayoutObject
  52. {
  53. public:
  54.     // ctors
  55.     CLayoutFeatPack(const CLayoutFeat::TFeatList& feats);
  56.     //
  57.     // pure virtual requirements
  58.     //
  59.     // Access the feature's remapped location
  60.     const CLayoutFeat::TFeatList& GetFeatures(void) const;
  61.     CLayoutFeat::TFeatList& SetFeatures(void);
  62.     // access the position of this object.
  63.     const objects::CSeq_loc& GetLocation(void) const;
  64.     // access our core component - we wrap an object of some sort
  65.     const CObject* GetObject(TSeqPos pos) const;
  66.     bool HasObject(const CObject* obj) const;
  67.     // Comparators
  68.     bool LessByPos (const CLayoutObject& obj) const;
  69.     bool LessBySize(const CLayoutObject& obj) const;
  70.     // retrieve the type of this object
  71.     EType GetType() const;
  72.     // Is this layout object selectable in the viewers?
  73.     bool IsSelectable() const;
  74. protected:
  75.     // Location include all features in the pack.
  76.     CRef<objects::CSeq_loc> m_Location;
  77.     
  78.     CLayoutFeat::TFeatList  m_Features;
  79. };
  80. inline
  81. const CLayoutFeat::TFeatList& CLayoutFeatPack::GetFeatures(void) const
  82. {
  83.     return m_Features;
  84. }
  85. inline
  86. CLayoutFeat::TFeatList& CLayoutFeatPack::SetFeatures(void)
  87. {
  88.     return m_Features;
  89. }
  90. inline
  91. bool CLayoutFeatPack::IsSelectable() const
  92. {
  93.     return false;
  94. }
  95. inline
  96. const objects::CSeq_loc& CLayoutFeatPack::GetLocation(void) const
  97. {
  98.     return *m_Location;
  99. }
  100. inline
  101. const CObject* CLayoutFeatPack::GetObject(TSeqPos pos) const
  102. {
  103.     TSeqRange r = GetLocation().GetTotalRange();
  104.     if (pos >= r.GetFrom()  &&  pos <= r.GetTo()) {
  105.         return m_Location.GetPointer();
  106.     }
  107.     return NULL;
  108. }
  109. inline
  110. bool CLayoutFeatPack::HasObject(const CObject* obj) const
  111. {
  112.     return m_Location.GetPointer() == obj;
  113. }
  114. inline
  115. bool CLayoutFeatPack::LessByPos(const CLayoutObject& obj) const
  116. {
  117.     // default: compare by ranges
  118.     TSeqRange r0 = GetLocation().GetTotalRange();
  119.     TSeqRange r1 = obj.GetLocation().GetTotalRange();
  120.     return (r0.GetFrom() < r1.GetFrom());
  121. }
  122. inline
  123. bool CLayoutFeatPack::LessBySize(const CLayoutObject& obj) const
  124. {
  125.     TSeqRange r0 = GetLocation().GetTotalRange();
  126.     TSeqRange r1 = obj.GetLocation().GetTotalRange();
  127.     return (r0.GetLength() < r1.GetLength());
  128. }
  129. inline
  130. CLayoutFeatPack::EType CLayoutFeatPack::GetType() const
  131. {
  132.     return eFeatPack;
  133. }
  134. END_NCBI_SCOPE
  135. /* @} */
  136. /*
  137.  * ===========================================================================
  138.  * $Log: feat_pack.hpp,v $
  139.  * Revision 1000.0  2004/06/01 19:54:51  gouriano
  140.  * PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.4
  141.  *
  142.  * Revision 1.4  2004/05/14 14:24:47  dicuccio
  143.  * Added new pure virtual requirement on CLayoutObject(): GetType(), returns enum
  144.  * defined in CLayoutObject
  145.  *
  146.  * Revision 1.3  2004/05/03 13:34:54  dicuccio
  147.  * FIxed include guards, doxygen groups
  148.  *
  149.  * Revision 1.2  2004/05/03 12:41:35  dicuccio
  150.  * Fixed #includes and export specifiers
  151.  *
  152.  * Revision 1.1  2004/04/30 11:52:53  dicuccio
  153.  * Split out from gui/utils
  154.  *
  155.  * Revision 1.4  2004/04/16 14:27:17  dicuccio
  156.  * Added doxygen module tag
  157.  *
  158.  * Revision 1.3  2004/04/15 12:57:43  lebedev
  159.  * Changed GetObject to return NULL or const pointer based on given position
  160.  *
  161.  * Revision 1.2  2004/03/11 17:19:32  dicuccio
  162.  * Use TSeqRange instead of TRange.  Use gui/gui instead of gui/types
  163.  *
  164.  * Revision 1.1  2004/02/24 14:36:54  lebedev
  165.  * Initial revision
  166.  *
  167.  * ===========================================================================
  168.  */
  169. #endif  // GUI_OBJUTILS___FEAT_PACK__HPP