Commit ccac2dee authored by Nemo Ma's avatar Nemo Ma

Update c33701112.lua

parent fe1ce61e
...@@ -2,15 +2,15 @@ ...@@ -2,15 +2,15 @@
function c33701112.initial_effect(c) function c33701112.initial_effect(c)
--xyz summon --xyz summon
c:EnableReviveLimit() c:EnableReviveLimit()
aux.AddXyzProcedureLevelFree(c,nil,c33701112.xyzcheck,3,3) aux.AddXyzProcedureLevelFree(c,nil,c33701112.xyzcheck,3,3,c33701112.ovfilter,aux.Stringid(33701112,0),c33701112.xyzop)
--attribute --attribute
local e2=Effect.CreateEffect(c) local e1=Effect.CreateEffect(c)
e2:SetType(EFFECT_TYPE_SINGLE) e1:SetType(EFFECT_TYPE_SINGLE)
e2:SetProperty(EFFECT_FLAG_SINGLE_RANGE) e1:SetProperty(EFFECT_FLAG_SINGLE_RANGE)
e2:SetCode(EFFECT_ADD_ATTRIBUTE) e1:SetCode(EFFECT_ADD_ATTRIBUTE)
e2:SetRange(LOCATION_MZONE) e1:SetRange(LOCATION_MZONE)
e2:SetValue(0x2f) e1:SetValue(0x2f)
c:RegisterEffect(e2) c:RegisterEffect(e1)
--extra material --extra material
local e2=Effect.CreateEffect(c) local e2=Effect.CreateEffect(c)
e2:SetDescription(aux.Stringid(33701112,0)) e2:SetDescription(aux.Stringid(33701112,0))
...@@ -19,8 +19,8 @@ function c33701112.initial_effect(c) ...@@ -19,8 +19,8 @@ function c33701112.initial_effect(c)
e2:SetCode(EFFECT_SPSUMMON_PROC) e2:SetCode(EFFECT_SPSUMMON_PROC)
e2:SetRange(LOCATION_EXTRA) e2:SetRange(LOCATION_EXTRA)
e2:SetLabelObject(c) e2:SetLabelObject(c)
e2:SetCondition(c33701112.xyzcon) e2:SetCondition(c33701112.xyzcon2)
e2:SetOperation(c33701112.xyzop) e2:SetOperation(c33701112.xyzop2)
e2:SetValue(SUMMON_TYPE_XYZ) e2:SetValue(SUMMON_TYPE_XYZ)
local e3=Effect.CreateEffect(c) local e3=Effect.CreateEffect(c)
e3:SetType(EFFECT_TYPE_FIELD+EFFECT_TYPE_GRANT) e3:SetType(EFFECT_TYPE_FIELD+EFFECT_TYPE_GRANT)
...@@ -28,32 +28,29 @@ function c33701112.initial_effect(c) ...@@ -28,32 +28,29 @@ function c33701112.initial_effect(c)
e3:SetTargetRange(LOCATION_EXTRA,0) e3:SetTargetRange(LOCATION_EXTRA,0)
e3:SetTarget(c33701112.mattg) e3:SetTarget(c33701112.mattg)
e3:SetLabelObject(e2) e3:SetLabelObject(e2)
c:RegisterEffect(e3) c:RegisterEffect(e3)
--em
local e2=Effect.CreateEffect(c)
e2:SetDescription(aux.Stringid(33701112,1))
e2:SetType(EFFECT_TYPE_FIELD)
e2:SetProperty(EFFECT_FLAG_UNCOPYABLE+EFFECT_FLAG_IGNORE_IMMUNE)
e2:SetCode(EFFECT_SPSUMMON_PROC)
e2:SetRange(LOCATION_EXTRA)
e2:SetCondition(c33701112.xyzcon2)
e2:SetOperation(c33701112.xyzop2)
e2:SetValue(SUMMON_TYPE_XYZ)
c:RegisterEffect(e2)
end end
function c33701112.xyzcheck(g) function c33701112.xyzcheck(g)
return g:GetClassCount(Card.GetLevel)==1 return g:GetClassCount(Card.GetLevel)==1
end end
function c33701112.ovfilter(c)
return c:IsFaceup() and c:IsXyzType(TYPE_XYZ) and c:IsSetCard(0x1445)
end
function c33701112.xyzop(e,tp,chk,mc)
if chk==0 then return Duel.GetFlagEffect(tp,33701112)==0 and mc:CheckRemoveOverlayCard(tp,1,REASON_COST) end
mc:RemoveOverlayCard(tp,1,1,REASON_COST)
Duel.RegisterFlagEffect(tp,33701112,RESET_PHASE+PHASE_END,0,1)
end
function c33701112.mattg(e,c) function c33701112.mattg(e,c)
return c:IsSetCard(0x1445) and c:IsType(TYPE_XYZ) return c:IsSetCard(0x1445) and c:IsType(TYPE_XYZ)
end end
function c33701112.xyzcon(e,c,og,lmat,min,max) function c33701112.xyzcon2(e,c,og,lmat,min,max)
if c==nil then return true end if c==nil then return true end
local tp=c:GetControler() local tp=c:GetControler()
local xc=e:GetLabelObject() local xc=e:GetLabelObject()
return Duel.GetLocationCountFromEx(tp,tp,xc,e:GetHandler())>0 and xc:IsCanBeXyzMaterial(nil) return Duel.GetLocationCountFromEx(tp,tp,xc,e:GetHandler())>0 and xc:IsCanBeXyzMaterial(nil)
end end
function c33701112.xyzop(e,tp,eg,ep,ev,re,r,rp,c,og,lmat,min,max) function c33701112.xyzop2(e,tp,eg,ep,ev,re,r,rp,c,og,lmat,min,max)
local xc=e:GetLabelObject() local xc=e:GetLabelObject()
local mg=xc:GetOverlayGroup() local mg=xc:GetOverlayGroup()
if mg:GetCount()~=0 then if mg:GetCount()~=0 then
...@@ -74,24 +71,3 @@ end ...@@ -74,24 +71,3 @@ end
function c33701112.splimit(e,c,tp,sumtp,sumpos) function c33701112.splimit(e,c,tp,sumtp,sumpos)
return bit.band(sumtp,SUMMON_TYPE_XYZ)==SUMMON_TYPE_XYZ return bit.band(sumtp,SUMMON_TYPE_XYZ)==SUMMON_TYPE_XYZ
end end
function c33701112.xxxfil(c,e,tp)
return c:IsCanBeXyzMaterial(nil) and Duel.GetLocationCountFromEx(tp,tp,c,e:GetHandler())>0 and c:IsSetCard(0x1445) and c:IsType(TYPE_XYZ) and c:GetOverlayCount()>0
end
function c33701112.xyzcon2(e,c,og,lmat,min,max)
if c==nil then return Duel.IsExistingMatchingCard(c33701112.xxxfil,tp,LOCATION_MZONE,0,1,nil,e,tp) end
local tp=c:GetControler()
return true
end
function c33701112.xyzop2(e,tp,eg,ep,ev,re,r,rp,c,og,lmat,min,max)
Duel.Hint(HINT_SELECTMSG,tp,HINTMSG_XMATERIAL)
local tc=Duel.SelectMatchingCard(tp,c33701112.xxxfil,tp,LOCATION_MZONE,0,1,1,nil,e,tp):GetFirst()
tc:RemoveOverlayCard(tp,1,1,REASON_COST+REASON_XYZ)
local mg=tc:GetOverlayGroup()
if mg:GetCount()~=0 then
Duel.Overlay(e:GetHandler(),mg)
end
e:GetHandler():SetMaterial(Group.FromCards(tc))
Duel.Overlay(e:GetHandler(),Group.FromCards(tc))
end
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment