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

生物技术

开发平台:

C/C++

  1. /*
  2.  * ===========================================================================
  3.  * PRODUCTION $Log: glcolortable.cpp,v $
  4.  * PRODUCTION Revision 1000.1  2004/06/01 20:50:39  gouriano
  5.  * PRODUCTION PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.5
  6.  * PRODUCTION
  7.  * ===========================================================================
  8.  */
  9. /*  $Id: glcolortable.cpp,v 1000.1 2004/06/01 20:50:39 gouriano Exp $
  10.  * ===========================================================================
  11.  *
  12.  *                            PUBLIC DOMAIN NOTICE
  13.  *               National Center for Biotechnology Information
  14.  *
  15.  *  This software/database is a "United States Government Work" under the
  16.  *  terms of the United States Copyright Act.  It was written as part of
  17.  *  the author's official duties as a United States Government employee and
  18.  *  thus cannot be copyrighted.  This software/database is freely available
  19.  *  to the public for use. The National Library of Medicine and the U.S.
  20.  *  Government have not placed any restriction on its use or reproduction.
  21.  *
  22.  *  Although all reasonable efforts have been taken to ensure the accuracy
  23.  *  and reliability of the software and data, the NLM and the U.S.
  24.  *  Government do not and cannot warrant the performance or results that
  25.  *  may be obtained by using this software or data. The NLM and the U.S.
  26.  *  Government disclaim all warranties, express or implied, including
  27.  *  warranties of performance, merchantability or fitness for any particular
  28.  *  purpose.
  29.  *
  30.  *  Please cite the author in any work or product based on this material.
  31.  *
  32.  * ===========================================================================
  33.  *
  34.  * Authors:  Mike DiCuccio
  35.  *
  36.  * File Description:
  37.  *    Incremental and mutually contrastive color table generator.
  38.  */
  39. #include <ncbi_pch.hpp>
  40. #include <gui/opengl/glcolortable.hpp>
  41. BEGIN_NCBI_SCOPE
  42. CGlColorTable::CGlColorTable()
  43.     : m_MaxItems(8),
  44.       m_ColorStep(1.0f),
  45.       m_MinColor(0.0f),
  46.       m_MaxColor(1.0f),
  47.       m_ColorDiff(1.0f)
  48. {
  49. }
  50. CGlColorTable::CGlColorTable(int items, float min_color, float max_color)
  51.     : m_MaxItems(items),
  52.       m_ColorStep(1.0f),
  53.       m_MinColor(min_color),
  54.       m_MaxColor(max_color),
  55.       m_ColorDiff(1.0f)
  56. {
  57.     if (m_MaxColor < m_MinColor) {
  58.         std::swap(m_MaxColor, m_MinColor);
  59.     }
  60.     m_ColorDiff = m_MaxColor - m_MinColor;
  61.     x_CalcColorStep();
  62. }
  63. CGlColor CGlColorTable::GetColor(int i) const
  64. {
  65.     i = abs (i % m_MaxItems);
  66.     int reps = i / 7;
  67.     int idx  = i % 7 + 1;
  68.     CGlColor color;
  69.     float val = (reps + 1) * m_ColorStep + m_MinColor;
  70.     color.SetRed  (val * ((idx & 0x01)     ));
  71.     color.SetGreen(val * ((idx & 0x02) >> 1));
  72.     color.SetBlue (val * ((idx & 0x04) >> 2));
  73.     return color;
  74. }
  75. END_NCBI_SCOPE
  76. /*
  77.  * ===========================================================================
  78.  * $Log: glcolortable.cpp,v $
  79.  * Revision 1000.1  2004/06/01 20:50:39  gouriano
  80.  * PRODUCTION: UPGRADED [GCC34_MSVC7] Dev-tree R1.5
  81.  *
  82.  * Revision 1.5  2004/05/21 22:27:45  gorelenk
  83.  * Added PCH ncbi_pch.hpp
  84.  *
  85.  * Revision 1.4  2003/01/15 21:14:21  dicuccio
  86.  * Fixed bugs in indexing colors - must index only 7 (not 8) colors
  87.  *
  88.  * Revision 1.3  2003/01/13 13:10:11  dicuccio
  89.  * Namespace clean-up.  Retired namespace gui -> converted all to namespace ncbi.
  90.  * Moved all FLUID-generated code into namespace ncbi.
  91.  *
  92.  * Revision 1.2  2003/01/10 15:28:10  dicuccio
  93.  * Changed logic of CGlColorTable - support m_MaxItems colors as a rotating color
  94.  * buffer (i.e., index = index mod m_MaxItems)
  95.  *
  96.  * Revision 1.1  2002/11/22 18:06:28  dicuccio
  97.  * Initial revision.
  98.  *
  99.  * ===========================================================================
  100.  */