Compare commits

...

2 Commits

Author SHA1 Message Date
6e93d8628f Bug fixes and improvements
* Added dev skip for cardgame for testing purposes (I swear!)
* Fixed missing achievement triggers for 'Mad Hatter' and 'Poster Boy'
* Fixed cardgame twins challenge being inaccessible
* Fixed colour picker invoking non-existing image outside wardrobe scope
* Disabled cardgame easter egg (broken, requires refactoring)
* Improved cardgame hints
* Improved cardgame event handling
* Fixed grammar
2023-07-08 21:44:47 +01:00
2f136986e2 Bug fixes
* Fixed character cheeks and tears layers being stuck in both gameplay and character studio
* Fixed missing reset properties during end event labels
* Improved updater hint for potential edge cases
2023-07-08 21:44:47 +01:00
20 changed files with 92 additions and 28 deletions

View File

@ -26,6 +26,7 @@ label end_astoria_event:
$ states.ast.busy = True
$ astoria.wear("all")
$ astoria.set_cum(None)
$ astoria.set_face(tears=False, cheeks=False)
call music_block
jump main_room_menu

View File

@ -22,6 +22,7 @@ label end_cho_event:
$ states.cho.busy = True
$ cho.wear("all")
$ cho.set_cum(None)
$ cho.set_face(tears=False, cheeks=False)
call music_block
jump main_room_menu

View File

@ -19,6 +19,7 @@ label end_hermione_event:
$ states.her.busy = True
$ hermione.wear("all")
$ hermione.set_cum(None)
$ hermione.set_face(tears=False, cheeks=False)
call music_block
jump main_room_menu

View File

@ -162,7 +162,7 @@ label hg_tutor_E1:
call her_walk("door", "base")
her @ cheeks blush "{size=-4}(I'm glad professor agreed to tutor me!){/size}" ("base", "happyCl", "worried", "mid", xpos="base", ypos="head", flip=False, trans=d3)
her @ cheeks blush "{size=-4}(I'm glad the professor agreed to tutor me!){/size}" ("base", "happyCl", "worried", "mid", xpos="base", ypos="head", flip=False, trans=d3)
her "{size=-4}(But pleasure and pain? I don't understand where this is going...){/size}" ("annoyed", "base", "base", "R")
her "{size=-4}(And what other students is he tutoring?){/size}" ("annoyed", "base", "worried", "L")

View File

@ -10,6 +10,7 @@ label end_hooch_event:
$ states.hoo.busy = True
$ hooch.wear("all")
$ hooch.set_cum(None)
$ hooch.set_face(tears=False, cheeks=False)
call music_block
jump main_room_menu

View File

@ -12,6 +12,8 @@ label end_luna_event:
$ states.active_girl = None
$ states.lun.busy = True
$ luna.wear("all")
$ luna.set_cum(None)
$ luna.set_face(tears=False, cheeks=False)
call music_block
jump main_room_menu

View File

@ -11,6 +11,8 @@ label end_susan_event:
$ states.active_girl = None
$ states.sus.busy = True
$ susan.wear("all")
$ susan.set_cum(None)
$ susan.set_face(tears=False, cheeks=False)
call music_block
jump main_room_menu

View File

@ -32,6 +32,7 @@ label end_tonks_event:
$ states.ton.busy = True
$ tonks.wear("all")
$ tonks.set_cum(None)
$ tonks.set_face(tears=False, cheeks=False)
call music_block
jump main_room_menu

View File

@ -4,7 +4,6 @@
default states.twi.ev.cardgame.known = False
default states.twi.ev.cardgame.stage = 0
default states.twi.ev.cardgame.first_random = True
default states.twi.ev.cardgame.delay = 7
default states.twi.ev.cardgame.stocked = False
default states.twi.ev.cardgame.stock_talk = False
default states.twi.ev.cardgame.interest = False

View File

@ -120,11 +120,6 @@ label quests:
# CARDGAME - EVENTS
#
if game.day >= states.twi.ev.cardgame.delay:
if states.cardgame.unlocked and states.twi.ev.cardgame.stage >= 1 and not states.twi.ev.cardgame.stocked:
if not game.daytime:
$ letter_cards_store.send()
if geniecard_level < 2 and states.sna.ev.cardgame.stage >= 3 and states.her.ev.cardgame.stage >= 3 and states.twi.ev.cardgame.stage >= 2:
if not game.daytime:
$ letter_cards_tier2.send()

View File

@ -36,9 +36,6 @@ screen color_picker(color, alpha, title, pos_xy, color_default):
# Set HSVA variables based on RGBA when screen shows
on "show" action Function(color_picker_update_hsva)
if not renpy.get_screen("wardrobe"):
add "confirm_fade"
frame:
style_prefix gui.theme()
if pos_xy and False:

View File

@ -112,7 +112,8 @@ label letter_cards_unlock:
default letter_cards_store = Letter(
text = "{size=-7}Weasley's Wizard Wheezes shop emporium is now officially partnering with Wizard cards.\nVisit our shop for the best deals on card packs in all of Hogwarts!{/size}",
label = "letter_cards_store"
label = "letter_cards_store",
wait = 7
)
label letter_cards_store:

View File

@ -8,7 +8,7 @@ default tutorial_dict = {
"points": ["House Points", "House points are awarded to students for excelling in their assignments. You can manipulate the points system directly by awarding points to students for completing their tasks, or by befriending the teachers.\n\nSome characters may care about house points more than others so keep that in mind.", False],
"map": ["Navigation", "The map allows you to traverse the castle by clicking on one of the icons. Highlighted areas indicate a new event on that location. You can access the map from within the desk menu.", False],
"time": ["Passing Time", "There are many activities you may do at Hogwarts, but occasionally there might not be much to do.\nIf this is the case then you can pass time by clicking on the {color=#204997}{b}pass time button{/b}{/color} located in the top-right corner.\n\n{size=-2}Or you could always rub one out for old time's sake. The choice is yours.{/size}", False],
"mail": ["Mail", "Owls will occasionally bring you letters or parcels. Click on the owl or parcel to interact with it.\n\nUnlike mail pidgeons, owls are tidy creatures and won't shit all over your floors. Theorethically...", False],
"mail": ["Mail", "Owls will occasionally bring you letters or parcels. Click on the owl or parcel to interact with it.\n\nUnlike mail pidgeons, owls are tidy creatures and won't shit all over your floors. Theoretically...", False],
"brewing": ["Potions Brewing", "Brewing potions wasn't always an easy task, but thanks to Magic Cauldron incorporated (TM), the entire process became automated. Once you have the required ingredients in your inventory, simply click on the {color=#204997}{b}cauldron{/b}{/color} to make the desired potion.", False],
"milestones": ["Relationship milestones", "Every milestone is a chance to level up your bond with your virtual companion, leaving your real love life in the dust. Instead of boring old XP, you'll earn a boatload of (s)ass. Now that's what I call an upgrade! No need to go through any awkward first date chat, just advance to the next level.\n\nChoosing this option will progress their story and unlock more favours and events.\n\nBut beware, once you commit, old favours become inaccessible and are replaced with new ones. You may wish to postpone it until you exhaust all content you wish to see on the current level. So choose wisely, my friend.", False],
}

View File

@ -99,6 +99,23 @@ init python:
selectenemycard = -1
return "NewTurn"
elif _return == "skip_win":
renpy.show_screen("card_end_message", "You win!")
renpy.sound.play("sounds/card_win.ogg")
renpy.pause(3.0) # Pause before end
renpy.hide_screen("card_end_message")
renpy.hide_screen("card_battle")
renpy.transition(dissolve)
return "win"
elif _return == "skip_lost":
renpy.show_screen("card_end_message", "You lost...")
renpy.pause(3.0) # Pause before end
renpy.hide_screen("card_end_message")
renpy.hide_screen("card_battle")
renpy.transition(dissolve)
return "lost"
else:
if not selectcard == -1:
renpy.sound.play("sounds/card.ogg")
@ -248,6 +265,11 @@ screen card_battle(l_playerdeck, l_enemydeck, shown_cards):
if not selectenemycard == -1:
use cardrender(l_enemydeck[selectenemycard], 860,17+80*selectenemycard, backside= shown_cards[selectenemycard])
if config.developer:
vbox:
textbutton "Dev skip (win)" action Return("skip_win")
textbutton "Dev skip (lose)" action Return("skip_lost")
use close_button
transform cardrender_move(xpos_card, ypos_card, start_xy):

View File

@ -139,13 +139,13 @@ screen deck_builder_screen():
keysym "game_menu"
#Easter egg
hbox:
xpos 1020
ypos 296
xsize 40
ysize 40
button action Jump("color_change") background "#ffffff00"
#add Solid(get_hex_string(playercolor_rgb))
# hbox:
# xpos 1020
# ypos 296
# xsize 40
# ysize 40
# button action Jump("color_change") background "#ffffff00"
# #add Solid(get_hex_string(playercolor_rgb))
screen deck_builder_gallery():
zorder 8

View File

@ -28,8 +28,9 @@ label twins_first_duel:
fre "So you better get ready for a rematch!"
twi "Because we'll win next time!"
gen "We'll see about that... I can't have students going around showing up to their headmaster, can I?" ("base", xpos="far_left", ypos="head")
$ states.twi.ev.cardgame.stage = 1
$ states.twi.ev.cardgame.delay = states.twi.ev.cardgame.delay+game.day
$ letter_cards_store.send()
pass
else:
twi "Not again..."

View File

@ -90,4 +90,19 @@ label purchase_item(item):
$ game.gold -= item.price
$ item.owned += 1
$ item_store_achievements()
return
init python:
def item_store_achievements():
# We require a function because lambdas aren't pickleable
if isinstance(item, Decoration):
_posters = filter(lambda x: (x.type == "decoration" and x.placement == poster_OBJ), inventory.items)
_hats = filter(lambda x: (x.type == "decoration" and "hat" in x.name.lower()), inventory.items)
if all(i.owned > 0 for i in _posters):
achievements.unlock("postman")
if all(i.owned > 0 for i in _hats):
achievements.unlock("hats")

View File

@ -203,9 +203,13 @@ label item_store:
menu:
"-First Duel-":
jump twins_first_duel
"-Challenge-" if states.twi.ev.cardgame.stage > 1:
"-Challenge-" if states.twi.ev.cardgame.stock_talk:
jump twins_second_duel
"-You need to beat the first duel-" (style="disabled") if states.twi.ev.cardgame.stage < 1:
"-You need to beat the first duel-" (style="disabled") if not states.twi.ev.cardgame.stock_talk:
if states.twi.ev.cardgame.stage < 1:
gen "(I should beat them at their own game at least once before I try this again...)"
elif not states.twi.ev.cardgame.stock_talk:
gen "(I need to wait for a letter from them before we can continue...)"
jump twins_duel_menu
"-Never mind-":
twi "Your loss professor."

View File

@ -22,7 +22,14 @@ init python:
global UPDATE_VER, UPDATE_HINT
if (not updater.can_update() or config.developer) and not self.simulate:
if (config.developer or not updater.can_update()) and not self.simulate:
if config.developer:
UPDATE_HINT = "Updater is disabled."
else:
UPDATE_HINT = "Cannot fetch updates."
renpy.restart_interaction()
return
check = True
@ -106,6 +113,15 @@ init python:
j.group = objects
j.is_stale()
# Fix cardgame events
delattr(states.twi.ev.cardgame, "delay")
if states.twi.ev.cardgame.stage == 1 and not states.twi.ev.cardgame.stock_talk and not letter_cards_store in mailbox.letters:
# In case the player already started the event chain, send the letter early.
letter_cards_store.send()
getattr(store, "letter_cards_store").wait = 7
if current > latest:
raise Exception("Loaded save file is incompatible. (Save Version: {}, Game Version: {})".format(current, latest))

View File

@ -30,7 +30,12 @@ init python in studio:
fp, fn = os.path.split(f)
fn, ext = os.path.splitext(fn)
expression = os.path.split(fp)[1]
expressions = d.setdefault(charname, _dict()).setdefault(part, _list((None,)))
if part in ("cheeks", "tears"):
expressions = d.setdefault(charname, _dict()).setdefault(part, _list((False,)))
else:
expressions = d.setdefault(charname, _dict()).setdefault(part, _list())
if not fp.startswith(path) or not ext in extensions:
continue
@ -48,8 +53,8 @@ init python in studio:
d[i]["eyes"] = faces[i].get("eyes", [None]).index("base")
d[i]["mouth"] = faces[i].get("mouth", [None]).index("base")
d[i]["pupils"] = faces[i].get("pupils", [None]).index("mid")
d[i]["cheeks"] = faces[i].get("cheeks", [None]).index(None)
d[i]["tears"] = faces[i].get("tears", [None]).index(None)
d[i]["cheeks"] = faces[i].get("cheeks", [False]).index(False)
d[i]["tears"] = faces[i].get("tears", [False]).index(False)
d[i]["zoom"] = 0.5
d[i]["flip"] = 1
d[i]["alpha"] = 1.0
@ -143,8 +148,8 @@ init python in studio:
choices[drag.char_name]["eyes"] = faces[drag.char_name]["eyes"].index("base")
choices[drag.char_name]["mouth"] = faces[drag.char_name]["mouth"].index("base")
choices[drag.char_name]["pupils"] = faces[drag.char_name]["pupils"].index("mid")
choices[drag.char_name]["cheeks"] = faces[drag.char_name]["cheeks"].index(None)
choices[drag.char_name]["tears"] = faces[drag.char_name]["tears"].index(None)
choices[drag.char_name]["cheeks"] = faces[drag.char_name]["cheeks"].index(False)
choices[drag.char_name]["tears"] = faces[drag.char_name]["tears"].index(False)
choices[drag.char_name]["zoom"] = 0.5
choices[drag.char_name]["flip"] = 1
choices[drag.char_name]["alpha"] = 1.0