当前位置: 首页>>代码示例>>C++>>正文


C++ volume::get_voxel_color方法代码示例

本文整理汇总了C++中volume::get_voxel_color方法的典型用法代码示例。如果您正苦于以下问题:C++ volume::get_voxel_color方法的具体用法?C++ volume::get_voxel_color怎么用?C++ volume::get_voxel_color使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在volume的用法示例。


在下文中一共展示了volume::get_voxel_color方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: assert

vega::data::hexagonal_prismatic_lattice::hexagonal_prismatic_lattice( const volume& v )
{
    VEGA_LOG_FN;

    // Lattice L = {Lx, Ly, Lz};
    static const int Lx[3] = {2, -1, 0};
    static const int Ly[3] = {0, 2, 0};
    static const int Lz[3] = {0, 0, 1};

    myWidth = v.get_width() / 2;
    myHeight = v.get_height() / 2;
    myDepth = v.get_depth();

    assert(myWidth > 0 && myHeight > 0 && myDepth > 0);

    myLatticeCells.reserve(myWidth * myHeight * myDepth);

    for(uint16 k=0;k<myDepth;++k)
    {
        for(uint16 i=0;i<myHeight;++i)
        {
            for(uint16 j=0;j<myWidth;++j)
            {
                prismatic_hexagon_node cell;

                cell.x = j;
                cell.y = i + j/2 + j%2;
                cell.z = k;


                static const int hex_neighbor_offset[NEIGHBOR_COUNT][3] = 
                { 
                               {1, 1, 0}, {0, 1, 0}, {-1, 0, 0}, {-1, -1, 0}, {0, -1, 0}, {1, 0, 0},
                    {0, 0,-1}, 
#if NEIGHBOR_COUNT==20
                               {1, 1,-1}, {0, 1,-1}, {-1, 0,-1}, {-1, -1,-1}, {0, -1,-1}, {1, 0,-1},
#endif
                    {0, 0, 1}, 
#if NEIGHBOR_COUNT==20                               
                               {1, 1, 1}, {0, 1, 1}, {-1, 0, 1}, {-1, -1, 1}, {0, -1, 1}, {1, 0, 1}
#endif
                };

                for(int h=0; h<NEIGHBOR_COUNT; ++h)
                {
                    int hj = cell.x + hex_neighbor_offset[h][0];
                    int hi = cell.y + hex_neighbor_offset[h][1] - hj/2 - hj%2;
                    int hk = cell.z + hex_neighbor_offset[h][2];

                    if( hi >= 0 && hi < myHeight && hj >= 0 && hj < myWidth && hk >=0 && hk < myDepth )
                        cell.hex[h] = hk * myWidth * myHeight + hi * myWidth + hj;
                    else
                        cell.hex[h] = -1;
                }

                // the hexagon pixel offsets from the upper left corner
                // 
                // x 1-2 o
                //  /   \
                // 3-4-5-6
                //  \   /
                // o 7-8 o
                //

                static const int hex_pixel_offset[8][2] = { {1, 0}, {2, 0}, {0, 1}, {1, 1}, {2, 1}, {3, 1}, {1, 2}, {2, 2}};
                
                math::vector3d vertex = cell.get_vertex();
#ifndef USE_COLOR_MAP
                cell.density = 0.f;
#else
                cell.color.RGBA = 0;
#endif

                // compute average density
                int k = 0;
                for(size_t h=0;h<8;++h)
                {
                    math::vector3d pixel;
                    int xx = (int)vertex.x + hex_pixel_offset[h][0];
                    int yy = (int)vertex.y + hex_pixel_offset[h][1];
                    int zz = (int)vertex.z;
                    if( xx >= 0 && yy >= 0 && zz >= 0 && xx < v.get_width() && yy < v.get_height() && zz < v.get_depth() )
                    {
#ifndef USE_COLOR_MAP                        
                        float vx = v.get_voxel(xx, yy, zz);
                        cell.density = (cell.density * k + vx) * (1.f/(++k));
#else
                        r8g8b8a8 vx = v.get_voxel_color(xx, yy, zz);
                        cell.color.A = (cell.color.A * k + vx.A) / ++k;
                        cell.color.R = (cell.color.R * k + vx.R) / ++k;
                        cell.color.G = (cell.color.G * k + vx.G) / ++k;
                        cell.color.B = (cell.color.B * k + vx.B) / ++k;
#endif
                    }
                }

                myLatticeCells.push_back(cell);
            }
        }

//.........这里部分代码省略.........
开发者ID:mihaipopescu,项目名称:VEGA,代码行数:101,代码来源:hexagonal_prismatic_lattice.cpp


注:本文中的volume::get_voxel_color方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。