CONSELHOS DE UM AMADOR
// De zero a amador ao longo de anos de aprendizado
Eu definitivamente ficaria longe de mecanismos de alto nível como o Unity ou o Torque2D MIT. Eles são ótimos para protótipos pequenos, mas eu nunca os levaria a sério para desenvolver meu próprio videogame. Por que eu deveria? Qual é o objetivo, a menos que não seja nada além de um simples remake do SideScroller ou Arcade?
A maioria dos mecanismos de jogos, bibliotecas ou estruturas não faz nada além da tarefa mais simples, com um monte de código inchado com funções e recursos que você nunca usará.
Quando eu era novo no desenvolvimento de jogos anos atrás, comecei no topo. Motores de nível muito alto. Não é algo muito alto como o RPG MAKER, mas definitivamente lá no alto, como Unity e Torque. Então eu fui mais baixo, para XNA e C #, porque havia muitos recursos e tutoriais. Meu projeto principal precisava do desempenho, ou talvez eu seja apenas obsessivo-compulsivo por querer um desempenho incrível no meu software, mesmo que não seja um projeto grande. O XNA simplesmente não o cortou, e eu tive muitos problemas com o mecanismo que li exigindo uma dor de cabeça para corrigir. Qual é o sentido de usar algo "de nível superior", como XNA / C #, quando você está fazendo o mesmo trabalho (corrigindo bugs e problemas de XNA) que faria com seu próprio mecanismo em C ++?
Depois de algum tempo de aprendizado, eu finalmente aprendi sobre como os mecanismos de jogo são projetados e comecei a analisar o código dos próprios mecanismos. Lendo o que a maioria dos profissionais tem a dizer e as queixas dos críticos dos mecanismos de jogos me fizeram perceber: 'Por que usar um mecanismo? "
Escovar o meu C ++ e realmente entrar em algumas filosofias usadas nessa linguagem me ajudou muito. No entanto, eu havia passado tanto tempo aprendendo tanto que só queria começar a fazer um jogo.
Então, acabei com algo com muitos elogios, era C ++ e nível muito baixo: SDL. Infelizmente, isso foi uma dor de cabeça. É um nível tão baixo que não vejo razão para usar essa biblioteca. Prefiro simplesmente aprender OpenGL e fazê-lo sozinho do zero. Honestamente, foi principalmente o fato de que eu precisava implementar meu próprio código para fazer algo tão básico quanto virar uma imagem (e a implementação de outras pessoas não estava funcionando por causa de como eu lidei com sprites) que me levou a lixeira SDL permanentemente. É ótimo se você quer um renderizador de software, mas na IMO eu prefiro descartá-lo para ficar mais baixo com o hardware (OpenGL) ou superior (SFML).
Não querendo comprar outro livro na amazon e aprender mais uma API, fui mais alto. SFML é simplesmente maravilhoso, para não mencionar altamente elogiado em toda a internet. Eu li quase um número interminável de críticas positivas, com quase nenhuma negativa. Não posso dizer o mesmo para SDL. Ele lida com todos os conceitos básicos extremos, mas deixa o resto para mim e para outras bibliotecas de minha escolha. Eu continuo com isso desde então.
IMO, um mecanismo de jogo é apenas bobo. Bibliotecas de baixo nível são escolhas muito melhores para programadores experientes e iniciantes.
Observe também que aprendi mais sobre conceitos de programação e aprimorei minhas habilidades de desenvolvimento de software quando forçado a lidar com as coisas em um nível mais baixo do que eu já aprendi com os mecanismos de jogos WYSIWYG de alto nível.
O que algo como o Unity oferece a você sobre o XNA? Edição visual e muleta. Os novatos acabarão aprendendo que você ainda terá que codificar praticamente todo o jogo, como faria se tivesse C ++, e os editores visuais são ineficientes para algo que você mesmo pode criar.
O que algo como o XNA oferece a você sobre SFML ou sua própria implementação do OpenGL e outras bibliotecas úteis? OMI, absolutley nada de bom. Pior desempenho, C # em vez de C ++, uma infinidade de tutoriais para iniciantes, mas significativamente menos profissionalismo, e alguns poupadores de dor de cabeça porque o IMO é mais uma vez uma muleta para o que você deve aprender com C ++. Inicialmente, fiquei intimidado com C ++ e adorei C #, principalmente por causa de rumores e opiniões de tolos que tiveram os mesmos problemas que tive inicialmente com C ++: eu só queria um programador suficientemente bom. Percebi que precisava aprender mais fundamentos e aprimorar minhas fraquezas para superar os problemas que tive com o C ++, que o C # "facilitou". Eu já sinto falta da simplicidade de algumas coisas em c #? Nem mesmo! Eu sei como fazê-lo em C ++ sem problemas.
Se as bibliotecas de baixo nível ou o aprendizado do DirectX / OpenGL o intimidarem, espere até começar a entrar na complexidade de criar um videogame completo.
Minha filosofia sobre mecanismos de jogos pode ser resumida em dois exemplos que explicam a redundância e a inutilidade dos mecanismos, exceto em circunstâncias isoladas.
Os novatos que se sentem intimidados com bibliotecas de baixo nível terão um ataque quando descobrirem que, mesmo com um mecanismo de alto nível como o Unity, (além de renderização de gráficos, reprodução de áudio, carregamento de conteúdo; coisas básicas reais), será quase idêntico a criar um jogo do princípio. A complexidade está na engenharia de um jogo, no entendimento da API ou no desenvolvimento das classes a serem renderizadas na exibição.
Especialistas que não se sentem intimidados com a complexidade de criar um jogo completo em algo como Unity, não têm utilidade para o Unity, porque o tempo necessário para aprender com confiança a API e os requisitos de um mecanismo específico provavelmente é mais uma dor de cabeça e mais tempo do que o necessário para codificar as poucas classes necessárias para executar o básico.
Portanto, os motores são inúteis para iniciantes, porque iniciantes não podem fazer nada com eles porque não possuem as habilidades de engenharia. Da mesma forma, os mecanismos são inúteis para os veteranos, porque eles já têm as habilidades de engenharia para fazê-lo sem um mecanismo e também podem usar seu próprio 'mecanismo' mais eficiente e específico do que passar pela dor de cabeça de aprender a API do mecanismo de jogo, funções e peculiaridades de desempenho. Sem mencionar o pesadelo maciço de trabalhar com mecanismos que você às vezes não consegue tocar porque eles não são de código aberto (ou mesmo se estiverem, ler o código de outros pode ser um pesadelo às vezes).
Heck, mesmo algumas "estruturas de jogos" de "nível baixo" não passam de poucas classes para criar uma janela, renderizar na tela e reproduzir áudio. Isso é algo que um profissional pode fazer do zero usando outras bibliotecas como SDL / SFML ou sua própria implementação do OpenGL / DirectX / OpenAL, em uma fração do tempo necessário para concluir um videogame completo.
TLDR;
Se você deseja programar, aprenda a ser um programador .
Evite usar mecanismos , mas não se engane e ignore bibliotecas incrivelmente úteis.
Se você quer ser um Game Designer , tente um mecanismo WYSIWYG e instale esses jogos!
Se você quer ser um programador de jogos , evite motores como a muleta que são.
Para mim , o uso de mecanismos de jogos de nível superior prejudicou minha capacidade de me tornar um programador. No momento em que comecei a usar bibliotecas de nível inferior, ou não usei nenhuma, comecei a aprender tanto que rapidamente passei de um novato a alguém que agora pode criar videogames sem nenhuma referência, tutorial ou livro ao meu lado. Apenas meu compilador e muita engenharia e prática.
A quantidade de aprendizado que obtive em bibliotecas de baixo nível em um CURTO período de tempo foi muito maior do que o ganho em MUITO LONGO tempo com MOTORES de nível superior. **