[WebAssembly] How To Get The Most Out Of OpenGL With C++ And WASM

Disclaimer: This post is meant to put out my experience of using OpenGL with C++ & WASM. I know there is WebGL that could be used instead of what I've done, but I was really curious about WASM and wanted to learn more about it. So I decided to give life to my university's Computer Graphics project by porting it to WASM.

 

I hope my experience of learning how to use C++, OpenGL & WASM might be of some use to you.

 

What we are building

 

 

Setting up

The first most step is to download emscripten and set it up, You can find the instructions here.

 

After that, you need to be sure that you have appropriate files installed for C++ & OpenGL, in most Linux distros all the required packages are already present.

 

Making the C++ program ready for WASM

The OpenGL project I had done for my university was a train that translates (moves) along the x-axis, and this was supposed to be controlled by the user.

 

I directly compiled the program to WASM and included it in my project, it worked fine on computers (I could control the train using the keyboard), but the problem was on mobile devices.

 

So I had to expose two functions from the C++ program to the javascript, it was done as follows -

 

extern "C" void EMSCRIPTEN_KEEPALIVE move_train_forward() { 
    angle -= 0.01f;
    glutPostRedisplay();
 }

 extern "C" void EMSCRIPTEN_KEEPALIVE move_train_backward() { 
    angle += 0.01f;
    glutPostRedisplay();
 }

where 

angle

 is the position of the train, and 

glutPostRedisplay()

 causes the program to re-render. The two functions would move the train forward and backward.

 

 

Also, you'd want to make sure you are importing 

emscripten.h

 into your C++ program.

 

 
#include <emscripten.h>

After this, we are ready to compile the program to WASM.

 
emcc main.cpp -lGL -lGLU -lglut  -s WASM=1 -s LEGACY_GL_EMULATION=1 -O3 -o index.js

We are setting 

경축! 아무것도 안하여 에스천사게임즈가 새로운 모습으로 재오픈 하였습니다.
어린이용이며, 설치가 필요없는 브라우저 게임입니다.
https://s1004games.com

LEGACY_GL_EMULATION=1

 because I am using an old version of OpenGL, feel free to skip it if you are using a newer version. The output is a js and wasm file, you'll need to use the js file in your HTML.

 

 

you can also compile the C++ program to a complete HTML, JS & WASM project by changing the command to

 
emcc main.cpp -lGL -lGLU -lglut  -s WASM=1 -s LEGACY_GL_EMULATION=1 -O3 -o index.html

Emscripten generates everything for you, you just need to run the project on a local server to see the result. But since we are planning to add much more functionality, we are just going to choose the js option.

 

Writing the HTML & JS

We need to create a canvas element, the output from the C++ program will be drawn on this canvas. Right after that, we are calling the js generated by Emscripten.

 

    <canvas id="canvas"></canvas>
    <script type="text/javascript">
      var canvas = document.getElementById("canvas");
      var Module = {
        canvas
      };
    </script>
    <script src="index.js"></script>

To control the train on mobile devices, I thought It'd be fun to control it using the accelerometer. The following code does it.

 

      const accelerometer = new Accelerometer({ frequency: 30 });
      accelerometer.addEventListener("reading", () => {
        const { x } = accelerometer;
        if (x > 0) {
          _move_train_forward();
        } else if (x < 0) {
          _move_train_backward();
        }
      });
      accelerometer.start();

Here 

_move_train_forward 

and 

_move_train_backward

 are the functions that we wrote in the C++ program (Emscripten adds the 

_

 in the beginning). I've used the same methods to control the train via buttons as well.

 

 

The rest of the code is available in the Codeandbox above. I'm going to stop here, let me know if you have any doubts! Thanks for taking the time to read through this article.

 

Previously published at https://www.lenvingonsalves.me/opengl-wasm-cpp/

 
 
 

[출처] https://hackernoon.com/how-to-get-the-most-out-of-opengl-with-c-and-wasm-eop33sb

 

 

본 웹사이트는 광고를 포함하고 있습니다.
광고 클릭에서 발생하는 수익금은 모두 웹사이트 서버의 유지 및 관리, 그리고 기술 콘텐츠 향상을 위해 쓰여집니다.
번호 제목 글쓴이 날짜 조회 수
190 Unity3D에서 멀티 언어 (다중언어 지원) [197] 졸리운_곰 2014.02.05 10891
189 [Web Assembly] Exploring Blazor with Visual Studio 2019 file 졸리운_곰 2019.12.18 6452
188 무작정 배우는 C언어 머드(MUD)게임만들기 Part1 게임스랩 file 졸리운_곰 2020.10.17 5247
187 유니티에서 턴제 게임 구현하기 졸리운_곰 2017.05.09 4489
186 Games on GitHub 오픈소스 게임 모음 file 졸리운_곰 2016.01.19 4100
185 IT 서비스 스토리보드 (와이어프레임) 샘플 file 졸리운_곰 2017.10.10 2730
184 코로나 sdk 참고자료들 : corona SDK resouces [91] file 졸리운_곰 2014.11.24 1939
183 파이썬과 웹 어셈블리 Python and WebAssembly file 졸리운_곰 2019.12.18 1543
182 깃허브에 있는 오픈소스 게임들 : Games on GitHub file 졸리운_곰 2016.11.27 1531
181 coronaSDK와 Javascript 연동 : Interface Javascript On CoronaSDK, [58] 졸리운_곰 2015.06.01 1263
180 각도와 거리로 좌표 구하기 file 가을의곰 2017.06.10 1198
179 무작정 배우는 C언어 머드(MUD)게임 만들기 Part2 게임스랩 file 졸리운_곰 2020.10.17 1176
178 유니티3D '퐁' 게임 개발 file 졸리운_곰 2016.02.01 1054
177 Optimize your Ionic Testing with Wallaby.js, Bard.js, and WebStorm file 졸리운_곰 2017.02.06 947
176 무작정 배우는 C언어 머드(MUD)게임 만들기 Part3 게임스랩 file 졸리운_곰 2020.10.17 943
175 (CGP)16장. 탱크 게임 file 졸리운_곰 2021.06.28 901
174 PyGame - 사용법(기본 실행 구조) file 졸리운_곰 2021.01.03 884
173 스타트업과 앱 기획을 위한 UI Sketch Sheet file 졸리운_곰 2017.10.10 876
172 [pyGame] python 게임(game)만들기 - 파이썬으로 게임 만들기 튜토리얼 file 졸리운_곰 2021.05.12 831
171 lua for java luaj : 자바에서 루아 언어 사용 LuaJ 졸리운_곰 2016.04.20 830
대표 김성준 주소 : 경기 용인 분당수지 U타워 등록번호 : 142-07-27414
통신판매업 신고 : 제2012-용인수지-0185호 출판업 신고 : 수지구청 제 123호 개인정보보호최고책임자 : 김성준 sjkim70@stechstar.com
대표전화 : 010-4589-2193 [fax] 02-6280-1294 COPYRIGHT(C) stechstar.com ALL RIGHTS RESERVED