Ir ao conteúdo
  • Cadastre-se

Benjamin Breeg

Membro Pleno
  • Posts

    230
  • Cadastrado em

  • Última visita

  1. Você já viu a serie de vídeos sobre Engine de Raycasting do canal manual do código? É um dos materiais mais completos no youtube sobre raycasting. São mais de 40 vídeos onde ele explica passo a passo como implementar inclusive toda a parte matemática.
  2. Bit blitting é obsoleto com o hardware que temos hoje em dia. A maneira mais eficiente ate mesmo para simples jogos 2D é criar geometria de triângulos, fazer o mapeamento das texturas e enviar diretamente para a placa de vídeo. Vale lembrar que placas de vídeo são projetadas para manipular quantidades absurdas de polígonos portanto enviar diretamente os bitmaps para a memória é desperdiçar processamento. A SFML por exemplo tem ferramentas para criar essa geometria de triângulos. https://www.sfml-dev.org/tutorials/2.5/graphics-vertex-array.php Pode ser uma boa começar por ai.
  3. Acho que com o hardware que temos disponível hoje em dia a maneira mais eficiente de desenhar coisas ate mesmo 2D é construir formas com triângulos, fazer o mapeamento de texturas e enviar para a placa de vídeo já que a engenharia das GPU desde a mais simples ate as mais poderosas é basicamente gerar uma quantidade absurda de triângulos numa velocidade altíssima, não tem porque não usarmos essas capacidades. Na SFML e acredito que outras bibliotecas você pode criar geometria de triângulos de forma mais simples, aqui nesse link tem um tutorial sobre os vertex arrays, que é uma uma maneira mais baixo nível de manipular triângulos sem que ter programar diretamente em OpenGL, DirectX ou ter que estudar aqueles livros de geometria que quebra o seu pé se cair. Aqui tem o exemplo de como criar um tilemap que é base pra muitos jogos. https://www.sfml-dev.org/tutorials/2.5/graphics-vertex-array.php
  4. Essa é a tradução da primeira versão do livro que cobre o C++98, a mais atual (2 edição) já é revisada para as versões C++ 11 e C++14. Não achei nenhuma informação de uma terceira edição revisada pra versões mais modernas do C++.
  5. Você não esta tentando usar o source do allegro5 sem compilar para gerar as dll etc etc ? Verifique o arquivo que baixou para ver se não é isso, tenha certeza que baixou os binários para Windows para MinGW ou compilador Microsoft ou os arquivos para Linux. https://github.com/liballeg/allegro5/releases
  6. O grande problema é que a versão 4 só aceita resoluções pré-definidas, não digo que você não consiga fazer funcionar mesclando win32 ou outras peripécias técnicas mas vai ser uma gambiarra daquelas. Eu vi aqui que em 2019 lançaram uma versão nova do Allegro 4.. a versão 4.4.3, pelo que diz o post do dev fizeram muitos bugfixes e parece que mexeram em coisas relacionadas a problemas no modo full screen. Se você não quer de jeito nenhum migrar para a versão 5 pode ser um bom ponto de partida dar uma olhada. https://www.allegro.cc/forums/thread/617731 http://members.allegro.cc/EdgarReynaldo/BuildA4.html testei aqui o o MinGW i686-8.1.0-release-posix-dwarf-rt_v6-rev0 e funcionou perfeitamente.
  7. Você esta dizendo criar a janela Win32 e fazer o Allegro usar esse contexto Win32? Em APIs como a SFML você consegue criar um contexto Win32 e usar funções da SFML livremente, o Allegro não da suporte a esse recurso nem na versão 5 creio eu. Poderia ser possível ne, na pratica o Allegro usa a Win32 por trás da cortina.
  8. Cara acho que o Allegro 4 não suporta resoluções definidas pelo usuário que seria o caso, você pode ter fullscreen e windowed mas não tenho certeza se realmente não aceita fullscreen window. So vendo mesmo.
  9. No Allegro 5 você pode usar o "ALLEGRO_FULLSCREEN_WINDOW" para setar uma janela em tela cheia com a barra visível Aqui um exemplo aperta "M" para você ver o efeito, veja se é o que você quer. #include "allegro5/allegro.h" #include "allegro5/allegro_font.h" #include "allegro5/allegro_ttf.h" #include "allegro5/allegro_direct3d.h" #include <cstdio> class Display { protected: ALLEGRO_DISPLAY* display; ALLEGRO_EVENT_QUEUE* queue; ALLEGRO_TIMER* timer; ALLEGRO_FONT* verdana20; int origw; int origh; int w; int h; int xpos; int ypos; int adapter; bool opengl; bool redraw; bool quit; bool fullscreen; public : Display(); int Init(); bool Create(int width , int height , int adapter , bool use_opengl); void Destroy(); void RefreshInfo(); void DisplayInfo(); void Register(); void ToggleFullscreen(); bool SetAdapter(int nadapter); bool UseOpenGL(); bool UseDirect3D(); void CheckInput(); void Draw(); void Run(); bool Quit() {return quit;} }; int main(int argc , char** argv) { Display d; int ret = d.Init(); if (ret != 0) {return ret;} if (!d.Create(800 , 600 , 0 , true)) { return 1; } d.Run(); return 0; } Display::Display() : display(0), queue(0), timer(0), verdana20(0), origw(0), origh(0), w(0), h(0), xpos(0), ypos(0), adapter(0), opengl(true), redraw(true), quit(false), fullscreen(false) {} int Display::Init() { if (!al_init()) { return -1; } if (!al_init_font_addon() || !al_init_ttf_addon()) { return -2; } if (!al_install_keyboard()) { return -3; } if (!al_install_mouse()) { return -4; } queue = al_create_event_queue(); if (!queue) { return -6; } timer = al_create_timer(1.0/60.0); if (!timer) { return -7; } al_register_event_source(queue , al_get_keyboard_event_source()); al_register_event_source(queue , al_get_timer_event_source(timer)); al_register_event_source(queue , al_get_mouse_event_source()); verdana20 = al_load_ttf_font("Verdana.ttf" , -20 , 0); if (!verdana20) { return -10; } return 0; } bool Display::Create(int width , int height , int new_adapter , bool use_opengl) { Destroy(); int ndflags = ALLEGRO_WINDOWED | ALLEGRO_RESIZABLE | (use_opengl?ALLEGRO_OPENGL:ALLEGRO_DIRECT3D); al_set_new_display_flags(ndflags); al_set_new_display_adapter(new_adapter); origw = width; origh = height; display = al_create_display(origw,origh); if (display) { opengl = use_opengl; adapter = new_adapter; Register(); al_start_timer(timer); } redraw = true; return display; } void Display::Destroy() { if (display) { al_stop_timer(timer); al_destroy_display(display); display = 0; } } void Display::RefreshInfo() { al_get_window_position(display , &xpos , &ypos); w = al_get_display_width(display); h = al_get_display_height(display); } void Display::DisplayInfo() { RefreshInfo(); al_draw_textf(verdana20 , al_map_rgb(255,255,255) , 10 , 10 , 0 , "Window position <%d , %d>" , xpos , ypos); al_draw_textf(verdana20 , al_map_rgb(255,255,255) , 10 , 40 , 0 , "Window dimensions <%d , %d>" , w , h); al_draw_textf(verdana20 , al_map_rgb(255,255,255) , 10 , 70 , 0 , "Adapter #%d" , adapter); al_draw_textf(verdana20 , al_map_rgb(255,255,255) , 10 , 100 , 0 , "%d Available adapters" , al_get_num_video_adapters()); al_draw_textf(verdana20 , al_map_rgb(255,255,255) , 10 , 130 , 0 , "Using %s" , opengl?"OpenGL":"Direct3D"); } void Display::Register() { al_register_event_source(queue , al_get_display_event_source(display)); } void Display::ToggleFullscreen() { fullscreen = !fullscreen; al_set_display_flag(display , ALLEGRO_FULLSCREEN_WINDOW , fullscreen); } bool Display::SetAdapter(int nadapter) { return Create(w , h , nadapter , opengl); } bool Display::UseOpenGL() { return Create(w , h , adapter , true); } bool Display::UseDirect3D() { return Create(w , h , adapter , false); } void Display::CheckInput() { do { ALLEGRO_EVENT ev; al_wait_for_event(queue , &ev); if (ev.type == ALLEGRO_EVENT_DISPLAY_CLOSE || (ev.type == ALLEGRO_EVENT_KEY_DOWN && ev.keyboard.keycode == ALLEGRO_KEY_ESCAPE)) { quit = true; break; } if (ev.type == ALLEGRO_EVENT_DISPLAY_RESIZE) { al_acknowledge_resize(display); } if (ev.type == ALLEGRO_EVENT_KEY_DOWN) { if (ev.keyboard.keycode == ALLEGRO_KEY_F) { ToggleFullscreen(); } if (ev.keyboard.keycode == ALLEGRO_KEY_M) { al_set_display_flag(display , ALLEGRO_MAXIMIZED , true); } if (ev.keyboard.keycode == ALLEGRO_KEY_N) { al_set_display_flag(display , ALLEGRO_MAXIMIZED , false); } if (ev.keyboard.keycode == ALLEGRO_KEY_O) { if (!UseOpenGL()) { printf("Failed to create an opengl context.\n"); quit = true; break; } } if (ev.keyboard.keycode == ALLEGRO_KEY_D) { if (!UseDirect3D()) { printf("Failed to create a Direct3D context.\n"); quit = true; break; } } for (int i = 0 ; i < al_get_num_video_adapters() ; ++i) { if (ev.keyboard.keycode == ALLEGRO_KEY_1 + i) { if (!SetAdapter(i)) { printf("Failed to set adapter %d.\n" , i); quit = true; break; } } } } if (ev.type == ALLEGRO_EVENT_TIMER) { redraw = true; } } while (!al_is_event_queue_empty(queue)); } void Display::Draw() { if (redraw) { al_set_target_backbuffer(display); al_clear_to_color(al_map_rgb(0,0,0)); DisplayInfo(); al_flip_display(); redraw = false; } } void Display::Run() { while (!quit) { Draw(); CheckInput(); } }
  10. Partindo do principio que você deseja desenvolver um sistema operacional do zero deve ter um conhecimento bastante razoável de C++, Assembly e hardware. Acredito que uma boa forma de aprender é estudar o código de quem o fez, tente procurar nos repositórios do GitHub pequenos projetos, pode ser uma boa para tentar entender como funciona o desenvolvimento de um SO na pratica. Aqui pode ser um bom ponto de partida: https://wiki.osdev.org/Main_Page
  11. Entendi você quer fazer um jogo no console.. é possível tem que criar um handle para console window. Seguindo aquele exemplo mas sem abrir janela gráfica, processamento de mensagens etc etc #include <windows.h> static COLORREF redColor=RGB(255,0,0); static COLORREF blueColor=RGB(0,0,255); static COLORREF greenColor=RGB(0,255,0); /* SetPixel */ void setPixel(int x,int y,COLORREF& color=redColor) { HWND console = GetConsoleWindow(); HDC hdc = GetDC(console); SetPixel(hdc,x,y,color); ReleaseDC(console, hdc); return; } void drawLineBresenham(int xa, int ya, int xb, int yb) { int dx = abs(xa - xb), dy = abs(ya - yb); int p = 2 * dy - dx; int twoDy = 2 * dy, twoDyDx = 2 * (dy - dx); int x, y, xEnd; if (xa > xb) { x = xb; y = yb; xEnd = xa; } else { x = xa; y = ya; xEnd = xb; } setPixel(x, y); while(x < xEnd) { x++; if(p < 0) p += twoDy; else { y++; p += twoDyDx; } setPixel(x, y); } } int main() { drawLineBresenham(10, 20, 250, 300); return 0; }
  12. Aqui tem um exemplo de como usar SetPixel para desenhar linhas através do algoritmo de Bresenham. Talvez ajude. #include <windows.h> #include <cmath> #define ROUND(a) ((int) (a + 0.5)) /* set window handle */ static HWND sHwnd; static COLORREF redColor=RGB(255,0,0); static COLORREF blueColor=RGB(0,0,255); static COLORREF greenColor=RGB(0,255,0); void SetWindowHandle(HWND hwnd) { sHwnd=hwnd; } /* SetPixel */ void setPixel(int x,int y,COLORREF& color=redColor) { if(sHwnd==NULL) { MessageBox(NULL,"sHwnd was not initialized !","Error",MB_OK|MB_ICONERROR); exit(0); } HDC hdc=GetDC(sHwnd); SetPixel(hdc,x,y,color); ReleaseDC(sHwnd,hdc); return; // NEVERREACH // } void drawLineBresenham(int xa, int ya, int xb, int yb) { int dx = abs(xa - xb), dy = abs(ya - yb); int p = 2 * dy - dx; int twoDy = 2 * dy, twoDyDx = 2 * (dy - dx); int x, y, xEnd; if (xa > xb) { x = xb; y = yb; xEnd = xa; } else { x = xa; y = ya; xEnd = xb; } setPixel(x, y); while(x < xEnd) { x++; if(p < 0) p += twoDy; else { y++; p += twoDyDx; } setPixel(x, y); } } /* Window Procedure WndProc */ LRESULT CALLBACK WndProc(HWND hwnd,UINT message,WPARAM wParam,LPARAM lParam) { switch(message) { case WM_PAINT: SetWindowHandle(hwnd); drawLineBresenham(10, 20, 250, 300); break; case WM_CLOSE: // FAIL THROUGH to call DefWindowProc break; case WM_DESTROY: PostQuitMessage(0); return 0; default: break; // FAIL to call DefWindowProc // } return DefWindowProc(hwnd,message,wParam,lParam); } int WINAPI WinMain(HINSTANCE hInstance,HINSTANCE hPrevInstance,LPSTR lpCmdLine,int iCmdShow) { static TCHAR szAppName[] = TEXT("Straight Line"); WNDCLASS wndclass; wndclass.style = CS_HREDRAW|CS_VREDRAW ; wndclass.lpfnWndProc = WndProc ; wndclass.cbClsExtra = 0 ; wndclass.cbWndExtra = 0 ; wndclass.hInstance = hInstance ; wndclass.hIcon = LoadIcon (NULL, IDI_APPLICATION) ; wndclass.hCursor = LoadCursor (NULL, IDC_ARROW) ; wndclass.hbrBackground = (HBRUSH) GetStockObject (WHITE_BRUSH) ; wndclass.lpszMenuName = NULL ; wndclass.lpszClassName = szAppName ; // Register the window // if(!RegisterClass(&wndclass)) { MessageBox(NULL,"Registering the class failled","Error",MB_OK|MB_ICONERROR); exit(0); } // CreateWindow // HWND hwnd=CreateWindow(szAppName,"Bresenham's Algorithm - Programming Techniques", WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, CW_USEDEFAULT, NULL, NULL, hInstance, NULL); if(!hwnd) { MessageBox(NULL,"Window Creation Failed!","Error",MB_OK); exit(0); } // ShowWindow and UpdateWindow // ShowWindow(hwnd,iCmdShow); UpdateWindow(hwnd); // Message Loop // MSG msg; while(GetMessage(&msg,NULL,0,0)) { TranslateMessage(&msg); DispatchMessage(&msg); } /* return no error to the operating system */ return 0; }
  13. Isso pode ajudar, na essência esse VisualG é um compilador pascal traduzido, ele não deve possuir todos os recursos da linguagem pascal mas com esse referencia fica fácil você fazer a transição. https://fdocumentos.tips/document/transicao-do-pascal-para-c.html
  14. Existe também o livro introdutório de C++ do Bjarne Stroustrup: Princípios e Práticas de Programação com C++, já vi dele sendo vendido em sebos online por preços mais camaradas, um que que tem boas recomendações em forums e lista de melhores livros é o C++ Primer, 5th Edition do Stanley B. Lippma. Esse link pode ajudar: https://stackoverflow.com/questions/388242/the-definitive-c-book-guide-and-list
  15. Acho que depende do seu gosto pessoal, se gosta do Python tem muitas opções para desenvolvimento de jogos, tem o PyGame, Cocos2d, a Godot engine que usa GDScript(baseado em python), a Panda3d fora versões de bibliotecas gráficas consagradas do C/C++ que foram portadas para o Python: PyOpenGL, PySFML, PySDL2 entre muitas outras. Agora acredito que quando se fala em desenvolvimento de jogos não tem como não falar em C++, praticamente toda grande e pequena engine mesmo que use scripts baseados em outras linguagens é construída em C++, fora que C++ é sintaxe base para muitas linguagens o que facilita para você programar em outras linguagens. Outro ponto importante é que as duas engines mais populares usam C++ e C# que é caso da Unreal e da Unity, o que também pode influenciar no aprendizado visto que a demanda de materiais para estudo(cursos, youtube, livros) é maior.

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...