Sorry your browser is not supported!

You are using an outdated browser that does not support modern web technologies, in order to use this site please update to a new browser.

Browsers supported include Chrome, FireFox, Safari, Opera, Internet Explorer 10+ or Microsoft Edge.

Geek Culture / Visual novel game logic

Author
Message
Lukas W
13
Years of Service
User Offline
Joined: 5th Sep 2003
Location: Sweden
Posted: 10th Dec 2016 14:01
I was just toying with the idea of writing one, and it got me thinking that I had no idea where to start. So I searched google for some tips, but all it gives me is software to buy or (even) free software. That is not what I needed because I wanted to know how they work internally. So I open up notepad...

+ Code Snippet

Assuming everything is stored in an array ex. DATA[ SCENE_ID, FRAME_ID ]. I could build the game like that DATA[ 0, 0 ] = "[snd|night.wav|l] Yo listen up here's a story, about a little guy that lives in a blue world[w]".
Which, using some string manipulation - grabs the "commands" and turns them into whatever the hell they are supposed to do while all other text displays one char at a time using 'text_speed'.

But I got stuck here, how would I handle a branching storyline? Because using that shitty method would (probably...) work flawlessly for a linear story only.
To "jump" from one frame (the frame that asks players choice) to another frame that continues that storyline is probably viable, but meh.. to me it does not seem like it would do any good - and quite possibly only make a complete mess of a cluster of scenes and frames that I would eventually forget what they do. I guess writing an editor could help, huh. Tsk, this is more work than I imagined.

Any tips?
IS that a game, a program, or 3 year old drawing.
Lukas W
13
Years of Service
User Offline
Joined: 5th Sep 2003
Location: Sweden
Posted: 10th Dec 2016 20:48
What, I don't remember this forum was so quiet Well it doesn't matter; I still did not decide if I want to try and make one yet.
IS that a game, a program, or 3 year old drawing.
Seppuku Arts
Moderator
12
Years of Service
User Offline
Joined: 18th Aug 2004
Location: Cambridgeshire, England
Posted: 11th Dec 2016 16:23 Edited at: 11th Dec 2016 16:25
We are quieter than we used to be. I did come across a good Text Adventure tutorial way back, when trying to learn C#, it might have the kind of logic you're looking for. https://www.3dbuzz.com/training/view/xna-volume-1/hyperion-text-adventure-game

It is in their XNA section, but actually just uses core Visual C# and a console project.

If I recall, it goes along the lines of treating it as entering rooms and areas. So rather than scenes, you are traversing across different rooms and that would be where player choice comes into it. Perhaps think of it like programming a Point and Click Adventure without the graphics. You have different exits and each room will contain various items, people and you can have a description of each, including the scene.

If you are translating that into a story, you would perhaps follow the same principle, but each "exit" is a different path the player can take in the story. Maybe think of it like a grid or a tree, how a player can traverse. Hmm, maybe if you are branching, maybe take some inspiration from Git? Given it is a version control program that focuses on a branched approach, might put you in the right frame of mind? Maybe if you are programming it, you could include "BRANCH" into your array.


It can potentially get more and more complicated you branch, depending on how complicated you're wanting to work the story logic.

The other approach could be to work in a 2D or 3D grid and traverse the story as you would in a 2D or 3D space, but I think that's more traditional text adventures rather than a visual novel branching.

But in taking the inspiration from Git Branching. Here is a visual representation:



And this is how you might lay it out in your story?




I guess programmatically, you'll want to still create an array, but for the branch, I wonder if we can store it as a float or a string. I suspect this will be the difficult part with arrays.


I might look at it from dealing with objects (if you're thinking DBP, you can simulate something that works with a similar logic using custom data types, but just takes more work to get running, as you can only store variables this way and not methods). So instead of "Scene 1, Frame 1" go for:

Scene1.Branch(1.2) = "Hello world, is it me you're looking for?"

In my head, the above is actually a method, rather than an array or variable.

In fact, I would probably break it down like this;

Scene1.AddBranch(float BranchID, string Frame)
currentFrame = Scene1.GetBranch(float BranchID)

In "AddBranch" you can have a fallback, should your Branch ID already exist, throw up an error, so you don't end up with accidentally creating a duplicate. You'll have an array you can insert into and store a float, perhaps into something like "Branch[0].id". Then add the string for the part of the story you want.
In "GetBranch" you pull out the string you need to progress the next part of the story.

So an active example might be:

Scene1.AddBranch(1.1, "Hello world, is it me you're looking for?")
Scene1.AddBranch(1.12 "Okay then...")
currentFrame = Scene1.GetBranch(1.1)
if (player.input = "Go Away Lionel") then currentFrame = Scene1.GetBranch(1.12)

If each frame can be labelled, you could replace the floats with strings, but I figure in branching, floats might be easier to some extent, especially if you've got a reference for each bit for it to make sense. I guess it could end up more complicated with each part, but I guess it can be tweaked to get less confusing, as I'd imagine 1.3311234221 would be harder to follow. I know Git has a label & an ID for branches, so maybe it'll make more sense that way. At least the pseudo code above can easily be made to work that way, as "Get Branch" searches for an ID by a value and not by asking for a specific ID.

Login to post a reply

Server time is: 2017-03-28 07:16:28
Your offset time is: 2017-03-28 07:16:28