mirror of
https://github.com/infinitefusion/infinitefusion-e18.git
synced 2025-12-06 06:01:46 +00:00
use splicers from field
This commit is contained in:
@@ -399,7 +399,6 @@ ItemHandlers::UseInField.add(:DREAMMIRROR, proc { |item|
|
||||
next 1
|
||||
})
|
||||
|
||||
|
||||
ItemHandlers::UseFromBag.add(:MAGICBOOTS, proc { |item|
|
||||
if $DEBUG
|
||||
if Kernel.pbConfirmMessageSerious(_INTL("Take off the Magic Boots?"))
|
||||
@@ -472,8 +471,44 @@ ItemHandlers::UseOnPokemon.add(:DNASPLICERS, proc { |item, pokemon, scene|
|
||||
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|
|
||||
if !pokemon.isFusion?
|
||||
scene.pbDisplay(_INTL("It won't have any effect."))
|
||||
@@ -1280,6 +1315,7 @@ def getPokemonPositionInParty(pokemon)
|
||||
return -1
|
||||
end
|
||||
|
||||
#don't remember why there's two Supersplicers arguments.... probably a mistake
|
||||
def pbDNASplicing(pokemon, scene, supersplicers = false, superSplicer = false)
|
||||
playingBGM = $game_system.getPlayingBGM
|
||||
dexNumber = pokemon.species_data.id_number
|
||||
@@ -1356,7 +1392,6 @@ def pbDNASplicing(pokemon, scene, supersplicers = false, superSplicer = false)
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
def selectFusion(pokemon, poke2, supersplicers = false)
|
||||
return nil if !pokemon.is_a?(Pokemon) || !poke2.is_a?(Pokemon)
|
||||
return nil if pokemon.egg? || poke2.egg?
|
||||
@@ -1366,12 +1401,11 @@ def selectFusion(pokemon, poke2, supersplicers = false)
|
||||
selectorWindow.dispose
|
||||
return selectedHead
|
||||
end
|
||||
|
||||
# firstOptionSelected= selectedHead == pokemon
|
||||
# selectedBody = selectedHead == pokemon ? poke2 : pokemon
|
||||
# newid = (selectedBody.species_data.id_number) * NB_POKEMON + selectedHead.species_data.id_number
|
||||
|
||||
|
||||
|
||||
# def pbFuse(pokemon, poke2, supersplicers = false)
|
||||
# newid = (pokemon.species_data.id_number) * NB_POKEMON + poke2.species_data.id_number
|
||||
# previewwindow = FusionPreviewScreen.new(pokemon, poke2)#PictureWindow.new(picturePath)
|
||||
@@ -1392,7 +1426,6 @@ end
|
||||
# end
|
||||
# end
|
||||
|
||||
|
||||
def pbFuse(pokemon, poke2, supersplicers = false)
|
||||
newid = (pokemon.species_data.id_number) * NB_POKEMON + poke2.species_data.id_number
|
||||
fus = PokemonFusionScene.new
|
||||
@@ -1456,7 +1489,6 @@ def pbUnfuse(pokemon, scene, supersplicers, pcPosition = nil)
|
||||
pokemon.exp_when_fused_head = nil
|
||||
pokemon.exp_when_fused_body = nil
|
||||
|
||||
|
||||
if pokemon.shiny?
|
||||
pokemon.shiny = false
|
||||
if pokemon.bodyShiny? && pokemon.headShiny?
|
||||
@@ -1472,7 +1504,8 @@ def pbUnfuse(pokemon, scene, supersplicers, pcPosition = nil)
|
||||
poke2.shiny = true
|
||||
pokemon.shiny = false
|
||||
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
|
||||
pokemon.shiny = true
|
||||
else
|
||||
@@ -1487,11 +1520,9 @@ def pbUnfuse(pokemon, scene, supersplicers, pcPosition = nil)
|
||||
pokemon.debug_shiny = true if pokemon.debug_shiny && pokemon.body_shiny
|
||||
poke2.debug_shiny = true if pokemon.debug_shiny && poke2.head_shiny
|
||||
|
||||
|
||||
pokemon.body_shiny = false
|
||||
pokemon.head_shiny = false
|
||||
|
||||
|
||||
if !pokemon.shiny?
|
||||
pokemon.debug_shiny = false
|
||||
end
|
||||
|
||||
Binary file not shown.
Reference in New Issue
Block a user