Evolution Maker

Você não esta conectado. Para poder ver links e imagens registre-se ou logue-se

Participe do fórum, é rápido e fácil

Evolution Maker

Você não esta conectado. Para poder ver links e imagens registre-se ou logue-se

Evolution Maker

Gostaria de reagir a esta mensagem? Crie uma conta em poucos cliques ou inicie sessão para continuar.


3 participantes

    adicionar ambiente

    avatar
    Wiat_X
    Admin Oficial


    Mensagens : 2
    Pontos : 6
    Data de inscrição : 01/06/2012

    adicionar ambiente Empty adicionar ambiente

    Mensagem  Wiat_X Qua Jun 20, 2012 10:01 am

    0 - O que você irá precisar

    Este tópico zero, é somente para deixar aqui o que você precisar baixar para que tudo funcione.

    - UDK - [Tens de ter uma conta e sessão iniciada para poderes visualizar este link]

    - Alguns scripts - [Tens de ter uma conta e sessão iniciada para poderes visualizar este link]

    Antes que você pergunte o porque dos scripts, já vou respondendo. Como a intenção do tutorial é apenas para mostrar como criar o jogo e não como programá-lo, então vou usar estes scripts prontos apenas para nosso exemplo.

    Faça o download de tudo e mãos a obra.



    1 - Estrutura de pastas

    Após instalar o UDK você terá a seguinte estrutura de pasta na raiz:



    A pasta BINARIES contém os executáveis do jogo, do UnrealFrontEnd e alguns outros programas do UDK. Somente em alguns poucos casos esta pasta é modificada, portanto não precisa se preocupar com ela.

    Na pasta DEVELOPMENT é onde ficam todos os arquivos que contém seu código-fonte, ou seja, as classes que você cria. É a pasta mais importante para quem quer mudar totalmente o tipo de jogo, mudar câmeras, armas e por ai vai. Mas claro, mudar na programação, e não visualmente. O código fonte tem a extenção .UC e os arquivos quando compilados ficam com a extenção .U.

    A pasta ENGINE é responsável por guardar toda a engine e não devemos mecher nesta pasta, deixe ela ali queitinha, pois é ali que estão os arquivos necessários para a engine funcionar.

    Já a pasta UTGAME, é na maioria das vezes a pasta mais usada, pois é aqui que fica todo o conteúdo do seu jogo, como inis, texturas, materiais, modelos, localização e por ai vai.

    Dentro da pasta UTGame temos então muitas pastas importantes também, vou apresentar a estrutura de dentro dela e a descrição de cada uma:



    A pasta CONFIG contém os arquivos INIs, que são os arquivos de suma importância para seu jogo.

    A pasta CONTENT guarda arquivos como materiais, texturas, levels(mapas/fases), sons, e tudo o que seu jogo terá neste sentido. Uma coisa importante, é que você não deve usar o conteúdo do Unreal Tournament 3 que já vem numa versão demo com o UDK apara fins comerciais, pois são arquivos que pertencem a Epic Games, eles apenas deixam ai de teste para você ter por onde testar e começar.

    A pasta LOCALIZATION contém os textos de acordo com a linguagem, sejam os textos dos menus, os dos diálogos ou qualquer outro que seu jogo possua.

    A pasta MOVIES guarda os vídeos de introdução, vídeos de loading do jogo, e por ai vai.

    A pasta SCRIPT mantém seus arquivos fontes compilados, que são os arquivos .U.

    Já a pasta SPLASH é onde ficam as imagens de splash do seu jogo. Aquelas que aparecem na entrada e tudo mais.

    Existem outras pastas ainda, mas não são importantes no momento, então não vou falar sobre elas.

    Uma dica importante, vamos supor que sua equipe vá desenvolver um jogo usando o UDK, então você precisará de algum controlador de versão para juntar as modificações e tudo mais. Como exemplo, falarei sobre o SVN. Usando o SVN em seu projeto, as únicas pastas que você precisará adicionar no SVN serão as pastas DEVELOPMENT e UTGAME.

    Outra coisa, vamos criar uma pasta com conteúdo somente para nosso jogo, sem misturas com as que já existem. Para isso crie dentro da pasta UTGAME\Content as seguintes pastas:

    UTGame\Content\ExampleGame\Levels
    UTGame\Content\ExampleGame\UPK
    A pasta ExampleGame\Levels conterá nossos mapas/fases.

    A pasta Example\UPK conterá todos os outros arquivos(texturas/materiais/modelos e por ai vai).

    Então teremos nossa estrutura de conteúdo(content) assim:





    Outra dica: Embora eu aqui coloque as vezes o nome todo em maiúsculo, você deve colocar sempre seguindo o padrão, pois a engine as vezes da uns bugs com isso, e não coloque espaço no nome das pastas. Com o tempo você vai pegando os macetes e limitações neste sentido.

    Uma recomendação do pessoal do The Ball é que você não coloque muitas pastas separando os conteúdos como é o UT3 (Unreal Tournament 3), pois não há necessidade, o game deles tem 1.5GB com apenas 20 arquivos .UPK.

    Vamos continuar.



    2 - UnrealScript

    Bom, vamos agora até a pasta DEVELOPMENT\SRC, pois lá é onde ficam os arquivos fonte.

    Descompacte o arquivo .ZIP que você baixou no link que deixei no começo do tutorial dentro desta pasta(DEVELOPMENT\SRC). Ficando a estrutura assim:



    Lembrando que estou criando a pasta com nome de MyGame apenas por seguir o exemplo do pessoal do The Ball, mas você pode colocar qualquer nome, ou no caso o nome do seu jogo. Se você está fazendo um jogo chamado Zombie Tower Defense, crie a pasta ZombieTowerDefense no lugar de MyGame(lembre-se: sem espaços e/ou acentos).

    Por direito, você pode usar todo o código do jogo Unreal Tournament 3, mas não o conteúdo(mesh, textura, material, som), então não fique criando classes para controle do seu personagem do zero, sempre herde de alguém, por exemplo, se você quer criar uma classe para controle do personagem, faça assim:

    class MyPawn extends UTPawn;

    Sempre use a herança, pois irá facilitar sua vida.

    Uma dica importante, se você reparar, em alguns scripts você tem uma sessão assim, DefaultProperties, isso quer dizer que o que estiver ali dentro, será visível pelo editor com o valor padrão que está definido ali. Lembrando que se na classe que você herdou já tiver algum valor padrão definido para alguma propriedade, a sua classe criada irá herdar automaticamente, então só coloque ali o que for necessário e diferente da classe que você herdar.

    Bom, agora precisamos adicionar nossa pasta criada à lista de diretórios para compilação. Para isso abra o arquivo:

    UTGame\Config\DefaultEngine.ini

    Procure pela sessão:

    [UnrealEd.EditorEngine]

    E adicione a seguinte linha depois da última desta sessão:

    +EditPackages=UTGame
    +EditPackages=UTEditor
    +EditPackages=UTGameContent
    +EditPackages=MyGame <- adicione esta linha

    A ordem correta das pastas é muito importante, pois diz ao compilador quais pastas devem ser carregadas e compiladas primeiro.

    Esta linha que adicionamos diz que o arquivo MyGame deve ser carregado sempre que o editor for aberto.

    Antes de salvar as alterações desmarque o atributo somente leitura do arquivo, e ai sim você pode salvar as alterações.

    Bom, com este arquivo alterado, podemos apagar o arquivo UTEngine.ini desta mesma pasta, pois quando o editor for aberto, ele criará automaticamente um outro arquivo UTEngine.ini baseado no arquivo que alteramos DefaultEngine.ini.

    Após apagar este arquivo, vamos compilar nosso código para ver se está tudo OK.

    Para isso, vá na pasta BINARIES(fica na raiz da instalação) e abra o arquivo UnrealFrontEnd.exe.

    Este programa é responsável por muitas coisas no processo de desenvolvimento, e uma delas é compilar nosso código. Após abrir o programa, vá na barra lá em cima, clique na setinha ao lado do botão MAKE e depois em FULL RECOMPILE.





    Bom, se tudo ocorrer bem, você verá na lista ao lado falando sobre MyGame e na pasta UTGame\Script você terá o arquivo MyGame.u quando a compilação acabar.

    Ai você pergunta, mas porque MyGame.u? Eu te explico, a razão para ele chamar este arquivo assim é porque ele compila todo o seu código em um único arquivo, que terá o nome do seu projeto, no nosso caso ele chamou de MyGame.u pois o nome do nosso projeto em Development\Src é MyGame.

    Continuando.



    3 - Arquivos INI

    Aqui vamos dizer para a engine qual o gametype que ele usará e qual o pawn que ele usará como padrão. Que no nosso caso será as classes que criamos.

    Abra o arquivo:

    UTGame\Config\DefaultGame.ini

    Vá ate a sessão:

    [Engine.GameInfo]

    Faça as seguintes alterações:

    Troque "DefaultGame=UTGame.UTDeathmatch" para "DefaultGame=MyGame.MyGameInfo".
    Troque "PlayerControllerClassName=UTGame.UTPlayerController" para "PlayerControllerClassName=MyGame.MyPlayerController"
    Novamente desmarque o atributo somente leitura do arquivo e salve as alterações. Entenderam o que fizemos? Apenas estamos dizendo à engine que o tipo de jogo padrão será baseado na nossa classe(gametype) e que a classe que representa o player será a nossa(pawn).



    4 - Mapa básico

    Bom, neste tópico nem vou me demorar, pois já fiz um outro tutorial sobre isso bem detalhado para você começar.

    Link: [Tens de ter uma conta e sessão iniciada para poderes visualizar este link]

    Crie um mapa básico qualquer e vou dizer aqui algumas opções interessantes que precisamos alterar.

    Mas antes, vamos criar um atalho pra o editor para que ele gere um log.

    Vá até a pasta Binaries\Win32 e crie um atalho para o arquivo UDKLift.exe e adicione a seguinte linha de comando nas propriedades do atalho:

    editor -log

    Coloque isto logo após o texto UDKLift.exe, assim:





    Bom, vou criar um mapa junto com vocês só para ter-mos um mapa igual para o exemplo. Preste atenção nos detalhes, pois são bem úteis e interessantes.

    Abra o editor pelo atalho que criamos. Após aberto vamos criar nosso mapa bem básico.

    Clique com o botão direito sob o cubo na barra à esquerda e coloque os atributos como estão na imagem abaixo.





    Uma observação: O atributo Hollow quer dizer OCO, ou seja, vamos criar um cubo OCO onde podemos colocar dentro dele o que quiser-mos, no caso, nosso mapa será dentro do cubo.

    Após criar o cubo, clique na ferramenta CSG ADD só para nosso cubo ficar com uma textura padrão para nos orientar-mos no editor.





    Bom, agora aproxime a camera de modo que você fique dentro do editor.

    Adicione uma luz e posicione no centro (botão direito do mouse -> Add Actor -> Add Light).

    Adicione também um playerstart (botão direito do mouse -> Add Actor -> Add PlayerStart).





    Feito isso, salve seu mapa/fase. Preste atenção no nome, pois em nosso arquivo fonte MyGameInfo.uc tem definido o prefixo do nome dos mapas/fases, que é MG. Então salve o mapa/fase com o nome MG-[Alguma coisa], no meu caso coloquei MG-ExampleGameLevel.

    Ah e salve o arquivo na nossa pasta de mapas/fases, que é:

    UTGame\Content\ExampleGame\Levels\

    O prefixo é importante, pois é através dele que a engine sabe qual a classe do tipo de jogo(gametype) deve ser usada. Como o prefixo é MG então ele sabe que a classe a ser chamada é MyGameInfo.

    Agora faça um Build ALL pelo editor.





    Vá no menu lá em cima chamado View -> World Properties, e expanda o item WorldInfo. Mude o item Game Type For PIE para usar a nossa classe MyGameInfo.





    Calma, Calma, Calma! Me explique isso.

    Bom, primeiro, PIE significa: Play in Editor e alterando este item, estamos dizendo que quando agente for testar o mapa pelo editor, nós queremos que ele chame a nossa classe MyGameInfo e faça o que tem que fazer com o que programamos nela. É um atalho para você programar e testar as alterações no mapa rapidamente.

    Agora, clique com o botão direito no nosso mapa/fase e use o famoso Play From Here, mas cuidado para você não clicar lá fora do cubo, faça isso dentro do cubo.

    Testou? Bem bacana né? Você reparou que a camera ficou estilo terceira pessoa? Pois é, você pode alterar e ver o código através da classe MyPlayerController.

    Um simples comando faz toda a mágica: SetBehindView(true);

    Uma dica para quando você estiver jogando em modo primeira pessoa e quiser mudar para terceira pessoa com a camera original, é só você apertar a tecla [TAB].

    Vamos continuar que a hora já está avançada.



    5 - Menu


    O menu também é algo simples. E nada mais é do que um outro level(mapa/fase) feito que é carregado na inicialização. Bom, vamos lá, primeiro faça uma cópia do arquivo do mapa/fase que você acabou de criar. No meu caso vou criar uma cópia do arquivo MG-ExampleGameLevel.udk, e se você seguiu o mesmo exemplo, faça isso também, gere uma cópia e renomeie para ExampleGameFrontEnd.udk:



    Feito isso, abra o arquivo que criamos como cópia(ExampleGameFrontEnd.udk).

    Vamos criar uma UI Scene. Para isso, vamos criar um pacote(package). Entre no Content Browser(menu View -> Browser Windows -> Content Browser).

    Clique no botão NEW lá embaixo:





    Na janela que aparecer coloque as informações como na imagem abaixo, preenchendo o Package, Name, Factory. Selecione a Factory corretamente(UI SCene), senão não adianta.





    De um duplo-clique na UI Scene que criamos, que já deve vir selecionada após clicar em OK.





    Preste atenção que esta parte é um pouco chata.

    Quando a janela abrir, clique com o botão direito em qualquer área quadriculada e vá no menu: Place Widget -> Button [Standard]





    Coloque qualquer nome quando aparecer a janela pedindo o nome do botão.

    Por padrão o botão já vem cobrindo toda a área verde, mas se não vier, redimensione o botão para ficar do tamanho da área representada pela linha verde. Essa linha verde representa toda a tela.

    Agora clique com o botão direito em cima do botão e depois clique no menu UnrealKismest Editor:





    Essa ferramenta é bem útil pois faz a ligação com o UnrealScript para nós.

    Na janela do Kismet que abriu, clique lá embaixo no item Global Sequence, se já não estiver.





    Agora clique com o botão direito do mouse na parte cinza, e clique no menu: New Event -> UI -> OnClick.





    Depois, clique novamente com o botão direito na parte cinza e clique no menu: New Action -> Level -> Activate Level Event:





    Após adicionar os itens, ligue o evento OUT do OnClick com o IN do Activate Level Event. Depois selecione o evento Activate Level Event e mude o atributo Event Name para OpenYourLevel. Como mostro na imagem abaixo:





    Uma dica importante: O nome do evento precisa ser único, ou seja, não pode se repetir.

    Mas o que eu fiz? não entendi nada!

    Vamos lá. Revisando. Criamos um novo cenário "UI Scene", colocamos um botão na tela e criamos o evento OnClick que chamará o evento de nome OpenYourLevel do mapa/fase.

    Isso poderia ser feito via script? Sim, mas daria mais trabalho.



    Agora feche esta janela e clique numa parte vazia do UI Scene e ao lado direito, nas propriedades procure pela flag Pause Game While Active e desmarque.

    Isso fará com que o jogo continue ativo, rodando, enquanto esta tela é exibida.





    Agora algo muito importante, você precisa sempre salvar seu trabalho, pois senão vai ser tudo perdido. Para salvar faça assim, feche a janela do UI Scene e voltaremos ao content browser, então clique com o botão direito do mouse no nosso basicstartmenu_UI (UIScene) e no menu que aparecer, clique em Salvar.

    Salve na nossa pasta UPK que criamos, lembra? (UTGame\Content\ExampleGame\UPK\), com o nome que ja está sugerido.





    Bom, já criamos nossa UI, adicionamos os eventos e tal, agora precisamos associar este evento que criamos ao nosso mapa/fase.

    Feche o content browser e clique no botão Open UnrealKismet.





    Bom, agora vamos adicionar uma nova ação no Kismet. Em um espaço vazio, clique com o botão direito do mouse e clique no menu: Add New Action -> UI Scenes -> Open Scene.





    Adicione um novo evento, clique com o botão direito do mouse e clique no menu: New Event -> Level Startup.





    Ligue o evento OUT do Level Startup com o IN do Open Scene. Depois clique no item Open Scene e mude a propriedade Scene para a UISCene que criamos: UIScene'MyGameInterface.basicstartmenu_UI'. Ficando assim:





    Adicione agora um novo evento. Clique com o botão direito do mouse numa parte vazia e clique no menu: Add New Event -> Remote Event e depois adicione uma nova ação, clique com o botão direito do mouse: New Action -> Misc -> Console Command.

    Bom, clique no evento Remote Event e mude a propriedade Event Name para OpenYourLevel que foi o evento que criamos no botão, lembra?





    Agora clique no Console Command e adicione o comando: open MG-examplegamelevel, como na imagem abaixo:





    Lembrando que você pode criar mais de um comando, clicando no sinal de mais (+).

    Esse comando que será executado no console será ativado quando clicar-mos no botão, então nossa UI será para isso, ao clicar no botão vamos chamar nosso mapa/fase inicial.



    Adicione agora uma nova ação, clique com o botão direito do mouse numa parte vazia e clique no menu: New Action -> Toggle -> Toggle Cinematic Mode.





    Agora adicione uma variável, clique com o botão direito do mouse e depois no menu: New Variable -> Player -> Player.





    Agora ligue conforme a imagem abaixo. Está tudo juntinho pois não queria que a imagem ficasse grande para não tomar muito espaço na tela.





    Bom, vou explicar o que você fez. Você ligou oevento Level Startup em duas ações:

    OpenScene - que exibirá nossa tela que criamos no Kismet
    Toggle Cinematic Mode - aqui você poderá chamar uma apresentação de início de jogo, um vídeo, uma história ou algo do tipo, ao qual você pode usar a ferramenta Matinee para isso. Adicione o item que você criar na propriedade desta ação.
    E o Toggle Cinematic está ligado ao Player que executará o comando no console que está ligado ao evento OpenYourLevel que criamos no Kismet, no OnClick ou seja, o evento será o mesmo que você clicar na UIScene que criamos, que é ativar o mapa/fase para jogar-mos.

    Uma observação: Isto não funcionará no editor, somente no jogo mesmo.



    0 - Localização

    A internacionalização é bem simples, sempre que o jogador seleciona uma linguagem diferente a engine aponta para os respectivos diretórios. Mas nós vamos usar a localização INT (internacional) ou Inglês Smile

    Vamos fechar nosso editor, mas salve tudo.

    O editor só detecta a localização INT em sua inicialização.

    Crie um arquivo de texto chamado MyGame.int dentro da pasta: UTGame\Localization\INT.

    Neste arquivo que criamos adicione as linhas:

    [ExampleOfASection]
    01=Meu jogo
    02=To play click the button

    O que está entre os colchetes é chamado de sessão, quem está acostumado com arquivo INI conhece. Os números ali embaixo da sessão representa o número da linha, mas você pode usar qualquer coisa, como um texto por exemplo.

    Se você for usar texto, evite os espaços e acentos.

    Agora abra o editor novamente, depois abra nosso arquivo que contém a UIScene. Se você seguiu o tutorial, será ExampleGameFrontEnd.

    Abra o content browser, de um duplo-clique na nossa UIScene em nosso pacote(package).

    Clique com o botão direito do mouse e clique no menu: Place Widget -> Label [Standard].





    Faça isso duas vezes, de modo que você tenha duas labels em sua UIScene:





    Após adicionar as labels, clique na primeira label e no menu ao lado acesse a propriedade: Data -> Data Source -> Markup String e coloque o seguinte texto ali:





    Para explicar, caso você ainda não tenha sacado. Quando você definiu este texto na propriedade Markup String, você está dizendo que o conteúdo da label será uma string contida na sessão ExampleOfASection, no item 01 do jogo MyGame(o nosso jogo). Se você tivesse colocado no arquivo de localização assim:

    [Game]

    titulo=Meu jogo

    Então você colocaria assim na propriedade Markup String da label:



    Agora faça o mesmo para a segunda label, troque apenas o 01 por 02, ficando assim na propriedade Markup String da segunda label:



    Agora feche a janela do UIScene e não esqueça de salvar. Clique com o botão direito no item do content browser e depois em salvar, e ele já irá salvar no lugar que selecionamos antes.



    7 - Mais sobre os arquivos INIs

    Bom, já amanheceu e eu ainda estou aqui, às 6:00 da matina.

    Feche seu editor, pois para altera-mos os arquivos INIs, precisamos fechar ele.

    Abra o arquivo:

    UTGame\Config\DefaultEngine.ini

    Procure pela sessão [URL], e altere conforme abaixo:

    MapExt=udk - Não altere aqui, a não ser que você tenha salvo seus mapas com outra extenção.
    Map=UTFrontEnd.udk - Altere para ExampleGameFrontEnd.udk. Isso irá fazer com que carregue nosso menu como padrão.
    LocalMap=UTFrontEnd.udk - Da mesma forma que acima, altere para ExampleGameFrontEnd.udk.
    Então nosso INI ficará assim nesta sessão, nos itens abaixo:

    MapExt=udk
    Map=ExampleGameFrontEnd.udk
    LocalMap=ExampleGameFrontEnd.udk
    Os outros itens, deixe como estão.



    Agora procure pela sessão: [Engine.PackagesToAlwaysCook] e adicione a seguinte linha:

    +Package=ExampleGameFrontEnd

    Isso fará com que o UnrealFrontEnd sempre compile faça o cook deste arquivo.



    Agora procure pela sessão: [Engine.StartupPackages] e adicione a seguinte linha:

    +Package=MyGameInterface

    Isso fará com que o jogo sempre carregue este pacote. Lmebra que criamos este pacote para poder fazer a interface? Mas você não precisa colocar aqui todos os seus pacotes, somente os que forem relacionados a interface, para que sejam carregados primeiro.



    Agora procure pela sessão: [Engine.PackagesToForceCookPerMap] e adicione a seguinte linha:

    .Map=ExampleGameFrontend

    .Package=MyGameInterface

    Isso fará com que o pacote seja carregadao com o mapa(somente com este), pois as vezes a engine falha em carregar alguma coisa dela, então forçamos aqui somente os elementos da interface serem "cookeds" juntamente com o mapa/fase.



    Você pode também se quiser, alterar a sessão: [FullScreenMovie] e adicionar o que você quer carregar como filme ou tela de carregamento. Se não quiser alterar, não precisa.

    Terminamos, salve e exclua o arquivo UTEngine.ini para que seja criado outro baseado nessas nossas novas configurações.

    Agora inicie o jogo e teste o menu que criamos, o pressionamento do botão e por ai vai. Clique no atalho "Game - Unreal Development Kit".

    Aqui funcionou beleza.





    8 - Cooking

    Mais que raio de cooking é esse?

    Calma, vamos lá. Este é o processo de compilação final do seu projeto. Ele pega o conteúdo que você usou no seu projeto(texturas, materiais, mapas/fases, modelos), codigos, localização e tudo mais, e ainda protege para dificultar que qualquer um veja ou altere o conteúdo do seu jogo.

    Vamos à prática, feche o jogo, o editor e tudo mais e abra o UnrealFrontEnd(Binaries\UnrealFrontend.exe).

    Clique na ABA cooking, vai aparecer um campo de texto para você digitar o nome do mapa, digite o nome do nosso mapa: MG-ExampleGameLevel.

    Não precisa fazer o cook do outro mapa/fase(ExampleGameFrontEnd), pois lembra que adicionamos ele no INI para sempre ser feito o cook dele, pois ele faz parte da interface?

    Agora clique no botão COOK lá em cima.



    Após este processo, deverá ter sido criado uma pasta chamada CookedPC em UTGame, que é o conteúdo que será distribuido para o usuário final.





    9 - Packing

    Este é o processo mais esperado, a hora de empacotar todo o trabalho, gravar numa mídia e vender Smile

    Para fazer é muito difícil e complicado, preste MUITA atenção.

    Ainda no UnrealFrontEnd, clique no botão Package Game.

    Vai aparecer uma janela pedindo para você digitar o nome do jogo. Coloque o nome e clique no botão grande lá em baixo: Package



    Pronto. Será gerado o arquivo de instalação na pasta raiz do UDK:
    avatar
    PabloKiller
    Membro
    Membro


    Mensagens : 1
    Pontos : 1
    Data de inscrição : 06/08/2012

    adicionar ambiente Empty Re: adicionar ambiente

    Mensagem  PabloKiller Seg Ago 06, 2012 6:53 pm

    Cara eu sei que esse não e o lugar certo mais eu posso ser ADM????lol!
    cassio2012
    cassio2012
    Membro
    Membro


    Mensagens : 2
    Pontos : 2
    Data de inscrição : 13/08/2012
    Idade : 59
    Localização : São Paulo - sp - Capital

    adicionar ambiente Empty Um otimo tutorial

    Mensagem  cassio2012 Seg Ago 13, 2012 7:31 pm

    Ola , sou novo por aqui e meio que bebado em um tiroteio Smile
    Estou acompanhados as dicas deste incrivel forum, parece bobagem mas nao saboa que poderia criar mapas para jogos etc.. (sou novato nisso) terei muitas duvudas, e gostaria de deichar claro , tenho algumas dificuldades, mas nda de importante Smile


    valeu.

    Conteúdo patrocinado


    adicionar ambiente Empty Re: adicionar ambiente

    Mensagem  Conteúdo patrocinado


      Data/hora atual: Qui Nov 21, 2024 4:23 pm