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


C# Piece.AxisMask方法代码示例

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


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

示例1: FindPlace

            public int[] FindPlace(Piece piece)
            {
                //Выполняет поиск места для блока и помечает это место как занятое
                //Возвращает координаты, оговоренные условием

                Dictionary<Axis, int> StartIndices = new Dictionary<Axis, int>(3);
                Dictionary<Axis, int> StopIndices = new Dictionary<Axis, int>(3);

                foreach (Axis axis in Enum.GetValues(typeof(Axis)))
                {
                    if (piece.AxisMask(axis, ".C"))
                    {
                        //Если блок должен прилегать к грани, удаленной от оси,
                        //начальный индекс поиска его места приравнивается к максимальному индексу
                        StartIndices[axis] = cutsLengths[axis].Count - 1;
                    }
                    else
                    {
                        StartIndices[axis] = 0;
                    }

                    if (piece.AxisMask(axis, "C."))
                    {
                        //Если блок должен прилегать к грани, проходящей через ось,
                        //конечный индекс поиска его места приравнивается к минимальному индексу плюс один
                        StopIndices[axis] = 1;
                    }
                    else
                    {
                        StopIndices[axis] = cutsLengths[axis].Count;
                    }
                }

                //Поиск места для блока полным перебором с промежуточными условиями,
                //Отражающими, подходит ли блок для данной плоскости(ряда) блоков
                for (int i = StartIndices[Axis.X]; i < StopIndices[Axis.X]; i++)
                {
                    if (cutsLengths[Axis.X][i] == piece.Measure[Axis.X])
                    {
                        for (int j = StartIndices[Axis.Y]; j < StopIndices[Axis.Y]; j++)
                        {
                            if (cutsLengths[Axis.Y][j] == piece.Measure[Axis.Y])
                            {
                                for (int k = StartIndices[Axis.Z]; k < StopIndices[Axis.Z]; k++)
                                {
                                    if (cutsLengths[Axis.Z][k] == piece.Measure[Axis.Z])
                                    {
                                        if (!Taken[i, j, k])
                                        {
                                            //Если блок подходит по размерам и это место еще не занято,
                                            //Оно занимается и возвращаются координаты, оговоренные условием
                                            Taken[i, j, k] = true;
                                            return new int[] { cutsPositions[Axis.X][i], cutsPositions[Axis.Y][j], cutsPositions[Axis.Z][k] };
                                        }
                                    }
                                }
                            }
                        }
                    }
                }

                //Если подходящий блок не найден, возвращаются нулевые координаты.
                return new int[] { 0, 0, 0 };
            }
开发者ID:Rast1234,项目名称:2013,代码行数:64,代码来源:Ponomarev_Aleksandr.cs


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