Quest 5

Introducing Quest WebEditor – create text adventures online in your browser

Written February 16th, 2012 by
Categories: Quest 5, textadventures.co.uk
6 comments

I was hoping to announce the world’s very first online text adventure maker – but, dammit! Playfic got there first, by a matter of days. So, what I am announcing today may be the world’s second-ever online text adventure maker, but it is also rather different to Playfic as you will see.

The Quest WebEditor is the world’s first online visual text adventure maker. It is (almost) the entire desktop version of Quest, but transplanted into a web browser. So, now you can create a text adventure game, with no prior programming experience, and without downloading any software. You have access to the full range of Quest functionality, including multiple languages, the ability to use hyperlinks in your game (to make it easier to play without typing), and the ability to embed videos, pictures and sounds for a modern text game experience (personally I’m fairly tired of text adventures being thought of as “retro” all the time – there’s no need for them all to look like MS-DOS).

Let me take you on a tour!

First, you’ll need to log in to textadventures.co.uk. You’ll then be able to access the “Create” page, which looks like this:

Enter a name for your game (you can always change it later), and choose a language.

Hit the Create button, and your game will be created. This is what it looks like in the editor:

This is a similar layout to the desktop software, and the full range of functionality is available – including cut/copy/paste and undo/redo.

The Settings button lets you turn on Simple Mode – as in the desktop software, this hides away some of the functionality to make it easier to get started.

I’ve renamed the initial “room” to “lounge”, and I’ve clicked the “+ Room” button to add another location to the game, a kitchen. Now, with the lounge selected, I can add an exit to the kitchen from the Exits tab:

I can add an object by clicking the “+ Object” button. Here I’ve added a sofa, and entered a text description:

I can try the game by clicking the Play button. It appears in a new tab, using the same “play online” interface as the published games on the site.

I can interact with the game just like all Quest games. There’s no need to force your players to type commands – the hyperlinks allow you to make a game which can be played with a click of the mouse, or a touch of the screen:

Here’s the game output after looking at the sofa, and moving east into the kitchen.

The real power of Quest comes from scripts, which let you control anything in the game – move the player, change responses according to what the player has done before, set up puzzles, show pictures and more. Back in the editor, let’s change the description of the sofa so that it runs a script instead of just displaying text:

Now we can click the “Add new script” button to choose from various options. This is the Simple Mode list – there is a much bigger list if we turn this off:

Let’s play a YouTube video when the player looks at sofa. I choose “Play YouTube video” from the “Add New Script” dialog, and then I can enter a video ID. I found a clip of a TV sofa advert:

And here’s what the game looks like if we run it now:

So there you have it!

This is currently in private beta – email me if you’re very keen to test it. Otherwise, I will make it available as a public beta in a few weeks.

Gamebook mode (“Choose Your Own Adventure”) in Quest 5.2

Written January 16th, 2012 by
Categories: Quest 5
3 comments

I’ve started work on Quest 5.2, aiming for a release in the Spring. One of the first new features I’ve implemented begins to take Quest away from “pure” text adventures to open up another type of interactive storytelling – gamebooks, also known as Choose Your Own Adventure (CYOA).

The gamebook mode is fundamentally a simple alternative Core library, built on the Quest platform. This means that you can create games using Quest’s visual editor, include graphics, upload your game to be played online in a web browser, and have your game converted into an app – everything that a “full” Quest game supports, with the difference that it is much simpler to create and play a gamebook, as players are only given a limited set of choices.

To create a gamebook, the “New Game” dialog has been updated with a new “Game type” option:

The Editor for Gamebooks is simple – each game comprises a number of pages. Each page has some descriptive text, and links to other pages.

Pages automatically default to names Page1, Page2 etc., but you can call a page any name you like.

This is what a new gamebook (as shown in the Editor above) looks like when you play it:

That’s all there is to it – pretty simple stuff really, at least for this first version. There is definitely potential for adding functionality in the future – because gamebooks are not fundamentally any different from ordinary Quest games, the full power of Quest’s scripting engine is available. This means that different behaviour could be triggered based on the player’s previous choices, random elements could be added, YouTube or Vimeo videos embedded, and a whole lot more.

Hopefully this new mode will open up interactive stories to a wider audience – if a full text adventure is too much work, a gamebook is one way of creating an interactive story where you really can focus much more on the writing than the implementation.

Gamebook mode is part of Quest 5.2, which is currently in development. I’m aiming to release this around Spring, although there will be a beta version before then. If you want to try it out right now, you will need to build the code yourself.

Quest 5.1 now available

Written January 11th, 2012 by
Categories: Quest 5
4 comments

Quest 5.1 is now available.

The new version of Quest features the following improvements below (mostly copied from the beta announcement, so apologies if this is all familiar!)

  • Enhanced Game Browser. You can now see star ratings, and read reviews and comments, directly within Quest. You also have more control – from the Options window, you can change the download folder, and enable or disable the Sandpit and Adult categories. Also, the Adult category option can be “locked out” with a registry setting (see “Configuring Quest” on the wiki for details) – handy if you’re rolling out Quest on a school network for example.
  • Simple Mode. Hides Quest’s more advanced functionality in the Editor – great for beginners, or for using Quest with younger children. The Editor becomes stripped right down to the basics – only rooms and objects are displayed in the tree, without the distracting “clutter” of functions, walkthroughs and so on. The Script Editor is cut down so only the most important script commands are displayed when adding a command. But full power is only ever a click away – you can toggle Simple Mode on or off at any time from the Tools menu.
  • Walkthrough Enhancements. You can now include walkthroughs in published .quest files, and the new walkthrough assertions feature allows you to create automated tests. See Walkthrough Assertions on the wiki for details.
  • Loops. There is a new “while” loop, and a new step parameter for “for”.
  • Use/Give. These have been moved to their own tab in the object editor, which is now more flexible. There are now separate lists for “Use (other object) on this” and “Use this on (other object)”, so you can set up a “use A on B” relationship from either A or B.
  • Hyperlinks. You can now customise the look of hyperlink menus – change the menu fonts and colours, and turn link underlining on or off. It’s now easier to create custom hyperlinks – the new ObjectLink function makes it easier to create an object hyperlink, and the new CommandLink function lets you create a hyperlink that will run any command.
  • Metadata. From the game editor, you can now enter a description and choose a category. There is a new game ID which will be used to uniquely identify a game. This will make it possible to upload a game to textadventures.co.uk without having to re-enter descriptions etc. on the web upload form.
  • Better error reporting. Error messages are now more detailed, so if your game won’t load you should have a better idea why. If Quest crashes, you can now submit an error report online.
  • Comments in the Editor. Script comments (lines beginning with “//”) are no longer stripped away when you open an ASLX file in the Editor – comments are now viewable in the Script Editor, and you can add and edit them.
  • Videos now automatically start.
  • You can now turn off sounds from the Options window.

Full upgrade notes are available on the wiki.

Download Quest 5.1

Quest 5.1 Beta

Written December 14th, 2011 by
Categories: Quest 5
6 comments

Quest 5.1 Beta is now available. This is the beta test version of the next release of Quest, which features the following improvements:

  • Enhanced Game Browser. You can now see star ratings, and read reviews and comments, directly within Quest. You also have more control – from the Options window, you can change the download folder, and enable or disable the Sandpit and Adult categories. Also, the Adult category option can be “locked out” with a registry setting – handy if you’re rolling out Quest on a school network for example.
  • Simple Mode. Hides Quest’s more advanced functionality in the Editor – great for beginners, or for using Quest with younger children. The Editor becomes stripped right down to the basics – only rooms and objects are displayed in the tree, without the distracting “clutter” of functions, walkthroughs and so on. The Script Editor is cut down so only the most important script commands are displayed when adding a command. But full power is only ever a click away – you can toggle Simple Mode on or off at any time from the Tools menu.
  • Walkthrough Enhancements. You can now include walkthroughs in published .quest files, and the new walkthrough assertions feature allows you to create automated tests. Enter “assert:” followed by an expression at any point in a walkthrough, and that expression will be evaluated. The walkthrough will terminate if the expression evaluates to false.
  • Loops. There is a new “while” loop, and a new step parameter for “for”.
  • Use/Give. These have been moved to their own tab in the object editor, which is now more flexible. There are now separate lists for “Use (other object) on this” and “Use this on (other object)”, so you can set up a “use A on B” relationship from either A or B.
  • Hyperlinks. You can now customise the look of hyperlink menus – change the menu fonts and colours, and turn link underlining on or off. It’s now easier to create custom hyperlinks – the new ObjectLink function makes it easier to create an object hyperlink, and the new CommandLink function lets you create a hyperlink that will run any command.
  • Metadata. From the game editor, you can now enter a description and choose a category. There is a new game ID which will be used to uniquely identify a game. This will make it possible to upload a game to textadventures.co.uk without having to re-enter descriptions etc. on the web upload form.
  • Better error reporting. Error messages are now more detailed, so if your game won’t load you should have a better idea why. If Quest crashes, you can now submit an error report online.
  • You can now turn off sounds from the Options window.

Download Quest 5.1 Beta

“The Things That Go Bump In The Night” now available for iOS and Android

Written December 5th, 2011 by
Categories: Quest 5, textadventures.co.uk
2 comments

The Things That Go Bump In The Night is now available for iOS (iPhone, iPod Touch, iPad) and Android devices.

In this game, written by Tim Hamilton, you are a security guard settling down to a quiet night shift, when things start to go wrong. You must make your way around the compound, solving puzzles and dispatching mysterious beasts.

This is the first Quest game to appear for smartphones, and I believe it is the first text adventure to be specifically designed for a pocket-sized touch screen – you can play the entire game without typing, instead using the hyperlinks and tabs to navigate and interact with the game world.

You can find out more about how the game was made in my earlier blog post. The game is fairly difficult – if you get stuck, check out the comments on the original textadventures.co.uk game page for some tips! Also check out the Twitter hashtag #ttgbitn.

More games will be released soon. Maybe you’d like to write one? Any game written for Quest 5 can now be converted into an app, so if you’re interested, please get in touch!

“The Things That Go Bump In The Night” coming to iPhone and Android

Written November 29th, 2011 by
Categories: Quest 5
4 comments

The first Quest-powered smartphone app will be released soon. It is an updated version of Tim Hamilton’s The Things That Go Bump In The Night, currently one of the top-rated games on textadventures.co.uk, and will be available for both iPhone/iPod Touch and Android devices.

This is the first time that a Quest game has been converted into a native application. As I’ve explained in a previous blog post, the way it works is by using a tool which I’ve built to convert Quest games into pure Javascript. Using Phonegap, this HTML/JS is then wrapped into a cross-platform app.

That’s the theory, but it has taken a bit longer than I initially expected to get this first app ready for release, for reasons which I’ll go into below. The good news is that subsequent conversions should now be much quicker and easier.

Two Conversions

The first step was actually a pre-conversion – the app converter works with games written for Quest 5, but Tim’s game was written for Quest 4, which is effectively a completely different system (although sharing some of the same design). So the first thing to do was convert a Quest 4 game into a Quest 5 game.

I wrote a converter application which converts most of a game correctly, although there were still a few manual tweaks to do – even some Quest 4 bugs to emulate! What really helped was to have a complete walkthrough for the game – Quest 4 has a “transcript” feature which is similar to Quest 5′s walkthrough feature. This meant I could have Quest 4 and 5 automatically play the game through to completion, and compare the output, fixing things as I went along.

I then sent Tim the converted Quest 5 game, and he made a few more tweaks and corrections. He also adapted the game to make better use of hyperlinks – something which is really important for the smartphone version of the game. Tim’s enhancements mean it is possible to play the game through in its entirety, without having to type anything.

By the way, now that I have an internal Quest 4 to Quest 5 conversion tool, please get in touch if you have an old game you’d like to convert. The conversion isn’t perfect (which is why this won’t become part of Quest itself), but it can get you most of the way.

Re-engineering Quest

The next step was to convert Tim’s enhanced Q5 version of the game to Javascript, using the converter which I announced back in September. I’d thought the converter was 90% done, but as is the case with so much in the software world, the last 10% took far longer than the first 90%.

The main difficulty has been threading. Javascript is single-threaded, which means you can’t pause a running thread while you wait for some user input. This meant I needed to re-work all of Quest’s functions for displaying menus, waiting for keypresses, asking questions etc. The result of this is new asynchronous versions of various functions, which are implemented in Quest 5.1 and used by the Core Library, as the old synchronous versions of the functions cannot be converted to Javascript.

Being unable to block the thread to display a menu meant that I had to rewrite the parser, as this often needs to display menus to resolve the typed-in object names. I drew myself the diagram below and almost descended into insanity in the process:

So, that was annoying, but it’s actually a better design for the future (especially when playing a game via the web, as the server will no longer need to keep a thread hanging around if it’s waiting for the user to respond to a menu).

Eventually I had a pure HTML/JS version of the game which could be played in any web browser. I implemented the walkthrough feature to verify the game was working correctly, and again I sent it to Tim so he could check for any “off-walkthrough” problems.

Performance

Now the game was working in HTML/JS, it was straightforward to wrap it in Phonegap and create a functioning app. Even here there were unexpected problems – although the app ran at a respectable speed on my iPhone 4, when I ran it on my old iPhone 3G I was horrified to find that it would sometimes take 10 seconds to respond to a command. The fix was again some re-engineering of Quest 5 and the Core Library, this time adding the ability to cache regular expressions, and improving the performance of the scope functions.

Saving

The desktop/web version of Quest 5 saves games by writing out the entire game state. The JS app version takes a different approach, saving a delta instead – only changed attributes are saved to local storage. This is quicker, requires much less local storage, and also means that the app can be safely updated without breaking existing games. The delta is automatically saved after each turn. Again I found some performance issues here, so it took a bit of time to get this right. With a Phonegap app on the iPhone, you get no warning if your app is going to be terminated, so I had to make saving robust enough that it wouldn’t break things horribly if the game started saving but never finished (instead, there are effectively two save slots that are used alternately, so the worst that can happen is you lose one turn).

Android

By now I had the game working pretty well on iOS, and sent it to a few beta testers using TestFlight, which I highly recommend as it takes much of the pain out of ad-hoc distribution on the iPhone. I thought it would be a good idea to get it working on Android too, and I was pretty pleased when only two days after I took delivery of the cheap but surprisingly capable Samsung Galaxy Ace, I had a version that worked on that too.

The Android version looks pretty similar to the iOS version. There is no NativeControls plugin for Android, and Android doesn’t “do” iOS-style tabs at the bottom of the screen anyway, but it didn’t take long to create a native menu which can be used to switch between screens instead. When tapping an object link, I had to create a Javascript menu to display the verbs, but that was only a small amount of work too, made relatively easily using a jQuery UI dialog.

I was pleased with the overall Android development experience – it seems so much more developer-friendly than iOS. The documentation is laid out in a way that a mortal can understand, and it’s so much easier to send a build to beta testers – just email an APK file. Much more pleasant than dealing with certificates and distribution profiles on iOS.

Ready

So it is now ready – the first Quest-powered iOS and Android app, which is also my own first app for these platforms. The iOS version has been submitted to Apple, and I’ll submit the Android version as soon as it’s approved, so both versions will be available on the same day – watch this space!

Quest 5.0.1 released

Written October 13th, 2011 by
Categories: Quest 5
2 comments

The first bug-fix release of Quest 5 is now available – download Quest 5.0.1 here.

I’m pretty pleased that nothing too major was discovered in the v5.0 release, so thanks once again to the beta testers!

Here’s what’s new and what’s fixed:

  • New feature: Players can now customise fonts and colours for a game from the new Options window.
  • New feature: Container “open” and “close” messages can be customised per container.
  • Improved: More useful error messages if Quest can’t load a game file due to an error in one of your scripts.
  • Fixed: Various issues with Quest 4 games – locked exits in CAS files, sounds in ZIP files, and timers running at the wrong time.
  • Fixed: Memory leaks in the Editor which could cause Quest to hang when switching to/from the Code View with large games.
For the full list, see the Closed Quest 5.0.1 Items on the Issue Tracker.

Quest 5.0 is out now

Written August 30th, 2011 by
Categories: Quest 5
5 comments

Quest 5.0 is now available! Download it now.

A brand new system for creating text adventures

Quest 5 is more than just an upgrade from Quest 4 – it is a completely new system, rewritten from scratch. I started work on it around April 2009, and the first preview version was released in February 2010. In October 2010, I announced that the system was to be free and open source. And in April 2011, I decided to increase the pace of development – quitting my job to work on Quest full-time.

Easy to use, powerful, flexible

Compared to Quest 4, the new system is much more powerful, flexible and robust – and I believe it’s even easier to use. The standard game behaviour is written in Quest itself, which means it is completely customisable. New features include support for “undo” when playing games (and also undo/redo in the Editor), expressions, local variables, lists and dictionaries – if you used Quest 4 you’ll want to check out the Upgrade Notes.

Compared to other systems, I had several objectives. Many of these are the same objectives I’ve always had for Quest, but the rewrite has made it possible for me to finally do them properly:

  • Easy to create games. It’s easy to get started creating games with Quest 5. The visual editor is designed to be intuitive – everything is shown in plain English, and the aim is that features are easy to find by exploring the menus and tabs. You don’t need to learn programming syntax, or spend time trying to get the system to understand you. I believe that no other system is as easy to get started with.
  • Easy to play games. I would guess that the vast majority of people in the world have never played a text adventure game. Quest is designed so that new players should be able to easily figure out how to play – see my earlier blog post on Eliminating “Guess the Verb”.
  • Powerful. Behind the visual editor is a fully featured programming language. This means that although Quest is easy to learn, it doesn’t restrict what is possible. See my earlier blog post about the design of the Script Editor.
  • Modern. I believe we should try to think of text adventure games as a new format. Many people, particularly those under 30, give me a worryingly blank look when I say I’m trying to revive the text adventure – they don’t remember them in the first place. So there is no sense in trying to emulate the 1980′s. The modern text adventure must be part of the web – it must be possible to play games in a browser, and easily share links to them. Games should be able to embed anything on the web – links, pictures, sounds and YouTube videos can all be part of the modern text adventure experience. Quest games use HTML and Javascript whether they’re being played online or offline, which means they can be integrated with websites, and there is also the potential to create innovative new user interfaces for games. No other system offers this flexibility.
  • Shareable. It’s fairly pointless making games if other people don’t play them. Quest makes it easy to download and play games with its integrated game browser – there’s no need to visit a separate site, as you can easily download games directly inside the application. When you create a game and upload it to textadventures.co.uk, other people can play online in their web browser – there is no need for them to download any software, so they can play a game on Windows, Mac and Linux – even iPhone, iPad and Android, though there is still some work to be done to make the site easy to use with those devices. No other system makes it this easy for you to share your creations.
  • Flexible. Quest is fully open source, and under a fairly permissive licence (Ms-PL, which is similar to the MIT licence). This means you can use and adapt Quest for use in closed source applications, to create desktop games or to power websites. No other system lets you do this.
  • International. Quest 5 supports multiple languages. Out of the box, you can create games in English, French, German, Spanish or Dutch. Quest’s standard text comes from one file, meaning it is straightforward to create your own translation.
But don’t take my word for it, download it now and see for yourself.

This is just the beginning

There are many more things I want to add to Quest, but “shipping is also a feature” as they say – I thought it was important to get something of release quality “out there” as soon as I could. The Issue Tracker will give you some idea of what is coming up – there are currently a large number of features assigned to a future “Quest 5.1″ release, though this is quite a long list at the moment so I would expect a lot of those features to be pushed back to later releases.

In addition to the features listed on the Issue Tracker, there are some other Quest projects in the pipeline:

  • Linux and OS X versions of the desktop Player (and eventually, the Editor)
  • iPhone- and iPad-friendly versions of the web Player – maybe also native applications
  • “Simple mode” for the Editor, to make it even easier (particularly for children) to create games with Quest
  • Possibly a web-based Editor
  • Improvements to the textadventures.co.uk site – better profiles, editing existing game listings, improvements to categories, easier embedding of games in other websites, game analytics (e.g. what percentage of people complete your game), non-public games (i.e. not listed in the categories but you can still share the game via a link)
  • Integration of Quest with e-learning systems such as Moodle
If you have any other suggestions please let me know!

You can help

I quit my job to make Quest but I don’t really have a business plan – my primary motivation is really just that I want the software to exist. If it brings opportunities my way, that’s marvellous (and if not, it’s all good for my CV/resumé – I’m not completely nuts). So if you have a particular project in mind, please get in touch. Maybe you’d like me to do some custom development for you? Maybe you’ve seen a feature on the Issue Tracker you would like to sponsor?

Or if you would simply like to express your gratitude, if you think this software which I am giving away is worth something, I am of course happy to accept donations too, large or small.

If you don’t want to contribute money, there are other ways to show your appreciation – get involved! Quest isn’t just “my” project any more – as it’s open source, I’m happy to accept code contributions and translations. All feedback is very useful, so please report any bugs you find using the Issue Tracker, make suggestions at Uservoice, and join in the forums. You can also email me at alex@axeuk.com or tweet me @alexwarren.

Thanks

Many thanks to everybody who has made suggestions, posted bug reports, contributed features and translations. I don’t even know some of your real names. In no particular order, thanks to Stephen Hart, Jhames, Pertex, Jonathan Dobson, ThePixie, Xordevoreaux, Lina Anna, Guillaume Poulain, and anyone else I’ve forgotten!

Keep up to date

To keep up to date:

  • Join the mailing list for release announcements
  • Follow @TextAdv on Twitter for Quest announcements and game releases
  • Follow @alexwarren on Twitter for Quest announcements and other thoughts

Download Quest 5.0 now

Quest 5.0 Release Candidate 2

Written August 9th, 2011 by
Categories: Quest 5
7 comments

Inevitably, a few bugs were logged against last week’s Release Candidate 1, so I’ve now fixed them and uploaded a new Release Candidate 2, which you can download here.

The biggest bugs fixed were that the Exits tab wasn’t showing existing exits, and a memory leak that could cause a hang after switching back and forth in the Code View after making edits. See the issue tracker list for full details.

The only thing that might remotely be called a new feature is the ability to translate the labels for the panes in the language template.

I’ll be up in Edinburgh watching comedy for the next week, which will be nice as London has descended into rioting as I type this – I’m drowning out the sound of distant sirens with some soothing music, so it will be nice to get away from it for a few days (presuming it doesn’t spread to Edinburgh too). If only we could persuade these kids to sit quietly indoors playing text adventures instead. Anyway, I’ll be checking my emails and the forums but may be slower to reply than usual.

When I get back I’ll fill in the remaining gaps in the documentation, fix any bugs that have been logged and then we’ll be ready to go!

Twitter: @alexwarren

Quest 5.0 Release Candidate 1

Written August 4th, 2011 by
Categories: Quest 5
6 comments

In the week since Beta 4 was released, 24 issues have been closed on the Issue Tracker, most of which have been relatively minor bugs. I have reached the magic zero mark again, so it’s time for the first release candidate, which you can download now.

A few minor features did make it through:

  • Quest now uses the JAWS API to speak all text aloud if you’re using the JAWS screen reader
  • It’s now easier to lock and unlock exits from a script
  • You can look in directions (contribution by Stephen Hart)
  • You can now edit “ask” and “tell” topics
  • It’s now easier to disable the object panes
  • Objects can now be cloned by a script
  • Added a function to tell if an object inherits a particular type
Being a release candidate means in theory that if no bugs are found, I won’t need to update the setup file for the final release – this could be the one. I do expect there will probably be more bugs logged over the coming week or so though, and I still need to update the documentation, so I’m not saying “this is it!” just yet – I expect that the final release will be available towards the end of August.