Need Help w/ Simple Hunger & Thirst System for Single Player
[Deleted User]
Posts: 0
I'm trying to make a simple Hunger & Thirst System for a Single-Player module that does the following:
I found this function by @Proleric
int bhHour() {return ((GetCalendarYear() - 1) * 12 * 30 * 24) + ((GetCalendarMonth() - 1) * 30 * 24)
+ ((GetCalendarDay() - 1) * 24) + GetTimeHour();}
And used it to set the start time in the module's pre-enter using
SetLocalInt(oPC, "StartHour", bhHour());
I can fudge my way through most of it, BUT how do I use this function to check for elapsed time? I just can't wrap my head around it.
- If the PC goes without water for more than a day - take 1 point of damage each day from dehydration.
- If the PC goes without food for more than a day - set a variable that marks starvation level and after starvation level hits 3, the PC takes 1 point of damage each day
- Drinking from Waterskin resets timer
- Eating food resets timer
I found this function by @Proleric
int bhHour() {return ((GetCalendarYear() - 1) * 12 * 30 * 24) + ((GetCalendarMonth() - 1) * 30 * 24)
+ ((GetCalendarDay() - 1) * 24) + GetTimeHour();}
And used it to set the start time in the module's pre-enter using
SetLocalInt(oPC, "StartHour", bhHour());
I can fudge my way through most of it, BUT how do I use this function to check for elapsed time? I just can't wrap my head around it.
0
Comments
Subsequently (checking on heartbeat or whatever) elapse time in hours is bhHour() - T1.
When that goes over 24, apply penalty.
After drinking,
The script foobar will run 24 game hours later to apply penalties if LastDrinkTime was 24 hours ago (but do nothing if the timestamp has been updated by drinking in the meanwhile).
Personally, I feel a little uncomfortable with delaying scripts for very long periods, preferring to check regularly to shut down unwanted delayed scripts, but this is probably irrational on my part as I haven't actually encountered any problems with it.
The PC has 480 Thirst Charges (24 hours) and 1440 Hunger Charges (72 Hours). Every Module Heartbeat, the number of charges is reduced by 1. When the charges reach 0 the effect is applied and the charges are reset to 20 (1 hour) for the Thirst Charges and 480 (24 hours) for the Hunger Charges.
Eating and drinking somethings resets the charges to their initial values.
Using charges I can also make adjustments for the quality of the food and drink, amount, etc. Probably not the best method, but I can understand this stuff well-enough.
If you're thinking of publishing for general use, strictly speaking 480 should read ((24 / 6) * HoursToSeconds()) and so on, because the module author can alter the Minutes per Hour in module properties.
Perhaps other readers can confirm whether the assumption of 6 seconds per heartbeat is precisely reliable. It feels more natural to me to refer to the game date directly, especially since some of my timed quests run for game weeks, where a discrepancy could become visible to the player... but I'm probably being hypervigilant.
I'm not planning on publishing for general use - the Hunger/Thirst is module specific. Thus, I can tweak it easily enough if I change the game clock settings in the module properties.