Creating a World for a Text/Menu based Life Sim/RPG
I was thinking something like a 'city' class that contains a list of building objects, which in turn contain rooms objects. Would this be simple enough? Sorry for my basic use of terminology, just trying to keep it simple enough that I can still understand it.
Thanks in advance for any help that you can provide.
Ultimately, you are the only person that can decide if it is simple enough for you. However, the fact that you ask about it, rather than know the answer, suggests to me, it's too complicated at this point.
There is no shame in starting very small. Less elements means less things going on at the same time, so better chance in understanding.
A second point is that I don't see what "city" or "building" adds. Basically, interaction happens between or more persons in the same room, or one person in one room (if you can interact with the room itself). So, maybe you should ask yourself how "two rooms in one house" is relevant, and how "two houses in one city" is relevant (in interacting).
I never considered writing this kind of program, but maybe a good starting point is a single room. One person interacting with the room, and then two persons in the same room interacting.
You'd get experience in how these things work, and some building blocks to scale up later to cities, the world, and ultimately, the universe!
(ho wait, that was about ruling worlds, never mind ;) )
Not trying to be difficult or hostile, just having conversation
You HAVE been.
@Alberth was only trying to help based on very little information he had.
If he mis-understood you in any way, take that as an opportunity to explain your situation and the help you need more politely
can't help being grumpy...
Just need to let some steam out, so my head doesn't explode...
Fair enough, but in my experience, the biggest thing you'll learn is that you get very solidly stuck, and get terribly frustrated by it.I don't necessarily agree with the notion that because someone has to ask a question about something means it's too complicated for them. How is one supposed to learn anything if that's the case?
If you continue programming, you'll get plenty opportunities to take a too big bite, no need to look for it
You didn't mention this in your first post, so how was I to know that?But that aside, I do plan on stating small, like one room at a time, but I want to structure this in a way that I can build on it, rather than rewrite everything when I am ready to move forward.
The strategy itself is sound, except you may be putting too much emphasis on re-using the code (but that is normal).
In my experience, the thing that really counts is not the code with the solution, the method of solving is what is really important.
Once you know that, you can rewrite the code in a few hours to a day. When I do that, the code usually also improves until the 3rd or 4th rewrite, as you have the room to start again but you have better knowledge where you want to go.
I meant in terms of interaction. I can see two persons in one room interacting with each other (which I guess is a large part of the game). I cannot see one person in one room, and another person in another room, interacting with each other (other than by a quite limited thing called 'phone').I am not understanding the next part of your reply. 'Two houses in one city' is relevant because the cities will (hopefully) eventually be filled with more people with their own houses. 'Two rooms in a house' seems relevant because different rooms will serve different functions (bedroom, kitchen, bathroom, etc.)
As such in terms of interaction, multiple rooms or multiple houses don't look very relevant to me, it's just (many) more two-persons-in-one-room cases that happen at the same moment in time.
(But you probably have thought about things a lot longer than me, you may be able to point out a flaw in my reasoning.)
Not sure where that is coming from, but I have no hostile intentions.Not trying to be difficult or hostile, just having conversation.
It's just that a text-only medium with smileys as only way to express emotions, has a lot of room for misunderstanding. I write text that I believe to be completely understandable, but you interpret it differently from my intended direction. That's not my fault (other than having to try better), and it's not your fault, it's just the medium that makes communication very difficult. This also happens the other way around; your remarks and questions get interpreted in ways you don't expect.
The only way to solve this is to try be more clear in what you mean in follow-up posts.
I would suggesting considering if there is a difference other than data between a city, building and room and then consider if there is a need for separate classes. It would seem to me that each of "city", "building" and "room" could actually be done with one "location" class that can contain other locations (which could be none). This way you could the add additional "levels" to your structure such as building being made up of floors, cities made up of districts, states made up of cities, etc. without having to create additional classes for each type.
I don't know how much programming experience you have, but I'll suggest that before you start planning out a city and filling it with things you try a single room. Then implement some of the things you'd like to simulate, like interacting with another person in the room. After that add a second room, and implement the features that multiple rooms would require, like the ability to move between them, update a room while the player is not there, etc.
It's amazing how many design steps you can miss when you start with content in a type of program you haven't written before. I've been amazed by it in my own projects.
If you are going to stick with the design as you've laid it out (and for all I know you already have all the details planned for how everything will fit together), it may be better to use a more general Location class as Dragoncar suggested. But your needs and style will inform the specific design approach you use, and there is always more than one way to accomplish a programming task. The right way is a way that works, and you can refine things after the basics are running.
-------R.I.P.-------
Selective Quote
~Too Late - Too Soon~
I definitely intend to start small with a single room, and start working my up from there
Thanks for the additional replies!