示例#1
0
        public void TesteSomaValorMag()
        {
            calculador = new CalculadorNumero();
            ValorMag valorMagIgual1    = new ValorMag(50, 2);
            ValorMag valorMagIgual2    = new ValorMag(60, 2);
            ValorMag resultadoMagIgual = calculador.SomaValorMag(valorMagIgual1, valorMagIgual2);

            Assert.IsTrue(resultadoMagIgual.Valor == 11);
            Assert.IsTrue(resultadoMagIgual.Magnitude == 3);
            Assert.IsTrue(resultadoMagIgual.ValorReal == "110");

            ValorMag valorMagPerto1    = new ValorMag(50, 4);
            ValorMag valorMagPerto2    = new ValorMag(50, 3);
            ValorMag resultadoMagPerto = calculador.SomaValorMag(valorMagPerto1, valorMagPerto2);

            Assert.IsTrue(resultadoMagPerto.Valor == 55);
            Assert.IsTrue(resultadoMagPerto.Magnitude == 4);
            Assert.IsTrue(resultadoMagPerto.ValorReal == "5500");

            ValorMag valorMagLonge1    = new ValorMag(50, 3);
            ValorMag valorMagLonge2    = new ValorMag(50, 8);
            ValorMag resultadoMagLonge = calculador.SomaValorMag(valorMagLonge1, valorMagLonge2);

            Assert.IsTrue(resultadoMagLonge.Valor == 50);
            Assert.IsTrue(resultadoMagLonge.Magnitude == 8);
            Assert.IsTrue(resultadoMagLonge.ValorReal == "50000000");
        }
示例#2
0
        public void TesteCalculaPorcentagem()
        {
            calculador = new CalculadorNumero();
            long resultado = calculador.CalculaPorcentagem(20, 133);

            Assert.IsTrue(resultado == 26);
        }
示例#3
0
        public void TesteMultiplicaValorMagPorValorMag()
        {
            calculador = new CalculadorNumero();
            ValorMag valorMag1 = new ValorMag(10, 3);
            ValorMag valorMag2 = new ValorMag(10, 5);
            ValorMag resultado = calculador.MultiplicaValorMag(valorMag1, valorMag2);

            Assert.AreEqual(10, resultado.Valor);
            Assert.AreEqual(7, resultado.Magnitude);
            Assert.AreEqual("1000000", resultado.ValorReal);
        }
示例#4
0
        public void TesteRetornaMenorValorMag()
        {
            calculador = new CalculadorNumero();

            ValorMag num1 = new ValorMag(99, 5);
            ValorMag num2 = new ValorMag(26, 7);

            ValorMag resultado = calculador.RetornaMenorValorMag(num1, num2);

            Assert.AreEqual(num1.ValorReal, resultado.ValorReal);
        }
示例#5
0
        public void TesteMultiplicaValorMagDouble()
        {
            calculador = new CalculadorNumero();

            ValorMag numero        = new ValorMag(82, 6);
            double   multiplicador = 0.12;

            ValorMag resultado = calculador.MultiplicaValorMag(numero, multiplicador);

            Assert.AreEqual(98, resultado.Valor);
            Assert.AreEqual(5, resultado.Magnitude);
        }
示例#6
0
        public void TesteRetornaMenorValorMagDeLista()
        {
            calculador = new CalculadorNumero();
            List <ValorMag> lista = new List <ValorMag>
            {
                new ValorMag(10, 7),
                new ValorMag(15, 5),
                new ValorMag(35, 8),
                new ValorMag(10, 9),
                new ValorMag(99, 2),
                new ValorMag(58, 5),
                new ValorMag(20, 3)
            };

            ValorMag resultado = calculador.RetornaMenorValorMag(lista);

            Assert.AreEqual(99, resultado.Valor);
            Assert.AreEqual(2, resultado.Magnitude);
            Assert.AreEqual("99", resultado.ValorReal);
        }
示例#7
0
        public Resistencia Gerar(Random rnd)
        {
            GeradorInteiro   rng         = new GeradorInteiro();
            GeradorValorMag  genValorMag = new GeradorValorMag();
            GeradorBoolean   genBoolean  = new GeradorBoolean();
            GeradorString    genString   = new GeradorString();
            CalculadorNumero calculador  = new CalculadorNumero();
            Resistencia      resultado   = new Resistencia();
            ValorMag         min         = genValorMag.GerarEntre(new ValorMag(10, 0), new ValorMag(99, 10), rnd);
            ValorMag         max         = calculador.SomaValorMag(min, genValorMag.GerarEntre(new ValorMag(10, 0), new ValorMag(99, 10), rnd));

            char tipo;

            if (genBoolean.GeraComChance(50, rnd))
            {
                tipo = '+';
            }
            else
            {
                tipo = '-';
            }

            resultado.Nome = genString.GerarTamanhoEspecifico(3, 10, rnd);

            if (tipo == '+')
            {
                resultado.Positiva = genValorMag.GerarEntre(min, max, rnd);
                resultado.Negativa = new ValorMag();
            }
            else
            {
                resultado.Positiva = new ValorMag();
                resultado.Negativa = genValorMag.GerarEntre(min, max, rnd);
            }

            return(resultado);
        }
示例#8
0
        public Especie Gerar(Random rnd)
        {
            GeradorOrigem       genOrigem       = new GeradorOrigem();
            GeradorCriatividade genCriatividade = new GeradorCriatividade();
            GeradorDestreza     genDestreza     = new GeradorDestreza();
            GeradorExistencia   genExistencia   = new GeradorExistencia();
            GeradorForca        genForca        = new GeradorForca();
            GeradorIdeia        genIdeia        = new GeradorIdeia();
            GeradorIntelecto    genIntelecto    = new GeradorIntelecto();
            GeradorMateria      genMateria      = new GeradorMateria();
            GeradorModificador  genModificador  = new GeradorModificador();
            GeradorValorMag     genValorMag     = new GeradorValorMag();
            GeradorEnergia      genEnergia      = new GeradorEnergia();
            GeradorPericia      genPericia      = new GeradorPericia();
            GeradorHabilidade   genHabilidade   = new GeradorHabilidade();
            GeradorNatureza     genNatureza     = new GeradorNatureza();
            GeradorResposta     genResposta     = new GeradorResposta();
            GeradorBoolean      genBool         = new GeradorBoolean();
            CalculadorSer       calculadorSer   = new CalculadorSer();
            CalculadorNumero    calculadorNum   = new CalculadorNumero();


            Especie especie = new Especie()
            {
                ReinoTaxo          = rsg.GerarTamanhoEspecifico(2, 8, rnd),
                FiloTaxo           = rsg.GerarTamanhoEspecifico(2, 9, rnd),
                ClasseTaxo         = rsg.GerarTamanhoEspecifico(2, 8, rnd),
                OrdemTaxo          = rsg.GerarTamanhoEspecifico(2, 8, rnd),
                FamiliaTaxo        = rsg.GerarTamanhoEspecifico(2, 8, rnd),
                GeneroTaxo         = rsg.GerarTamanhoEspecifico(2, 8, rnd),
                NomeCientifico     = rsg.GerarTamanhoEspecifico(2, 8, rnd),
                NomePopular        = rsg.GerarTamanhoEspecifico(2, 8, rnd),
                OrigemEspecie      = genOrigem.Gerar(rnd),
                MagnitudeMin       = rng.GerarEntre(0, 5, rnd),
                MagnitudeMax       = rng.GerarEntre(0, 5, rnd),
                ReiMin             = rng.GerarEntre(0, 3, rnd),
                ReiMax             = rng.GerarEntre(1, 10, rnd),
                KiMin              = rng.GerarEntre(0, 50, rnd),
                KiMax              = rng.GerarEntre(1, 1000, rnd),
                NivelMin           = rng.GerarEntre(0, 10000, rnd),
                NivelMax           = rng.GerarEntre(1, 100000, rnd),
                TempoMax           = rng.GerarEntre(1, 10000, rnd),
                Energias           = genEnergia.GerarLista(rng.GerarEntre(1, 5, rnd), rnd),
                ForcaMin           = genForca.Gerar(rnd),
                ForcaMax           = genForca.Gerar(rnd),
                MateriaMin         = genMateria.Gerar(rnd),
                MateriaMax         = genMateria.Gerar(rnd),
                DestrezaMin        = genDestreza.Gerar(rnd),
                DestrezaMax        = genDestreza.Gerar(rnd),
                IntelectoMin       = genIntelecto.Gerar(rnd),
                IntelectoMax       = genIntelecto.Gerar(rnd),
                CriatividadeMin    = genCriatividade.Gerar(rnd),
                CriatividadeMax    = genCriatividade.Gerar(rnd),
                ExistenciaMin      = genExistencia.Gerar(rnd),
                ExistenciaMax      = genExistencia.Gerar(rnd),
                IdeiaMin           = genIdeia.Gerar(rnd),
                IdeiaMax           = genIdeia.Gerar(rnd),
                PericiasEspecie    = genPericia.GerarLista(rng.GerarEntre(1, 10, rnd), rnd),
                HabilidadesEspecie = genHabilidade.GerarLista(rng.GerarEntre(1, 3, rnd), rnd),
                OrigemPoder        = rsg.GerarTamanhoEspecifico(4, 10, rnd),
                VirtudesEspecie    = genModificador.GerarListaComOrigem("Virtudes", 0, rng.GerarEntre(1, 10, rnd), rnd, '+'),
                DefeitosEspecie    = genModificador.GerarListaComOrigem("Defeitos", 0, rng.GerarEntre(1, 10, rnd), rnd, '-'),
                ForcaVontadeMin    = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd),
                ForcaVontadeMax    = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd),
                IraMin             = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd),
                IraMax             = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd),
                PoderMaximoMin     = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd),
                PoderMaximoMax     = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd),
                FatorProgressao    = rng.GerarEntre(1, 10, rnd),
                CansacoMax         = rng.GerarEntre(0, 1000, rnd),
                FeMin              = rng.GerarEntre(0, 1000, rnd),
                FeMax              = rng.GerarEntre(0, 1000, rnd),
                KarmaMin           = rng.GerarEntre(0, 1000, rnd),
                KarmaMax           = rng.GerarEntre(0, 1000, rnd),
                MaxItensEquipados  = rng.GerarEntre(1, 10, rnd),
                AcaoMin            = rng.GerarEntre(1, 1000, rnd),
                AcaoMax            = rng.GerarEntre(0, 1000, rnd),
                AlturaMin          = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 5), rnd),
                AlturaMax          = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 5), rnd),
                Id = rng.GerarEntre(1, 1000, rnd),
                MaxArmasEquipadas = rng.GerarEntre(1, 10, rnd),
                //TODO: Subclassificacoes = GeraSubclassificacoes(),
                TurnoMin      = rng.GerarEntre(1, 1000, rnd),
                TurnoMax      = rng.GerarEntre(1, 1000, rnd),
                MaturidadeMin = 0,
                MaturidadeMax = 0,
                DestriaMax    = rng.GerarEntre(1, 10, rnd),
                DestriaMin    = 1,
                Porcentagem   = 0,
                TrabalhoMin   = rng.GerarEntre(0, 1000, rnd),
                Densidade     = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd),
                LarguraMin    = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 5), rnd),
                LarguraMax    = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 5), rnd),
                Especial      = rng.GerarEntre(1, 70, rnd),
                Natureza      = genNatureza.Gerar(rnd),
                RespostaMin   = genResposta.Gerar(rnd),
            };

            especie.MagnitudeMax    = especie.MagnitudeMin + especie.MagnitudeMax;
            especie.ReiMax          = especie.ReiMin + especie.ReiMax;
            especie.KiMax           = especie.KiMin + especie.KiMax;
            especie.ForcaVontadeMax = calculadorNum.SomaValorMag(especie.ForcaVontadeMin, especie.ForcaVontadeMax);
            especie.IraMax          = calculadorNum.SomaValorMag(especie.IraMin, especie.IraMax);
            especie.PoderMaximoMax  = calculadorNum.SomaValorMag(especie.PoderMaximoMin, especie.PoderMaximoMax);
            especie.FeMax           = especie.FeMin + especie.FeMax;
            especie.KarmaMax        = especie.KarmaMin + especie.KarmaMax;
            especie.AcaoMax         = especie.AcaoMin + especie.AcaoMax;
            especie.AlturaMax       = calculadorNum.SomaValorMag(especie.AlturaMin, especie.AlturaMax);
            especie.TurnoMax        = especie.TurnoMin + especie.TurnoMax;
            especie.MaturidadeMin   = (int)calculadorNum.CalculaPorcentagem(rng.GerarEntre(1, 30, rnd), especie.TempoMax);
            especie.MaturidadeMax   = especie.MaturidadeMin + (int)calculadorNum.CalculaPorcentagem(rng.GerarEntre(60, 99, rnd), especie.TempoMax);
            especie.TrabalhoMax     = especie.TrabalhoMin + rng.GerarEntre(0, 1000, rnd);
            especie.LarguraMax      = calculadorNum.SomaValorMag(especie.LarguraMin, especie.LarguraMax);

            especie.DeslocamentosMedios = new List <Deslocamento>()
            {
            };

            if (genBool.GeraComChance(90, rnd))
            {
                especie.DeslocamentosMedios.Add(new Deslocamento()
                {
                    Tipo  = "Solo",
                    Valor = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd)
                });
            }

            if (genBool.GeraComChance(70, rnd))
            {
                especie.DeslocamentosMedios.Add(new Deslocamento()
                {
                    Tipo  = "Mar",
                    Valor = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd)
                });
            }

            if (genBool.GeraComChance(40, rnd))
            {
                especie.DeslocamentosMedios.Add(new Deslocamento()
                {
                    Tipo  = "Ar",
                    Valor = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd)
                });
            }

            if (genBool.GeraComChance(10, rnd))
            {
                Deslocamento desMar = new Deslocamento()
                {
                    Tipo  = "Espaço",
                    Valor = genValorMag.GerarEntre(new ValorMag(1, 0), new ValorMag(99, 15), rnd)
                };
            }

            especie.RespostaMax = new Resposta()
            {
                Bravura     = especie.RespostaMin.Bravura + rng.GerarEntre(1, 1000, rnd),
                Coragem     = especie.RespostaMin.Coragem + rng.GerarEntre(1, 1000, rnd),
                Desespero   = especie.RespostaMin.Desespero + rng.GerarEntre(1, 1000, rnd),
                Heroismo    = especie.RespostaMin.Heroismo + rng.GerarEntre(1, 1000, rnd),
                Indiferenca = especie.RespostaMin.Indiferenca + rng.GerarEntre(1, 1000, rnd),
                Medo        = especie.RespostaMin.Medo + rng.GerarEntre(1, 1000, rnd),
                Panico      = especie.RespostaMin.Panico + rng.GerarEntre(1, 1000, rnd)
            };
            return(especie);
        }