I've been working full-time on a game called Bot Land for the last four years, and it just launched: https://bot.land/ In the game, you can make bots with a Scratch-like interface called Blockly or use a subset of JavaScript. Either way, bots are fully automated.
Here are some screenshots of the game: https://imgur.com/a/Rs2OWFg
Almost all of the development process (~5000 hours) was streamed live on Twitch: https://www.youtube.com/watch?v=RS5Va996Exg&list=PLSM9PbIe-9...
It's free to play, so please try it and tell me what you think!
Congrats on launching. After four years that’sa huge accomplishment.
Any advice?
Second, all available functions are accessible by clicking the question mark that shows in the script editor. Some Math functions like "abs", "floor", and "ceil" are exposed to users, but "sqrt" is not. This means that you would have to either write your own implementation or convince me to add it to the game. When I hear "sqrt" in Bot Land, I assume you want to find the distance between two objects, in which case you may be able to use the built-in "getDistanceTo" function. It can either take in an entity or two arguments representing (X, Y) coordinates and returns the Manhattan distance between the bot and the target.
If there's another scenario where you'd like the square root, I'd be glad to consider either accommodating the scenario or just adding access to Math.sqrt directly. If we go that route though, you wouldn't have access to whatever results from it before ~Tuesday of this week at the earliest.
I linked that rather than copy/pasting it because you may find other answers interesting on that page. :)
EDIT: I should clarify that 5000 hours is roughly the number of hours that I streamed, not the number of hours that I worked on Bot Land. There were way more hours spent in the background doing all sorts of things (including coding), but the majority of the actual development was on-stream.
I don't see how to make the commitment to spend multiple years without like an income coming from it and a team to work with. By myself it just becomes unbearable after a while.
I want to make a living off games. I'm almost 30 and things aren't getting easier.
Do you mind clarifying what you find brutal? I am very far from being a lawyer, so I just wanted to make sure I'm protected, which is why I contracted the work out in the first place.
This is amazing, congrats.
Two reasons:
1. By making them public, they show up for all of my subscribers on YouTube, but I assume most subscribers on YouTube want to watch "major" update videos like announcements, recaps, etc. 2. I didn't want a new person coming to the channel to get lost in the ~800 development videos rather than seeing the important ones.
> This is amazing, congrats.
Thank you! It's surreal to have spent this long developing something and finally launch it.
I also played - I guess back in the late 90's, with an autonomous Asteroids-like game where you'd write code to control your "space ship" that had "radar" to show you nearby opponents and had pretty much just Asteroid-like controls, which ran as a networked screensaver. It came out of a bunch of people working at Canon - a friend of mine worked there writing printer drivers...)
(Now I'm wondering what you'd get if you let loose inside a modern device, like a cellphone for example, with two opposing bits of fighting code with full root access, but strictly equally time and resource shared? Would Core War even make sense any more with Gigs of ram, hundreds of gigs of flash, asnf stuff like wifi and bluetooth?)
Here is more on its language http://vyznev.net/corewar/guide.html
This is nuts!
I had an idea for similar kind of game where you are a wizard and program your own spells. The mechanics would be inspired by how magic works in The Dresden Files[0], where you draw in magical energy, transform it and then use it in some way. Maybe one could connect it with linear logic and programming.
I assume the former. The goal was always for Bot Land to be free-to-play, and there were many different approaches to monetization discussed throughout development. In the end, I settled on the one you see in-game now, but the tenets were always the same: https://share.bot.land/monetization.html
For reference, salvage packs are the single monetization point of Bot Land. I'm not planning to include advertisements, and I don't want to do subscriptions or anything. Salvage packs contain only cosmetic items, and the rarities are included up-front (which I would have done even if certain platforms like Apple didn't require that).
You can play for free and obtain every item in the game. The game took not only a substantial amount of time to develop (4 years), but also a huge chunk of my savings that I'd built up from my past jobs. I do need some way to make money, and I don't think people would give a game like Bot Land a shot if it weren't free.
However, why not allow users to purchase those items directly? The use of "loot boxes", even for purely cosmetic items, can create dangerous and unhealthy addictive behaviors as people buy again and again trying to get the item they want. A number of countries [0] have made "loot boxes" illegal or placed restrictions on them, so this isn't a purely humanitarian concern.
Additionally, since you can sell those cosmetic items for "Botcoin, which you can then use to purchase anything else in the game." doesn't that end up giving your game P2W functionality? It seems like moving to direct purchases of cosmetic items would eliminate the need for re-sale and prevent concerns about your game being P2W.
[0] https://en.wikipedia.org/wiki/Loot_box#Regulation_and_legisl...
For any game to be monetarily viable, it needs to pull in an average of $X for each player. Any free-to-play game (including freemium but not including something like shareware) skews how that average is formed because typical free-to-play games are lucky to have 5% of their playerbase spending any amount of money. This means that a large portion of the playerbase is actively costing money. Thus, they tend to rely on whales to spend huge amounts of money to compensate for all of the people spending nothing (or next to nothing). For this to work, the spending ceiling needs to allow for purchases of this size to even take place.
I wrote a salvage-pack modeler that would compute how many items of each rarity you would get by opening X packs, and how much Botcoin you could convert those items into should you want to sell them. I determined that at the highest number of packs that you can buy (70 packs, i.e. $100), you unlock nearly every cosmetic item in the game except for the rarest ones (which you actually unlock very few of). However, the average Botcoin value is enough for you to purchase several specific items that you may have wanted. I never wanted players to spend $100 for a single item and not be able to get it somehow.
By allowing direct real-money purchases of individual cosmetic items, I'd have to skew prices so heavily to make the same average revenue that I don't think players would want to purchase them. Also, there wouldn't be the fun or mystery of opening a salvage pack. I know what that sounds like. I even did a parody of EA's famous words for April Fool's last year (https://youtu.be/cCmj2hKbWeQ). But I can unravel a bit of this at least:
1. I'm not a businessperson. I don't know much about the psychology behind sales and how to make various business models work.
2. I have somewhat conflicting goals with Bot Land. I want the game to be free-to-play, I don't want to exploit users, and I want to make a living off of the game.
3. The model which I know can fit those goals is the salvage-pack system that you see in the game now.
4. The payment model is not set in stone. So far, Bot Land has grossed significantly less than $1000, and a large portion of that is from users who already had accounts before the game even launched, likely indicating that those users wanted to support me moreso than get something in the game. It's easy to be ethical until challenged, but I'd like to think that if I found users spending ludicrous amounts of money in the game, I'd do something to curb that behavior.
5. There's been an absurd amount of work just getting to launch, and I'm not positive that I can even continue Bot Land's development beyond 2019 without greatly changing the plans my wife and I made (more about that here: https://docs.google.com/document/d/1aCE4s5UvVLH7dHuO1OA2m5Sw...). This bullet point's relevance is that I have so few resources to even be able to focus on the game alone right now, let alone any other issues that may pop up.
You may take this as incoherent rambling or mental gymnastics to be able to justify what is typically a predatory business model in gaming. I will be reevaluating as time passes to figure out whether something needs to be changed. I highly doubt Bot Land will be successful enough for me to even be able to make those decisions though.
> doesn't that end up giving your game P2W functionality?
Functional items are supposed to be balanced such that they can be situationally better than other items of the same category, but not outright better. Arguably, being situationally better allows you to be outright better the more situations you come across, but I think that fully exploring the nuances of this would be a much larger conversation when I think that the heart of your questions is around loot boxes. In short: I don't think that even if you could purchase Botcoin directly would the game be pay-to-win.
Finally, one last note that's not the most salient: I never really intended for salvage packs to be convertible into the other items in Bot Land, just cosmetic items. The one monetization point that I've written down for the future is to introduce hardware coupons, that way you can directly purchase functional items. I don't know when this would happen though, if ever.
---
There are parts in this post, specifically with the five points I enumerated, whose connection to the original questions and even to my own supporting points may not be clear to a reader. I took time and care to type this, but I'm sure that I could have made things clearer. I don't mind participating in an honest discussion about this or other aspects of the game. I'll likely stream tomorrow (Monday) if you want to ask me in-person (although I can't guarantee that I have the required amount of time to devote to the conversation).
Don't buy one.
I really liked your marketing document and think others might find it really useful, hope you don't mind me linking it here: https://docs.google.com/document/d/1TiSmB7IaWpIf_7cUWzk7GAtR...
(let me know if you are not ok with that and I'll edit the comment)
Alternatively, maybe you were referring to some other part of the game when you said you wouldn't want to play this, in which case I'd love to hear your feedback!
Loadout weapon drag window can get permanently stuck on the screen, requiring a refresh. See here https://i.imgur.com/cL4x2Vk.png
Steps to reproduce: Go to Edit Blueprint Window. Start dragging a window. Press backspace to go back to the game field. The window is now permanently stuck.
Also, it's better that I get reports than not, but if you've got any future bug reports or feature suggestions, there is an in-game bug reporter that you can use via the button at the upper right of most screens in the game.
Gave up at the ‘place two bots’ stage. Couldn’t work out how to place a bot. Love the idea. Needs UX love!
I've heard sporadic reports about not being able to place bots on iOS, and I'm still not sure if it's a bug (I only have my wife's iPhone to test on and it works there, but I know it's not representative of everyone's experience) or unclear instructions. This is the flow that should be happening: https://i.imgur.com/EalfL7J.png
The steps, as text:
1. Open your bot selector
2. Select a bot
3. Tap in the Arena to place one
Is that flow showing up for you? Are you on an iPad or something that shows the "desktop" view of things (i.e. the bot selector is expanded by default)?
Alternatively, in that mobile tutorial, should you try dragging the bots from the selector, that should work too, although it tends to take a little bit longer to deploy multiple bots that way.
Update. Got two bots (at least based on count), I have no clue how, started fight, but there is nothing to be seen, just black background. Battle finished and again everything black except the menues.
I am fan of bot wars and would love to play it, but this is just too frustrating to use.
• What device are you on?
• Are you using the app or the site?
• If you're on the site, what browser are you using, and have you pinned the site to your home screen, or is the URL bar showing?
• What OS version are you on?
The mobile versions of the game are thin wrappers around the web version (https://play.bot.land/), and there weren't very many mobile users before launch, so bugs certainly made it through the testing process.
Your for loop's body section is not legal. You can only use literals as a refinement on objects (when trying to index into an array[i] returned from findEntities).
> How was streaming development of the game?
It was great! People ask me a lot about what I'd change if I could go back in time or start again, and while I would certainly change some technological decisions, I would not change the streaming aspect. There are so many great things that have happened over the years, and I feel like the culmination of all of it can be summed up in this launch-day highlight I took: https://www.twitch.tv/videos/486320333
That one video felt like it made the whole journey worth it.
> Are you concerned about your source being visible?
I wasn't super concerned for a few reasons:
• Code is copyrighted as soon as you write it, so if someone were to take it, I would be able to take legal action against them.
• Perhaps more importantly, I didn't think anyone would want to copy Bot Land's code. Automation games are growing as a genre, but rarely will they include scripting as the main component. To my knowledge, there wasn't a scripting-based game ~4-5 years ago that proved that they could be successful.
• See the next answer...
> Or feeling like you are being watched or judged while coding?
Impostor Syndrome runs rampant with coders. Did I feel like I'd be judged? Yes. Was I? 100% yes (by some people). Were some people mean about it? You'd better believe it. However, I started streaming for accountability and marketing, and I wouldn't have gotten those benefits if I didn't stick with it.
Also, remember that as a streamer, you control who gets to stay around in your chat. People are entitled to their own opinions, but I think the #1 rule as a streamer is that of entertainment: the show must go on. As a programming streamer, this doesn't mean that you have to be entertaining all of the time since you have to be productive while streaming. Either way, in order to keep the show moving, you have to be in a good enough mood to do things. When a troll gets in the way of that, you purge/timeout/ban and move on.
If someone is judging you for your coding style or standards in an unconstructive way, you have tools at your disposal to handle it.
> When did you start streaming development?
I started on September 8th, 2015. I believe I had one follower on Twitch at the time, a real-life friend of mine.
> I'm worried my side project is too early in development to stream...
I don't think anything is really off-limits for a development stream. I've spent entire days streaming myself milling around entirely in a text document (i.e. not even code). I've spent days writing automated tests, triaging bugs, debugging, etc.
> Did you end up having to spend a bunch of time making extra stuff for your audience, like the faq you linked?
Yes. If I had to estimate how many full work days I've put into just streaming-related tasks, I would say it's about 10-15. Granted, you can just start with practically no preparation and see where it takes you, but I don't advise doing that. My advice on streaming hasn't changed too much in the past years; it's mostly encapsulated here: https://blog.bot.land/2016/10/being-a-development-streamer-o...
Streaming is just as saturated as games are nowadays. There are a million streamers trying to make it big who "don't care about the numbers, they're just doing it for themselves". If you want to get started, I'd say that you should come up with a goal pretty early on, and that goal should not be to earn money from the stream. I won't share exact numbers, but I make less than minimum wage as a streamer. As a developer at a traditional job (in the U.S.), I'd make plenty of money.
I'd be happy to answer more questions you may have, although I think you'll have to see for yourself how streaming goes in order to consider whether it's worth it. And be ready to come to the conclusion that it's not worth it since it can affect your productivity and possibly your mood/energy.
Do you find it difficult to converse with folks while programming? How do you maintain flow state while streaming? (Maybe this is just a skill you pick up?)
This comic (which you've probably seen!) sums up context-switching as a programmer: https://heeris.id.au/2013/this-is-why-you-shouldnt-interrupt...
Imagine that but multiplied by 100. Every 3 seconds, someone is saying something that you can see out of the periphery of your vision. How difficult it is to interact is up to you; you can hold off on chat and handle it every X minutes, you can let them interact with themselves, or you can interrupt your flow every few seconds.
I try to take extensive notes about what I'm doing at any given moment so that I can always pop the context back off the stack and resume my work. It's a skill you'll hone as you go.
I’ll give your game a try, maybe I’ll be proved wrong
* None - just ignore the scripting and let the default AI take care of everything. There are some items that can't be used this way, e.g. Teleport and EMP, because the default AI wouldn't know how you'd want to use them. * Blockly - use the block-based scripting to control your bots. This is what I suggest as the step for newcomers who still want to customize their bots' behavior. * BotLandScript - this is a subset of JavaScript that I only recommend for people who already know how to code.
Blockly and BotLandScript should have feature parity (not that they do right now, but the differences are somewhat minor given the target audiences for each), so you don't necessarily have to code (or even know how to code) to play Bot Land. Then again, scripting will certainly give you an advantage.
I know how to code, but I don't know how to win a game of BotLand. Having the ability to just start a match right away is killer.
I played a dozen or so matches so far. Really excited to see how development progresses. Also surprised at how well the mobile app runs considering it's a web wrapper (but it doesn't feel like most web wrappers do!)
Best of luck, and thanks for the game!
You’re going to get negativity from “developers” about using Blockly, but unless they’re your target audience don’t let it get to you.
Lots of EE’s use graphical tools to layout the circuit boards anyway... so text is really just an unnecessary abstraction over schematics & you’re bringing programming back to its roots :-)
"Linux supports the notion of a command line or a shell for the same reason that only children read books with only pictures in them. Language, be it English or something else, is the only tool flexible enough to accomplish a sufficiently broad range of tasks."
-- Bill Garrett
Now a point about EEs/CEs... it's way nicer to write:
module dff (
q,
d,
clk
);
output q;
reg q;
input d;
input clk;
always @(posedge clk) begin:
q <= d;
end
endmodule
than to actually lay out and route a flip flop. Of course you're going to simulate such modules, and use graphical tools (the least of which is just to picture signal waveforms), this isn't to say graphical tools are going away or are pointless, but I would readily take the other side on a bet about your prediction since I don't think programming will even in 100 years be something people think of as manipulating graphical elements rather than typing/chording expressions satisfying some grammar/syntax we'd call a language.