lets-go.html 6.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. <!DOCTYPE html>
  2. <head>
  3. <meta charset="utf-8" />
  4. <!-- Set the viewport width to device width for mobile -->
  5. <meta name="viewport" content="width=device-width" />
  6. <title>Let's go</title>
  7. <link rel="stylesheet" href="http://opengamestudio.org/theme/css/normalize.css" />
  8. <link rel="stylesheet" href="http://opengamestudio.org/theme/css/foundation.min.css" />
  9. <link rel="stylesheet" href="http://opengamestudio.org/theme/css/style.css" />
  10. <link rel="stylesheet" href="http://opengamestudio.org/theme/css/pygments.css" />
  11. <script src="http://opengamestudio.org/theme/js/custom.modernizr.js"></script>
  12. <!-- So Firefox can bookmark->"abo this site" -->
  13. <link href="feeds/all.atom.xml" rel="alternate" title="Opensource Game Studio" type="application/atom+xml">
  14. </head>
  15. <body>
  16. <!-- Nav Bar -->
  17. <nav>
  18. <!-- Show menu items and pages -->
  19. <div class="row">
  20. <div class="large-12 columns top-bar">
  21. <h1><a href="http://opengamestudio.org">Opensource Game Studio</a></h1>
  22. </div>
  23. </div>
  24. <div class="row top-menu">
  25. <div class="large-12 columns">
  26. <a href="/pages/games.html" class="menu-button secondary">Games</a>
  27. <a href="/pages/education.html" class="menu-button secondary">Education</a>
  28. <a href="/pages/about.html" class="menu-button secondary">About</a>
  29. </div>
  30. </div>
  31. </nav>
  32. <!-- End Nav -->
  33. <!-- Main Page Content and Sidebar -->
  34. <div class="row">
  35. <!-- Main Blog Content -->
  36. <div class="large-9 columns">
  37. <article>
  38. <header>
  39. <h3 class="article-title"><a href="http://opengamestudio.org/lets-go.html" rel="bookmark"
  40. title="Permalink to Let's go">Let's go</a></h3>
  41. </header>
  42. <h6 class="subheader" title="2017-03-16T00:00:00+03:00">Чт 16 марта 2017
  43. <a class="button secondary small translation-button" href="http://opengamestudio.org/lets-go-ru.html">ru</a>
  44. </h6> <p><img alt="Let's go" src="http://opengamestudio.org/2017-03_lets-go.png"></p>
  45. <p>In this article we describe our progress in January and February of 2017: rendering under iOS/Web and a new tutorial tool.</p>
  46. <p><strong>Rendering under iOS/Web</strong></p>
  47. <p>To our surprise, we got a simple red cube rendered under <a href="https://twitter.com/OpenGameStudio/status/826816343433498627">iOS</a> and <a href="https://twitter.com/OpenGameStudio/status/829731986264698881">Web</a> pretty fast: in early February. However, this is only the beginning of this year's challenge to support Android, iOS, and Web platforms. There's a long and bumpy road ahead of us as we need a lot more on each platform before we can claim a success: visual effects, Python scripting, data archives.</p>
  48. <p>Since it took us about four months to get to mobile and web platforms, we decided to share our knowledge and help OpenSceneGraph community with a guide that shows how to use OpenSceneGraph on desktop, mobile, and web. We believe the more widespread OpenSceneGraph is, the stronger our technology becomes. As Isaac Newton said, "If I have seen further, it is by standing on the shoulders of giants." OpenSceneGraph is our giant.</p>
  49. <p><strong>Tutorial tool</strong></p>
  50. <p>Having conducted four live sessions before, it was clear the guide needs videos depicting every nuance. However, bare video alone is only good for showing what to do and not for explaining why do it in a certain way. That's why we decided to combine video with text in the forms of video subtitles and separate articles.</p>
  51. <p>To combine text and video, we first tried <a href="http://openshotvideo.com">OpenShot</a>. It worked well, but we quickly saw its limitations:</p>
  52. <ul>
  53. <li>Too much time is spent on adjusting time frames and animations</li>
  54. <li>Project file and original resources are hard to track with VCS</li>
  55. </ul>
  56. <p>Since OpenSceneGraph cross-platform guide would consist of several tutorials, we decided to automate the process. Brief research revealed a great multimedia framework called <a href="http://mltframework.org">MLT</a>, which powers OpenShot itself. With MLT we got our tutorial tool in no time.</p>
  57. <p>Currently, the tutorial tool allows anyone to combine text and video using a simple text file like this:</p>
  58. <div class="highlight"><pre><span></span>background bg.png
  59. text 5 Let&#39;s install Blender
  60. video 0:6 install_blender.mp4
  61. text 5 Installing it with apt
  62. video 6:26 install_blender.mp4
  63. text 5 We&#39;re still installing it
  64. video 26:56 install_blender.mp4
  65. text 5 Congratulations! We just finished installing Blender
  66. </pre></div>
  67. <p>This is the actual script. See the final result <a href="https://github.com/OGStudio/openscenegraph-cross-platform-guide/tree/master/tutorial-tool">here</a>.</p>
  68. <p>That's it for describing our progress in January and February of 2017: rendering under iOS/Web and the new tutorial tool.</p>
  69. <p class="subheader">Category: <a href="http://opengamestudio.org/category/news.html">News</a>
  70. </p>
  71. </article>
  72. </div>
  73. <!-- End Main Content -->
  74. <!-- Sidebar -->
  75. <aside class="large-3 columns">
  76. <!--k
  77. <h5 class="sidebar-title">Site</h5>
  78. <ul class="side-nav">
  79. <li><a href="http://opengamestudio.org/archives.html">Archives</a>
  80. <li><a href="http://opengamestudio.org/tags.html">Tags</a>
  81. <li><a href="http://opengamestudio.org/feeds/all.atom.xml" rel="alternate">Atom feed</a></li>
  82. </ul>
  83. <h5 class="sidebar-title">Categories</h5>
  84. <ul class="side-nav">
  85. <li><a href="http://opengamestudio.org/category/news.html">News</a></li>
  86. </ul>
  87. -->
  88. <h5 class="sidebar-title">Ads</h5>
  89. <script async src="//pagead2.googlesyndication.com/pagead/js/adsbygoogle.js"></script>
  90. <!-- ogs2 -->
  91. <ins class="adsbygoogle"
  92. style="display:block"
  93. data-ad-client="ca-pub-4473792248813084"
  94. data-ad-slot="9024247127"
  95. data-ad-format="auto"></ins>
  96. <script>
  97. (adsbygoogle = window.adsbygoogle || []).push({});
  98. </script>
  99. </aside> <!-- End Sidebar -->
  100. </div> <!-- End Main Content and Sidebar -->
  101. <!-- Footer -->
  102. <footer class="row">
  103. <div class="large-12 columns">
  104. <hr />
  105. <div class="row">
  106. <div class="large-7 columns">
  107. <p>Proudly powered by <a href="http://getpelican.com">Pelican</a>, which takes great advantage of <a href="http://python.org">Python</a>.</p>
  108. </div>
  109. </div>
  110. </div>
  111. <script type="text/javascript">
  112. var _gaq = _gaq || [];
  113. _gaq.push(['_setAccount', 'UA-3773114-1']);
  114. _gaq.push(['_trackPageview']);
  115. (function() {
  116. var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
  117. ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
  118. var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
  119. })();
  120. </script>
  121. </footer>