use splicers from field

This commit is contained in:
infinitefusion
2023-05-07 18:20:17 -04:00
parent aa1199f6e2
commit e3dd66e067
2 changed files with 64 additions and 33 deletions

View File

@@ -399,7 +399,6 @@ ItemHandlers::UseInField.add(:DREAMMIRROR, proc { |item|
next 1 next 1
}) })
ItemHandlers::UseFromBag.add(:MAGICBOOTS, proc { |item| ItemHandlers::UseFromBag.add(:MAGICBOOTS, proc { |item|
if $DEBUG if $DEBUG
if Kernel.pbConfirmMessageSerious(_INTL("Take off the Magic Boots?")) if Kernel.pbConfirmMessageSerious(_INTL("Take off the Magic Boots?"))
@@ -472,8 +471,44 @@ ItemHandlers::UseOnPokemon.add(:DNASPLICERS, proc { |item, pokemon, scene|
next false next false
}) })
ItemHandlers::UseInField.add(:DNASPLICERS, proc { |item|
fusion_success = useSplicerFromField(false, false)
next 3 if fusion_success
next false
})
ItemHandlers::UseInField.add(:SUPERSPLICERS, proc { |item|
fusion_success = useSplicerFromField(true, true)
next 3 if fusion_success
next false
})
ItemHandlers::UseInField.add(:INFINITESPLICERS, proc { |item|
fusion_success = useSplicerFromField(false, false)
next true if fusion_success
next false
})
ItemHandlers::UseInField.add(:INFINITESPLICERS2, proc { |item|
fusion_success = useSplicerFromField(true, true)
next true if fusion_success
next false
})
def useSplicerFromField(supersplicers, superSplicer_arg2)
scene = PokemonParty_Scene.new
scene.pbStartScene($Trainer.party,"Select a Pokémon")
screen = PokemonPartyScreen.new(scene, $Trainer.party)
chosen = screen.pbChoosePokemon("Select a Pokémon")
pokemon = $Trainer.party[chosen]
fusion_success = pbDNASplicing(pokemon, scene, supersplicers, superSplicer_arg2)
screen.pbEndScene
scene.dispose
return fusion_success
end
ItemHandlers::UseOnPokemon.add(:DNAREVERSER, proc { |item, pokemon, scene| ItemHandlers::UseOnPokemon.add(:DNAREVERSER, proc { |item, pokemon, scene|
if !pokemon.isFusion? if !pokemon.isFusion?
scene.pbDisplay(_INTL("It won't have any effect.")) scene.pbDisplay(_INTL("It won't have any effect."))
@@ -1280,6 +1315,7 @@ def getPokemonPositionInParty(pokemon)
return -1 return -1
end end
#don't remember why there's two Supersplicers arguments.... probably a mistake
def pbDNASplicing(pokemon, scene, supersplicers = false, superSplicer = false) def pbDNASplicing(pokemon, scene, supersplicers = false, superSplicer = false)
playingBGM = $game_system.getPlayingBGM playingBGM = $game_system.getPlayingBGM
dexNumber = pokemon.species_data.id_number dexNumber = pokemon.species_data.id_number
@@ -1356,7 +1392,6 @@ def pbDNASplicing(pokemon, scene, supersplicers = false, superSplicer = false)
end end
end end
def selectFusion(pokemon, poke2, supersplicers = false) def selectFusion(pokemon, poke2, supersplicers = false)
return nil if !pokemon.is_a?(Pokemon) || !poke2.is_a?(Pokemon) return nil if !pokemon.is_a?(Pokemon) || !poke2.is_a?(Pokemon)
return nil if pokemon.egg? || poke2.egg? return nil if pokemon.egg? || poke2.egg?
@@ -1366,12 +1401,11 @@ def selectFusion(pokemon, poke2, supersplicers = false)
selectorWindow.dispose selectorWindow.dispose
return selectedHead return selectedHead
end end
# firstOptionSelected= selectedHead == pokemon # firstOptionSelected= selectedHead == pokemon
# selectedBody = selectedHead == pokemon ? poke2 : pokemon # selectedBody = selectedHead == pokemon ? poke2 : pokemon
# newid = (selectedBody.species_data.id_number) * NB_POKEMON + selectedHead.species_data.id_number # newid = (selectedBody.species_data.id_number) * NB_POKEMON + selectedHead.species_data.id_number
# def pbFuse(pokemon, poke2, supersplicers = false) # def pbFuse(pokemon, poke2, supersplicers = false)
# newid = (pokemon.species_data.id_number) * NB_POKEMON + poke2.species_data.id_number # newid = (pokemon.species_data.id_number) * NB_POKEMON + poke2.species_data.id_number
# previewwindow = FusionPreviewScreen.new(pokemon, poke2)#PictureWindow.new(picturePath) # previewwindow = FusionPreviewScreen.new(pokemon, poke2)#PictureWindow.new(picturePath)
@@ -1392,7 +1426,6 @@ end
# end # end
# end # end
def pbFuse(pokemon, poke2, supersplicers = false) def pbFuse(pokemon, poke2, supersplicers = false)
newid = (pokemon.species_data.id_number) * NB_POKEMON + poke2.species_data.id_number newid = (pokemon.species_data.id_number) * NB_POKEMON + poke2.species_data.id_number
fus = PokemonFusionScene.new fus = PokemonFusionScene.new
@@ -1456,7 +1489,6 @@ def pbUnfuse(pokemon, scene, supersplicers, pcPosition = nil)
pokemon.exp_when_fused_head = nil pokemon.exp_when_fused_head = nil
pokemon.exp_when_fused_body = nil pokemon.exp_when_fused_body = nil
if pokemon.shiny? if pokemon.shiny?
pokemon.shiny = false pokemon.shiny = false
if pokemon.bodyShiny? && pokemon.headShiny? if pokemon.bodyShiny? && pokemon.headShiny?
@@ -1472,7 +1504,8 @@ def pbUnfuse(pokemon, scene, supersplicers, pcPosition = nil)
poke2.shiny = true poke2.shiny = true
pokemon.shiny = false pokemon.shiny = false
poke2.natural_shiny = true if pokemon.natural_shiny && !pokemon.debug_shiny poke2.natural_shiny = true if pokemon.natural_shiny && !pokemon.debug_shiny
else #shiny was obtained already fused else
#shiny was obtained already fused
if rand(2) == 0 if rand(2) == 0
pokemon.shiny = true pokemon.shiny = true
else else
@@ -1487,11 +1520,9 @@ def pbUnfuse(pokemon, scene, supersplicers, pcPosition = nil)
pokemon.debug_shiny = true if pokemon.debug_shiny && pokemon.body_shiny pokemon.debug_shiny = true if pokemon.debug_shiny && pokemon.body_shiny
poke2.debug_shiny = true if pokemon.debug_shiny && poke2.head_shiny poke2.debug_shiny = true if pokemon.debug_shiny && poke2.head_shiny
pokemon.body_shiny = false pokemon.body_shiny = false
pokemon.head_shiny = false pokemon.head_shiny = false
if !pokemon.shiny? if !pokemon.shiny?
pokemon.debug_shiny = false pokemon.debug_shiny = false
end end

Binary file not shown.