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


C++ Floor::MaxX方法代码示例

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


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

示例1:

std::vector<std::vector<bool>> Graph<Room>::generateCorridors(Floor &floor) const
{
	auto arr = floor.toArray();

	int minX = floor.MinX(),
		maxX = floor.MaxX(),
		minY = floor.MinY(),
		maxY = floor.MaxY();

	for (const auto & node : nodes)
	{
		const Room & room = *node.content,
				   & next = *node.neighbors[0]->content;

		const int room_x = room.middle().x,
				  room_y = room.middle().y,

				  next_x = next.middle().x,
				  next_y = next.middle().y,

				  dx = next_x - minX,
				  dy = maxY - next_y;


		int x = room_x - minX,
		    y = maxY - room_y;

		//Horizontal part of corridor
		if (room_x < next_x)
			for (; x < dx; ++x)
				arr[y][x] = true;
		else
			for (; x > dx; --x)
				arr[y][x] = true;

		//Vertical part of corridor
		if (room_y < next_y)
			for (; y > dy; --y)
				arr[y][x] = true;
		else
			for (; y < dy; ++y)
				arr[y][x] = true;
	}

	return arr;
}
开发者ID:Dref360,项目名称:DungeonGenerator,代码行数:46,代码来源:Graph.cpp


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