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


C++ Landscape::getTile方法代码示例

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


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

示例1: setMap

void GameScene::setMap(const Landscape& lc)
{
    for (int yi = 0; yi < lc.height; yi++)
    {
        for (int xi = 0; xi < lc.width; xi++)
        {
            this->addTile(QPoint(xi, yi), lc.getTile(xi, yi));
        }
    }
}
开发者ID:mdcl23,项目名称:Runners,代码行数:10,代码来源:gamescene.cpp

示例2: make_graph

adjacency_list_t make_graph(Landscape landscape)
{

    int cnt = 0;

    adjacency_list_t adjacency_list(landscape.width*landscape.height);

    for(int i = 0; i < landscape.height; i++)
    {
        for(int j = 0; j < landscape.width; j++)
        {
            if (landscape.getTile(j, i).walkSpeed() == 0) {
                cnt++;
                continue;
            }

            if(i == 0)
            {
                /////////////////////////////////
                for(int i1 = 0; i1 < 2; i1++)
                {

                    for(int j1 = -1; j1 < 2; j1++)
                    {
                        if( (j == 0 && j1 == -1) || (j == landscape.width-1 && j1 == 1) )
                        {
                            continue;
                        }

                        double weight = 1;
                        if (isDiagonal(i1, j1)) {
                            weight = 1./sqrt(2.);
                        }

                        if( !( (i1 == 0) && (j1 == 0) ) )
                        {
                            if (landscape.getTile(j+j1, i+i1).walkSpeed() != 0) {
                                adjacency_list[cnt].push_back(neighbor(cnt + j1 + landscape.width*i1, weight));
                            }
                        }
                    }
                }
                //////////////////////////////////
            }
            else if(i == landscape.height - 1)
            {
                /////////////////////////////////
                for(int i1 = -1; i1 < 1; i1++)
                {
                    for(int j1 = -1; j1 < 2; j1++)
                    {
                        double weight = 1;
                        if (isDiagonal(i1, j1)) {
                            weight = 1./sqrt(2.);
                        }

                        if( (j == 0 && j1 == -1) || (j == landscape.width-1 && j1 == 1) )
                        {
                            continue;
                        }
                        if( !( (i1 == 0) && (j1 == 0) ) )
                        {
                            if ( landscape.getTile(j+j1, i+i1).walkSpeed() != 0 )
                            {
                                adjacency_list[cnt].push_back(neighbor(cnt + j1 + landscape.width*i1, weight));
                            }
                        }
                    }
                }
                //////////////////////////////////
            }
            else
            {
                /////////////////////////////////
                for(int i1 = -1; i1 < 2; i1++)
                {
                    for(int j1 = -1; j1 < 2; j1++)
                    {
                        double weight = 1;
                        if (isDiagonal(i1, j1)) {
                            weight = 1./sqrt(2.);
                        }

                        if( (j == 0 && j1 == -1) || (j == landscape.width-1 && j1 == 1) )
                        {
                            continue;
                        }

                        if( !( (i1 == 0) && (j1 == 0) ) )
                        {
                            if ( landscape.getTile(j+j1, i+i1).walkSpeed() != 0)
                            {
                                adjacency_list[cnt].push_back(neighbor(cnt + j1 + landscape.width*i1, weight));
                            }
                        }
                    }
                }
                //////////////////////////////////

            }
//.........这里部分代码省略.........
开发者ID:mdcl23,项目名称:Runners,代码行数:101,代码来源:dijkstra.cpp


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