-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.html
133 lines (125 loc) · 10.3 KB
/
index.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
<!DOCTYPE html>
<html lang="en">
<head>
<title>Sam Wagner</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="Sam Wagner's personal page discussing learning Rust and game development with Bevy.">
<!-- favicons -->
<link rel="apple-touch-icon" sizes="180x180" href="/assets/images/favicons/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="/assets/images/favicons/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="/assets/images/favicons/favicon-16x16.png">
<link rel="manifest" href="/assets/images/favicons/site.webmanifest">
<!-- font download -->
<link rel="preload" href="./assets/fonts/Luckiest_Guy/LuckiestGuy-Regular.ttf" as="font" type="font/ttf" crossorigin>
<link rel="preload" href="./assets/fonts/Wellfleet/Wellfleet-Regular.ttf" as="font" type="font/ttf" crossorigin>
<!-- css -->
<link rel="stylesheet" href="./css/main.css">
<!-- cannonical url -->
<link rel="canonical" href="https://samwagner.dev/">
</head>
<body>
<header>
<h1 id="heading-page-name"
class="heading-page-name heading-name">
Sam Wagner
</h1>
</header>
<main>
<section id="welcome-message-section">
<p id="welcome-message">
Welcome to my blog! This is a project called <a id="welcome-message-steam-port-github"
href="https://github.com/SamBWagner/steam-port"
rel="nofollow"
aria-label="GitHub for the project steam-port"
target="_blank">
steam-port
</a> where I'm exploring both bloging and building a full stack site using only the most basic of tools like <abbr
id="welcome-message-html-abbr"
title="Hyper-text Markup Language">HTML</abbr>, <abbr
id="welcome-message-css-abbr"
title="Cascading Style Sheets">
CSS</abbr>, and <abbr
id="welcome-message-js-abbr"
title="JavaScript">
JS
</abbr> for the front-end and a backend solution lovingly handbuilt by me.
</p>
</section>
<h2 id="learning-rust-blog-heading"
class="blog-heading">
Learning Rust
</h2>
<h3 class="blog-subheading">
My first game
</h3>
<section>
<p>Starting out in the industry there's been one thing I've heard continually. <a href="https://www.rust-lang.org/" rel="nofollow" aria-label="Rust's website" target="_blank">Rust</a> is cool, and you should learn it. So, after endless nagging by a few colleagues and the swathes of social media that pushes it, I’ve made the plunge.</p>
<p>A few colleagues and I chose to partake in GitHub’s GameOff 2023. So, we had to choose a set of technologies to work with. In this case, we chose Rust as the language for our game. But we were left scratching our heads with what game engine to use (or indeed whether to use one at all). We boiled it down to two options: <a href="https://godotengine.org/" rel="nofollow" aria-label="Godot's website" target="_blank">Godot</a>, a relatively famous cross-platform engine which had added some support for the Rust developers, and Bevy, a lightweight, Rust first game engine that was still in its infancy. We ended up choosing Bevy in this case for a ‘full Rust experience’ as one of the members on our team who was much more into Rust said that Godot’s support for Rust was good but not great.</p>
</section>
<section>
<h4 class="blog-section-heading">So, how’s Rust?</h4>
<p>Well, I found Rust to be a rather refreshing affair. Rust’s borrowing and explicit pointer management and were not odd for me and I found that only two things that left my head spinning were lifetimes and closures. Those Darn pipes just look so strange, and it took me just way too long to make the connection that they’re just anonymous functions like in any other language. The compiler was the best part of Rust. Its error messages are clear, concise, helpful and holds your hand throughout the whole process. I never had a moment where I felt like I was fighting it.</p>
<p>Overall, I’d say Rust is a great language to learn if you’re looking to build some memory efficient code and if you’re looking to get a start with learning some lower-level concepts. Unfortunately, I can’t comment on how the language holds up in an enterprise environment as the game’s scope was just too small. I can see that it’d be awesome but, of course, any language is only as good as its support. I’m sure that there are plenty of crates to help you and/or your company build whatever you need. But I’ll leave that to your own investigations.</p>
</section>
<section>
<h4 class="blog-section-heading">How’s Bevy?</h4>
<p>Bevy is an <a href="https://en.wikipedia.org/wiki/Entity_component_system" rel="nofollow" target="_blank">entity component system</a> (<abbr title="entity components system">ECS</abbr>), which means that when you’re writing the game code, you’ll be predominently following these few core steps:</p>
<ol>
<li>Creating components
<ul>
<li>These are simple structures like <code>Weight</code>, or <code>Direction</code> which can be combined to form Entities.</li>
</ul>
</li>
<li>Spawning and Querying for Entities
<ul>
<li>These are the individual ‘things’ in the Game world. The thing that took a while to understand is that nearly everything is an entity. If I made a fish, it was an entity. If I was looking for the death timer for a fish then, that itself was also an entity.</li>
</ul>
</li>
<li>Writing systems
<ul>
<li>These are the functions that run the game. You might create a system like <code>fish_movement()</code> which would find all the fish in the world and then move them in the direction that they’re meant to go.</li>
</ul>
</li>
</ol>
<p>All this is to say that when you first start, the game engine follows a paradigm in <abbr title="entity components system">ECS</abbr> and that paradigm is absolute. So, if you’ve worked with other engines, this might be a bit of a head spin to start with. As it was for a few of the members who worked on gone-fish with me.</p>
<p>Overall, as you end up building isolated systems, you end up with many opportunities to work with Rust in small doses. So, you can write simple code, and then immediately see the results of that code. I found it to be great for learning!</p>
</section>
<section>
<h4 class="blog-section-heading"4>Conclusions</h4>
<p>I found that both Rust and Bevy were, when combined, an excellent first experience with both Rust and Game development. I’d recommend this setup for anyone who’s looking to take their first foray into game development and the Rust programming language.</p>
<p>I’d recommend that if you’re going to give this expedition a try here is a list of things that I’d do for the best experience:</p>
<ol>
<li>Start off with the Rust Book. It’s a near perfect document for learning the language and doing it will give you a huge head start to the process of working on the game.
<ul>
<li>I’d complete up to section 3 (3 included) if you want to speed run the learning experience. If you want to be fully prepped, then I’d go all the way to 6 (6 included).</li>
</ul>
</li>
<li>Then move on to the Bevy Book where I’d just follow the guided tour and I’d finish the first part. Ending in the Audio section.
<ul>
<li>There’s also a phenomenal series by Jaques on YouTube which will take you through building a full game in Bevy! I found it much better than the book. However, not because the book was bad. I just prefer video where possible. <a href="https://www.youtube.com/watch?v=TQt-v_bFdao" rel="nofollow" aria-label="YouTube link to Jaques Bevy tutorial" target="_blank">Jaques Bevy tutorial</a></li>
<li>There’s a caveat to both suggestions though. As Bevy is a new, and constantly in flux game engine. Neither of these is entirely up to date with the version of Bevy that I used to build the game gone-fish. The book, at time of writing, was sitting somewhere between v0.9 and v0.11 and the tutorial linked is at v0.10.
If I were to do this all over again, I’d build my first game on the same versions as these tutorials, either v0.9 or v0.10. That way you don’t need to do any migratory steps while you’re still learning both.</li>
</ul>
</li>
</ol>
</section>
<section>
<h4 class="blog-section-heading"4>Credits</h4>
<p>None of this adventure would've been possible without the help of all of the people I mentioned throughout this project. I'll provide links to their GitHubs below. I hope you'll go and check them out!</p>
<ul>
<li>Tylah Kapa - <a href="https://github.com/tkapa" rel="nofollow" aria-label="GitHub profile link: @tkapa" target="_blank">@tkapa</a></li>
<li>Luke Parker - <a href="https://github.com/hona" rel="nofollow" aria-label="GitHub profile link: @hona" target="_blank">@hona</a></li>
<li>Brook Jeynes - <a href="https://github.com/BrookJeynes" rel="nofollow" aria-label="GitHub profile link: @BrookJeynes" target="_blank">@BrookJeynes</a></li>
</ul>
<p>Also, feel free to play the game on <a href="https://kapa.itch.io/gone-fish" rel="ugc" aria-label="gone-fish on Itch.io">Itch.io</a> where you can play it on the site through Web Assembly (<abbr title="Web Assembly">WASM</abbr>), or download it for either Windows of MacOS.</p>
</section>
</main>
<footer id="page-footer">
<ul>
<li id="sams-footer-github-label">GitHub: <a href="https://www.github.com/SamBWagner" rel="nofollow" aria-labelledby="sams-footer-github-label" target="_blank">@SamBWagner</a></li>
<li id="sams-footer-linkedin-label">LinkedIn: <a href="www.linkedin.com/in/sam-b-wagner" rel="nofollow" aria-labelledby="sams-footer-linkedin-label" target="_blank">Sam Wagner</a></li>
</ul>
</footer>
</body>
</html>