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

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: phylo_tree_force.hpp,v $
  4.  * PRODUCTION Revision 1000.0  2004/06/01 19:56:57  gouriano
  5.  * PRODUCTION PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.1
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. #if !defined(AFX_PHYLO_TREE_FORCE_HPP)
  10. #define AFX_PHYLO_TREE_FORCE_HPP
  11. /*  $Id: phylo_tree_force.hpp,v 1000.0 2004/06/01 19:56:57 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:  Vladimir Tereshkov
  37.  *
  38.  * File Description: 
  39.  *      Force tree layout           
  40.  */
  41. //#include <gui/widgets/phylo_tree/phylo_tree_render.hpp>
  42. #include <gui/widgets/phylo_tree/phylo_tree_radial.hpp>
  43. BEGIN_NCBI_SCOPE
  44. class CPhyloForce : public CPhyloRadial
  45. {
  46. private:
  47.     double m_Radius;    
  48.     double m_StartDegree;
  49.     double m_ParentDegree;
  50.     double m_SpringLength;    
  51.     double m_Stiffness;
  52.     double m_ElectricalRepulsion;
  53.     double m_Increment;
  54.     bool   m_Initialized;
  55.     CPhyloTreeDataSource::TNodeHash m_Hash;
  56. protected:
  57.     void  x_Calculate(CPhyloTreeNode * node);
  58.     void  x_DrawTree(CPhyloTreeNode * node); 
  59.     void  x_Normalize(CPhyloTreeNode * node);
  60.     void  x_CountLeafs(CPhyloTreeNode * node,  Int4 & lfCount);
  61.     void  x_Render(CGlPane& pane, CPhyloTreeDataSource& ds);            
  62.     void  x_Layout(CPhyloTreeDataSource& ds);
  63. public:
  64.     CPhyloForce();
  65.     ~CPhyloForce();
  66.     string  GetDescription(void);    
  67. };
  68. END_NCBI_SCOPE
  69. /*
  70.  * ===========================================================================
  71.  * $Log: phylo_tree_force.hpp,v $
  72.  * Revision 1000.0  2004/06/01 19:56:57  gouriano
  73.  * PRODUCTION: IMPORTED [GCC34_MSVC7] Dev-tree R1.1
  74.  *
  75.  * Revision 1.1  2004/05/06 19:40:51  tereshko
  76.  * Initial revision
  77.  *
  78.  * ===========================================================================
  79.  */
  80. #endif // !defined(AFX_PHYLO_TREE_FORCE_HPP)