當前位置: 首頁>>代碼示例>>C#>>正文


C# Channel.findMax方法代碼示例

本文整理匯總了C#中Procedurality.Channel.findMax方法的典型用法代碼示例。如果您正苦於以下問題:C# Channel.findMax方法的具體用法?C# Channel.findMax怎麽用?C# Channel.findMax使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Procedurality.Channel的用法示例。


在下文中一共展示了Channel.findMax方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: CratersAlgo

        public static Channel CratersAlgo(int sizeX, int sizeY, int numCraters, int seed)
        {
            Channel chan = new Channel(sizeX, sizeY);
            Console.WriteLine();
            Random rand = new Random(seed);
            for (int i = 0; i < numCraters; )
            {
                int x = rand.Next(0, sizeX);
                int y = rand.Next(0, sizeY);
                double radius = (rand.NextDouble() * 84.0) - 20;

                // Clamp
                //x=(x<0) ? 0 : ((x>size-1) ? size-1 : x);
                //x=(y<0) ? 0 : ((y>size-1) ? size-1 : y);
                //radius=(radius<20.0) ? 20.0 : ((radius>84.0) ? 84.0 : radius);

                Channel crater = (new Crater(sizeX, sizeY, x, y, radius)).toChannel();
                if (crater.findMax() != 1.0)
                {
                    continue;
                }
                //if(crater.findMin()!=0.0)
                //{
                //	Console.Write("!");
                //	continue;
                //}
                i++;
                drawTextProgressBar(i, numCraters);
                //crater.toLayer().saveAsPNG("../sims/crater_debug.png");
                chan.channelAdd(crater.normalize(-0.01f, 0.01f));
            }
            chan.normalize();
            Console.WriteLine("\nRange [{0},{1}]", chan.findMin(), chan.findMax());
            return chan;
        }
開發者ID:N3X15,項目名稱:Procedurality4NET,代碼行數:35,代碼來源:Main.cs

示例2: HillsAlgo

        public static Channel HillsAlgo(int sizeX, int sizeY, int numHills, int seed)
        {
            Console.WriteLine();
            Channel chan = new Channel(sizeX, sizeY);
            Random rand = new Random(seed);
            for (int i = 0; i < numHills; )
            {
                int x = rand.Next(0, sizeX);
                int y = rand.Next(0, sizeY);

                double radius = ((rand.NextDouble() * 84.0) - 20);
                Channel crater = (new Hill(sizeX, sizeY, x, y, (float)radius)).toChannel();
                if (crater.findMax() != 1.0)
                {
                    continue;
                }
                i++;
                drawTextProgressBar(i, numHills);
                //crater.toLayer().saveAsPNG("../sims/crater_debug.png");
                chan.channelAdd(crater.normalize(0f, 0.01f));
            }
            chan.normalize();
            Console.WriteLine("\nRange [{0},{1}]", chan.findMin(), chan.findMax());
            return chan;
        }
開發者ID:N3X15,項目名稱:Procedurality4NET,代碼行數:25,代碼來源:Main.cs


注:本文中的Procedurality.Channel.findMax方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。