Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- --https://github.com/Mokiros/roblox-FE-compatibility
- if game:GetService("RunService"):IsClient() then error("Script must be server-side in order to work; use h/ and not hl/") end
- local Player,Mouse,mouse,UserInputService,ContextActionService = owner
- local RealPlayer = Player
- do print("FE Compatibility code by Mokiros")local a=RealPlayer;script.Parent=a.Character;local b=Instance.new("RemoteEvent")b.Name="UserInput_Event"local function c()local d={_fakeEvent=true,Functions={},Connect=function(self,e)table.insert(self.Functions,e)end}d.connect=d.Connect;return d end;local f={Target=nil,Hit=CFrame.new(),KeyUp=c(),KeyDown=c(),Button1Up=c(),Button1Down=c(),Button2Up=c(),Button2Down=c()}local g={InputBegan=c(),InputEnded=c()}local CAS={Actions={},BindAction=function(self,h,i,j,...)CAS.Actions[h]=i and{Name=h,Function=i,Keys={...}}or nil end}CAS.UnbindAction=CAS.BindAction;local function k(self,l,...)local d=f[l]if d and d._fakeEvent then for m,e in pairs(d.Functions)do e(...)end end end;f.TrigEvent=k;g.TrigEvent=k;b.OnServerEvent:Connect(function(n,o)if n~=a then return end;f.Target=o.Target;f.Hit=o.Hit;if not o.isMouse then local p=o.UserInputState==Enum.UserInputState.Begin;if o.UserInputType==Enum.UserInputType.MouseButton1 then return f:TrigEvent(p and"Button1Down"or"Button1Up")end;if o.UserInputType==Enum.UserInputType.MouseButton2 then return f:TrigEvent(p and"Button2Down"or"Button2Up")end;for m,d in pairs(CAS.Actions)do for m,q in pairs(d.Keys)do if q==o.KeyCode then d.Function(d.Name,o.UserInputState,o)end end end;f:TrigEvent(p and"KeyDown"or"KeyUp",o.KeyCode.Name:lower())g:TrigEvent(p and"InputBegan"or"InputEnded",o,false)end end)b.Parent=NLS([==[local a=game:GetService("Players").LocalPlayer;local b=script:WaitForChild("UserInput_Event")local c=a:GetMouse()local d=game:GetService("UserInputService")local e=function(f,g)if g then return end;b:FireServer({KeyCode=f.KeyCode,UserInputType=f.UserInputType,UserInputState=f.UserInputState,Hit=c.Hit,Target=c.Target})end;d.InputBegan:Connect(e)d.InputEnded:Connect(e)local h,i;while wait(1/30)do if h~=c.Hit or i~=c.Target then h,i=c.Hit,c.Target;b:FireServer({isMouse=true,Target=i,Hit=h})end end]==],Player.Character)local r=game;local s={__index=function(self,q)local t=rawget(self,"_RealService")if t then return typeof(t[q])=="function"and function(m,...)return t[q](t,...)end or t[q]end end,__newindex=function(self,q,u)local t=rawget(self,"_RealService")if t then t[q]=u end end}local function v(d,w)d._RealService=typeof(w)=="string"and r:GetService(w)or w;return setmetatable(d,s)end;local x={GetService=function(self,t)return rawget(self,t)or r:GetService(t)end,Players=v({LocalPlayer=v({GetMouse=function(self)return f end},Player)},"Players"),UserInputService=v(g,"UserInputService"),ContextActionService=v(CAS,"ContextActionService"),RunService=v({_btrs={},RenderStepped=r:GetService("RunService").Heartbeat,BindToRenderStep=function(self,h,m,i)self._btrs[h]=self.Heartbeat:Connect(i)end,UnbindFromRenderStep=function(self,h)self._btrs[h]:Disconnect()end},"RunService")}rawset(x.Players,"localPlayer",x.Players.LocalPlayer)x.service=x.GetService;v(x,game)game,owner=x,x.Players.LocalPlayer end
- ---------------Shadow Max/Colossus by Shackluster---------------
- wait(0.2)
- Player = game:GetService("Players").LocalPlayer
- PlayerGui = Player.PlayerGui
- Cam = workspace.CurrentCamera
- Backpack = Player.Backpack
- Character = Player.Character
- Mouse = Player:GetMouse()
- Humanoid = Character.Humanoid
- Humanoid.Name = "Shadowmax"
- Humanoid.DisplayDistanceType = "None"
- RootPart = Character["HumanoidRootPart"]
- Torso = Character["Torso"]
- Head = Character["Head"]
- RightArm = Character["Right Arm"]
- LeftArm = Character["Left Arm"]
- RightLeg = Character["Right Leg"]
- LeftLeg = Character["Left Leg"]
- RootJoint = RootPart["RootJoint"]
- Neck = Torso["Neck"]
- RightShoulder = Torso["Right Shoulder"]
- LeftShoulder = Torso["Left Shoulder"]
- RightHip = Torso["Right Hip"]
- LeftHip = Torso["Left Hip"]
- local BMUSIC = Instance.new("Sound",Character)
- IT = Instance.new
- CF = CFrame.new
- VT = Vector3.new
- RAD = math.rad
- C3 = Color3.new
- UD2 = UDim2.new
- BRICKC = BrickColor.new
- ANGLES = CFrame.Angles
- EULER = CFrame.fromEulerAnglesXYZ
- COS = math.cos
- ACOS = math.acos
- SIN = math.sin
- ASIN = math.asin
- ABS = math.abs
- MRANDOM = math.random
- FLOOR = math.floor
- --//=================================\\
- --|| USEFUL VALUES
- --\\=================================//
- Animation_Speed = 3
- Frame_Speed = 1 / 60 -- (1 / 30) OR (1 / 60)
- local Speed = 16
- local ROOTC0 = CF(0, 0, 0) * ANGLES(RAD(-90), RAD(0), RAD(180))
- local NECKC0 = CF(0, 1, 0) * ANGLES(RAD(-90), RAD(0), RAD(180))
- local RIGHTSHOULDERC0 = CF(-0.5, 0, 0) * ANGLES(RAD(0), RAD(90), RAD(0))
- local LEFTSHOULDERC0 = CF(0.5, 0, 0) * ANGLES(RAD(0), RAD(-90), RAD(0))
- local DAMAGEMULTIPLIER = 1
- local ANIM = "Idle"
- local ATTACK = false
- local EQUIPPED = false
- local HOLD = false
- local COMBO = 1
- local Rooted = false
- local SINE = 0
- local KEYHOLD = false
- local CHANGE = 2 / Animation_Speed
- local WALKINGANIM = false
- local ANIMATOR = Humanoid.Animator
- local ANIMATE = Character.Animate
- ANIMATE:remove()
- for _,v in next, Humanoid:GetPlayingAnimationTracks() do
- v:Stop();
- end
- local ROBLOXIDLEANIMATION = IT("Animation")
- ROBLOXIDLEANIMATION.Name = "Roblox Idle Animation"
- ROBLOXIDLEANIMATION.AnimationId = "http://www.roblox.com/asset/?id=180435571"
- --ROBLOXIDLEANIMATION.Parent = Humanoid
- local WEAPONGUI = IT("ScreenGui", PlayerGui)
- WEAPONGUI.Name = "SHADOWMAX_GUI"
- script.Parent = WEAPONGUI
- Character.Archivable = true
- local CLONE = Character:Clone()
- CLONE.Parent = nil
- Character.Archivable = false
- local Effects = IT("Folder", Character)
- Effects.Name = "Effects"
- local UNANCHOR = true
- local SIZE = 1
- local FORM = "Normal"
- local SHADES = {}
- local TRANS = 0.5
- local SHADEDIST = 5
- --//=================================\\
- --|| LOCAL IDS
- --\\=================================//
- local GROWL = 1544355717
- local ROAR = 528589382
- local ECHOBLAST = 376976397
- local CAST = 459523898
- local ALCHEMY = 424195979
- local BUILDUP = 698824317
- local BIGBUILDUP = 874376217
- local IMPACT = 231917744
- local LARGE_EXPLOSION = 168513088
- local TURNUP = 299058146
- --//=================================\\
- --|| SAZERENOS' ARTIFICIAL HEARTBEAT
- --\\=================================//
- ArtificialHB = Instance.new("BindableEvent", script)
- ArtificialHB.Name = "ArtificialHB"
- script:WaitForChild("ArtificialHB")
- frame = Frame_Speed
- tf = 0
- allowframeloss = false
- tossremainder = false
- lastframe = tick()
- script.ArtificialHB:Fire()
- game:GetService("RunService").Heartbeat:connect(function(s, p)
- tf = tf + s
- if tf >= frame then
- if allowframeloss then
- script.ArtificialHB:Fire()
- lastframe = tick()
- else
- for i = 1, math.floor(tf / frame) do
- script.ArtificialHB:Fire()
- end
- lastframe = tick()
- end
- if tossremainder then
- tf = 0
- else
- tf = tf - frame * math.floor(tf / frame)
- end
- end
- end)
- --//=================================\\
- --\\=================================//
- --//=================================\\
- --|| SOME FUNCTIONS
- --\\=================================//
- function Raycast(POSITION, DIRECTION, RANGE, IGNOREDECENDANTS)
- return workspace:FindPartOnRay(Ray.new(POSITION, DIRECTION.unit * RANGE), IGNOREDECENDANTS)
- end
- function PositiveAngle(NUMBER)
- if NUMBER >= 0 then
- NUMBER = 0
- end
- return NUMBER
- end
- function NegativeAngle(NUMBER)
- if NUMBER <= 0 then
- NUMBER = 0
- end
- return NUMBER
- end
- function Swait(NUMBER)
- if NUMBER == 0 or NUMBER == nil then
- ArtificialHB.Event:wait()
- else
- for i = 1, NUMBER do
- ArtificialHB.Event:wait()
- end
- end
- end
- function CreateMesh(MESH, PARENT, MESHTYPE, MESHID, TEXTUREID, SCALE, OFFSET)
- local NEWMESH = IT(MESH)
- if MESH == "SpecialMesh" then
- NEWMESH.MeshType = MESHTYPE
- if MESHID ~= "nil" and MESHID ~= "" then
- NEWMESH.MeshId = "http://www.roblox.com/asset/?id="..MESHID
- end
- if TEXTUREID ~= "nil" and TEXTUREID ~= "" then
- NEWMESH.TextureId = "http://www.roblox.com/asset/?id="..TEXTUREID
- end
- end
- NEWMESH.Offset = OFFSET or VT(0, 0, 0)
- NEWMESH.Scale = SCALE
- NEWMESH.Parent = PARENT
- return NEWMESH
- end
- function CreatePart(FORMFACTOR, PARENT, MATERIAL, REFLECTANCE, TRANSPARENCY, BRICKCOLOR, NAME, SIZE, ANCHOR)
- local NEWPART = IT("Part")
- NEWPART.formFactor = FORMFACTOR
- NEWPART.Reflectance = REFLECTANCE
- NEWPART.Transparency = TRANSPARENCY
- NEWPART.CanCollide = false
- NEWPART.Locked = true
- NEWPART.Anchored = true
- if ANCHOR == false then
- NEWPART.Anchored = false
- end
- NEWPART.BrickColor = BRICKC(tostring(BRICKCOLOR))
- NEWPART.Name = NAME
- NEWPART.Size = SIZE
- NEWPART.Position = Torso.Position
- NEWPART.Material = MATERIAL
- NEWPART:BreakJoints()
- NEWPART.Parent = PARENT
- return NEWPART
- end
- local function weldBetween(a, b)
- local weldd = Instance.new("ManualWeld")
- weldd.Part0 = a
- weldd.Part1 = b
- weldd.C0 = CFrame.new()
- weldd.C1 = b.CFrame:inverse() * a.CFrame
- weldd.Parent = a
- return weldd
- end
- function QuaternionFromCFrame(cf)
- local mx, my, mz, m00, m01, m02, m10, m11, m12, m20, m21, m22 = cf:components()
- local trace = m00 + m11 + m22
- if trace > 0 then
- local s = math.sqrt(1 + trace)
- local recip = 0.5 / s
- return (m21 - m12) * recip, (m02 - m20) * recip, (m10 - m01) * recip, s * 0.5
- else
- local i = 0
- if m11 > m00 then
- i = 1
- end
- if m22 > (i == 0 and m00 or m11) then
- i = 2
- end
- if i == 0 then
- local s = math.sqrt(m00 - m11 - m22 + 1)
- local recip = 0.5 / s
- return 0.5 * s, (m10 + m01) * recip, (m20 + m02) * recip, (m21 - m12) * recip
- elseif i == 1 then
- local s = math.sqrt(m11 - m22 - m00 + 1)
- local recip = 0.5 / s
- return (m01 + m10) * recip, 0.5 * s, (m21 + m12) * recip, (m02 - m20) * recip
- elseif i == 2 then
- local s = math.sqrt(m22 - m00 - m11 + 1)
- local recip = 0.5 / s return (m02 + m20) * recip, (m12 + m21) * recip, 0.5 * s, (m10 - m01) * recip
- end
- end
- end
- function QuaternionToCFrame(px, py, pz, x, y, z, w)
- local xs, ys, zs = x + x, y + y, z + z
- local wx, wy, wz = w * xs, w * ys, w * zs
- local xx = x * xs
- local xy = x * ys
- local xz = x * zs
- local yy = y * ys
- local yz = y * zs
- local zz = z * zs
- return CFrame.new(px, py, pz, 1 - (yy + zz), xy - wz, xz + wy, xy + wz, 1 - (xx + zz), yz - wx, xz - wy, yz + wx, 1 - (xx + yy))
- end
- function QuaternionSlerp(a, b, t)
- local cosTheta = a[1] * b[1] + a[2] * b[2] + a[3] * b[3] + a[4] * b[4]
- local startInterp, finishInterp;
- if cosTheta >= 0.0001 then
- if (1 - cosTheta) > 0.0001 then
- local theta = ACOS(cosTheta)
- local invSinTheta = 1 / SIN(theta)
- startInterp = SIN((1 - t) * theta) * invSinTheta
- finishInterp = SIN(t * theta) * invSinTheta
- else
- startInterp = 1 - t
- finishInterp = t
- end
- else
- if (1 + cosTheta) > 0.0001 then
- local theta = ACOS(-cosTheta)
- local invSinTheta = 1 / SIN(theta)
- startInterp = SIN((t - 1) * theta) * invSinTheta
- finishInterp = SIN(t * theta) * invSinTheta
- else
- startInterp = t - 1
- finishInterp = t
- end
- end
- return a[1] * startInterp + b[1] * finishInterp, a[2] * startInterp + b[2] * finishInterp, a[3] * startInterp + b[3] * finishInterp, a[4] * startInterp + b[4] * finishInterp
- end
- function Clerp(a, b, t)
- local qa = {QuaternionFromCFrame(a)}
- local qb = {QuaternionFromCFrame(b)}
- local ax, ay, az = a.x, a.y, a.z
- local bx, by, bz = b.x, b.y, b.z
- local _t = 1 - t
- return QuaternionToCFrame(_t * ax + t * bx, _t * ay + t * by, _t * az + t * bz, QuaternionSlerp(qa, qb, t))
- end
- function CreateFrame(PARENT, TRANSPARENCY, BORDERSIZEPIXEL, POSITION, SIZE, COLOR, BORDERCOLOR, NAME)
- local frame = IT("Frame")
- frame.BackgroundTransparency = TRANSPARENCY
- frame.BorderSizePixel = BORDERSIZEPIXEL
- frame.Position = POSITION
- frame.Size = SIZE
- frame.BackgroundColor3 = COLOR
- frame.BorderColor3 = BORDERCOLOR
- frame.Name = NAME
- frame.Parent = PARENT
- return frame
- end
- function CreateLabel(PARENT, TEXT, TEXTCOLOR, TEXTFONTSIZE, TEXTFONT, TRANSPARENCY, BORDERSIZEPIXEL, STROKETRANSPARENCY, NAME)
- local label = IT("TextLabel")
- label.BackgroundTransparency = 1
- label.Size = UD2(1, 0, 1, 0)
- label.Position = UD2(0, 0, 0, 0)
- label.TextColor3 = TEXTCOLOR
- label.TextStrokeTransparency = STROKETRANSPARENCY
- label.TextTransparency = TRANSPARENCY
- label.FontSize = TEXTFONTSIZE
- label.Font = TEXTFONT
- label.BorderSizePixel = BORDERSIZEPIXEL
- label.TextScaled = false
- label.Text = TEXT
- label.Name = NAME
- label.Parent = PARENT
- return label
- end
- function FireArc(Part,ToLocation,AmountOfTime,Height,DoesCourontine)
- if DoesCourontine == false then
- local Direction = CF(Part.Position,ToLocation)
- local Distance = (Part.Position - ToLocation).magnitude
- for i = 1, AmountOfTime do
- Swait()
- Part.CFrame = Direction*CF(0,(AmountOfTime/200)+((AmountOfTime/Height)-((i*2)/Height)),-Distance/AmountOfTime)
- Direction = Part.CFrame
- end
- Part:remove()
- elseif DoesCourontine == true then
- coroutine.resume(coroutine.create(function()
- local Direction = CF(Part.Position,ToLocation)
- local Distance = (Part.Position - ToLocation).magnitude
- for i = 1, AmountOfTime do
- Swait()
- Part.CFrame = Direction*CF(0,(AmountOfTime/200)+((AmountOfTime/Height)-((i*2)/Height)),-Distance/AmountOfTime)
- Direction = Part.CFrame
- end
- Part:remove()
- end))
- end
- end
- function NoOutlines(PART)
- PART.TopSurface, PART.BottomSurface, PART.LeftSurface, PART.RightSurface, PART.FrontSurface, PART.BackSurface = 10, 10, 10, 10, 10, 10
- end
- function CreateWeldOrSnapOrMotor(TYPE, PARENT, PART0, PART1, C0, C1)
- local NEWWELD = IT(TYPE)
- NEWWELD.Part0 = PART0
- NEWWELD.Part1 = PART1
- NEWWELD.C0 = C0
- NEWWELD.C1 = C1
- NEWWELD.Parent = PARENT
- return NEWWELD
- end
- local S = IT("Sound")
- function CreateSound(ID, PARENT, VOLUME, PITCH, DOESLOOP)
- local NEWSOUND = nil
- coroutine.resume(coroutine.create(function()
- NEWSOUND = S:Clone()
- NEWSOUND.Parent = PARENT
- NEWSOUND.Volume = VOLUME
- NEWSOUND.Pitch = PITCH
- NEWSOUND.SoundId = "http://www.roblox.com/asset/?id="..ID
- NEWSOUND:play()
- if DOESLOOP == true then
- NEWSOUND.Looped = true
- else
- repeat wait(1) until NEWSOUND.Playing == false
- NEWSOUND:remove()
- end
- end))
- return NEWSOUND
- end
- function CFrameFromTopBack(at, top, back)
- local right = top:Cross(back)
- return CF(at.x, at.y, at.z, right.x, top.x, back.x, right.y, top.y, back.y, right.z, top.z, back.z)
- end
- --WACKYEFFECT({EffectType = "", Size = VT(1,1,1), Size2 = VT(0,0,0), Transparency = 0, Transparency2 = 1, CFrame = CF(), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(1,1,1), SoundID = nil, SoundPitch = nil, SoundVolume = nil})
- function WACKYEFFECT(Table)
- local TYPE = (Table.EffectType or "Sphere")
- local SIZE = (Table.Size or VT(1,1,1))
- local ENDSIZE = (Table.Size2 or VT(0,0,0))
- local TRANSPARENCY = (Table.Transparency or 0)
- local ENDTRANSPARENCY = (Table.Transparency2 or 1)
- local CFRAME = (Table.CFrame or Torso.CFrame)
- local MOVEDIRECTION = (Table.MoveToPos or nil)
- local ROTATION1 = (Table.RotationX or 0)
- local ROTATION2 = (Table.RotationY or 0)
- local ROTATION3 = (Table.RotationZ or 0)
- local MATERIAL = (Table.Material or "Neon")
- local COLOR = (Table.Color or C3(1,1,1))
- local TIME = (Table.Time or 45)
- local SOUNDID = (Table.SoundID or nil)
- local SOUNDPITCH = (Table.SoundPitch or nil)
- local SOUNDVOLUME = (Table.SoundVolume or nil)
- coroutine.resume(coroutine.create(function()
- local PLAYSSOUND = false
- local SOUND = nil
- local EFFECT = CreatePart(3, Effects, MATERIAL, 0, TRANSPARENCY, BRICKC("Pearl"), "Effect", VT(1,1,1), true)
- if SOUNDID ~= nil and SOUNDPITCH ~= nil and SOUNDVOLUME ~= nil then
- PLAYSSOUND = true
- SOUND = CreateSound(SOUNDID, EFFECT, SOUNDVOLUME, SOUNDPITCH, false)
- end
- EFFECT.Color = COLOR
- local MSH = nil
- if TYPE == "Sphere" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "Sphere", "", "", SIZE, VT(0,0,0))
- elseif TYPE == "Block" or TYPE == "Box" then
- MSH = IT("BlockMesh",EFFECT)
- MSH.Scale = SIZE
- elseif TYPE == "Cylinder" then
- MSH = IT("CylinderMesh",EFFECT)
- MSH.Scale = SIZE
- elseif TYPE == "Wave" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "FileMesh", "20329976", "", SIZE, VT(0,0,-SIZE.X/8))
- elseif TYPE == "Ring" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "FileMesh", "559831844", "", VT(SIZE.X,SIZE.X,0.1), VT(0,0,0))
- elseif TYPE == "Slash" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "FileMesh", "662586858", "", VT(SIZE.X/10,0,SIZE.X/10), VT(0,0,0))
- elseif TYPE == "Round Slash" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "FileMesh", "662585058", "", VT(SIZE.X/10,0,SIZE.X/10), VT(0,0,0))
- elseif TYPE == "Swirl" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "FileMesh", "1051557", "", SIZE, VT(0,0,0))
- elseif TYPE == "Skull" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "FileMesh", "4770583", "", SIZE, VT(0,0,0))
- elseif TYPE == "Crystal" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "FileMesh", "9756362", "", SIZE, VT(0,0,0))
- elseif TYPE == "Crown" then
- MSH = CreateMesh("SpecialMesh", EFFECT, "FileMesh", "173770780", "", SIZE, VT(0,0,0))
- end
- if MSH ~= nil then
- local MOVESPEED = nil
- if MOVEDIRECTION ~= nil then
- MOVESPEED = (CFRAME.p - MOVEDIRECTION).Magnitude/TIME
- end
- local GROWTH = SIZE - ENDSIZE
- local TRANS = TRANSPARENCY - ENDTRANSPARENCY
- if TYPE == "Block" then
- EFFECT.CFrame = CFRAME*ANGLES(RAD(MRANDOM(0,360)),RAD(MRANDOM(0,360)),RAD(MRANDOM(0,360)))
- else
- EFFECT.CFrame = CFRAME
- end
- for LOOP = 1, TIME+1 do
- Swait()
- MSH.Scale = MSH.Scale - GROWTH/TIME
- if TYPE == "Wave" then
- MSH.Offset = VT(0,0,-MSH.Scale.X/8)
- end
- EFFECT.Transparency = EFFECT.Transparency - TRANS/TIME
- if TYPE == "Block" then
- EFFECT.CFrame = CFRAME*ANGLES(RAD(MRANDOM(0,360)),RAD(MRANDOM(0,360)),RAD(MRANDOM(0,360)))
- else
- EFFECT.CFrame = EFFECT.CFrame*ANGLES(RAD(ROTATION1),RAD(ROTATION2),RAD(ROTATION3))
- end
- if MOVEDIRECTION ~= nil then
- local ORI = EFFECT.Orientation
- EFFECT.CFrame = CF(EFFECT.Position,MOVEDIRECTION)*CF(0,0,-MOVESPEED)
- EFFECT.Orientation = ORI
- end
- end
- EFFECT.Transparency = 1
- if PLAYSSOUND == false then
- EFFECT:remove()
- else
- repeat Swait() until SOUND.Playing == false
- EFFECT:remove()
- end
- else
- if PLAYSSOUND == false then
- EFFECT:remove()
- else
- repeat Swait() until SOUND.Playing == false
- EFFECT:remove()
- end
- end
- end))
- end
- --Lightning({Material = "Neon", FadeIn = false, Color = C3(1,1,1), Start = Torso.Position, End = Mouse.Hit.p, SegmentL = 2, Thickness = 0.1, DoesFade = false, Ignore = Character, MaxDist = 400, Branches = false, FadeTime = 15, Thicken = false})
- function Lightning(Table)
- local Color = Table.Color or C3(1,1,1)
- local StartPos = Table.Start or Torso.Position
- local EndPos = Table.End or Mouse.Hit.p
- local SegmentLength = Table.SegmentL or 2
- local Thickness = Table.Thickness or 0.1
- local Dissapear = Table.DoesFade or false
- local Parent = Table.Ignore or Character
- local MaxDist = Table.MaxDist or 400
- local Branches = Table.Branches or false
- local Thicken = Table.Thicken or false
- local FadeTime = Table.FadeTime or 15
- local FadeIn = Table.FadeIn or false
- local Material = Table.Material or "Neon"
- local HIT,HITPOS = CastProperRay(StartPos, EndPos, MaxDist, Parent)
- local DISTANCE = math.ceil((StartPos - HITPOS).Magnitude/((SegmentLength/SegmentLength)/1.5))
- local LIGHTNINGMODEL = IT("Model",Effects)
- LIGHTNINGMODEL.Name = "Lightning"
- local LastBolt = nil
- for E = 1, DISTANCE do
- local ExtraSize = 0
- if Thicken == true then
- ExtraSize = (DISTANCE-E)/15
- end
- local TRANSPARENCY = 0
- if FadeIn == true then
- TRANSPARENCY = 1-(E/(DISTANCE/1.5))
- if TRANSPARENCY < 0 then
- TRANSPARENCY = 0
- end
- end
- local PART = CreatePart(3, LIGHTNINGMODEL, Material, 0, TRANSPARENCY, BRICKC("Pearl"), "LightningPart"..E, VT(Thickness+ExtraSize,SegmentLength,Thickness+ExtraSize))
- PART.Color = Color
- MakeForm(PART,"Cyl")
- if LastBolt == nil then
- PART.CFrame = CF(StartPos,HITPOS)*ANGLES(RAD(90),RAD(0),RAD(0))*CF(0,-PART.Size.Y/2,0)
- else
- PART.CFrame = CF(LastBolt.CFrame*CF(0,-LastBolt.Size.Y/2,0).p,CF(HITPOS)*ANGLES(RAD(MRANDOM(0,360)),RAD(MRANDOM(0,360)),RAD(MRANDOM(0,360)))*CF(0,0,DISTANCE-E).p)*ANGLES(RAD(90),RAD(0),RAD(0))*CF(0,-PART.Size.Y/2,0)
- end
- LastBolt = PART
- if Branches == true and E < (DISTANCE-5) then
- local CHOICE = MRANDOM(1,7+((DISTANCE-E)*2))
- if CHOICE == 1 then
- local LASTBRANCH = nil
- for i = 1, MRANDOM(2,5) do
- local ExtraSize2 = 0
- if Thicken == true then
- ExtraSize = ((DISTANCE-E)/25)/i
- end
- local PART = CreatePart(3, LIGHTNINGMODEL, Material, 0, TRANSPARENCY, BRICKC("Pearl"), "Branch"..E.."-"..i, VT(Thickness+ExtraSize2,SegmentLength,Thickness+ExtraSize2))
- PART.Color = Color
- MakeForm(PART,"Cyl")
- if LASTBRANCH == nil then
- PART.CFrame = CF(LastBolt.CFrame*CF(0,-LastBolt.Size.Y/2,0).p,LastBolt.CFrame*CF(0,-LastBolt.Size.Y/2,0)*ANGLES(RAD(0),RAD(0),RAD(MRANDOM(0,360)))*CF(0,Thickness*7,0)*CF(0,0,-1).p)*ANGLES(RAD(90),RAD(0),RAD(0))*CF(0,-PART.Size.Y/2,0)
- else
- PART.CFrame = CF(LASTBRANCH.CFrame*CF(0,-LASTBRANCH.Size.Y/2,0).p,LASTBRANCH.CFrame*CF(0,-LASTBRANCH.Size.Y/2,0)*ANGLES(RAD(0),RAD(0),RAD(MRANDOM(0,360)))*CF(0,Thickness*3,0)*CF(0,0,-1).p)*ANGLES(RAD(90),RAD(0),RAD(0))*CF(0,-PART.Size.Y/2,0)
- end
- LASTBRANCH = PART
- end
- end
- end
- end
- if Dissapear == true then
- coroutine.resume(coroutine.create(function()
- for i = 1, FadeTime do
- Swait()
- for _, c in pairs(LIGHTNINGMODEL:GetChildren()) do
- if c.ClassName == "Part" then
- c.Transparency = c.Transparency + (i/FadeTime)/10
- end
- end
- end
- LIGHTNINGMODEL:remove()
- end))
- elseif Dissapear == false then
- Debris:AddItem(LIGHTNINGMODEL,0.1)
- end
- return {Hit = HIT,Pos = HITPOS,End = LastBolt.CFrame*CF(0,0,-LastBolt.Size.Z).p,LastBolt = LastBolt,Model = LIGHTNINGMODEL}
- end
- local DECAL = IT("Decal")
- function MagicRing(PART,CFRAME)
- local RING = CreatePart(3, Effects, "Granite", 0, 1, "Maroon", "MagicRing", VT(0,0,0),false)
- local WELD = CreateWeldOrSnapOrMotor("Weld", PART, PART, RING, CFRAME, CF(0, 0, 0))
- local MESH = IT("BlockMesh",RING)
- local BOTTOMTEXTURE = DECAL:Clone()
- BOTTOMTEXTURE.Parent = RING
- BOTTOMTEXTURE.Face = "Bottom"
- BOTTOMTEXTURE.Name = "BottomTexture"
- local TOPTEXTURE = DECAL:Clone()
- TOPTEXTURE.Parent = RING
- TOPTEXTURE.Face = "Top"
- TOPTEXTURE.Name = "TopTexture"
- local LIGHT = IT("PointLight",RING)
- BOTTOMTEXTURE.Texture = "http://www.roblox.com/asset/?id=1208118228"
- TOPTEXTURE.Texture = "http://www.roblox.com/asset/?id=1208118228"
- return RING,WELD,MESH
- end
- function MakeForm(PART,TYPE)
- if TYPE == "Cyl" then
- local MSH = IT("CylinderMesh",PART)
- elseif TYPE == "Ball" then
- local MSH = IT("SpecialMesh",PART)
- MSH.MeshType = "Sphere"
- elseif TYPE == "Wedge" then
- local MSH = IT("SpecialMesh",PART)
- MSH.MeshType = "Wedge"
- end
- end
- Debris = game:GetService("Debris")
- function CastProperRay(StartPos, EndPos, Distance, Ignore)
- local DIRECTION = CF(StartPos,EndPos).lookVector
- return Raycast(StartPos, DIRECTION, Distance, Ignore)
- end
- function ReSize()
- Humanoid.Parent = nil
- RootPart.Size = VT(2,2,1)*SIZE
- Torso.Size = VT(2,2,1)*SIZE
- RightArm.Size = VT(1,2,1)*SIZE
- RightLeg.Size = VT(1,2,1)*SIZE
- LeftArm.Size = VT(1,2,1)*SIZE
- LeftLeg.Size = VT(1,2,1)*SIZE
- RootJoint.C1 = ROOTC0 * CF(0 * SIZE, 0 * SIZE, 0 * SIZE) * ANGLES(RAD(0), RAD(0), RAD(0))
- Neck.C1 = CF(0 * SIZE, -0.5 * SIZE, 0 * SIZE) * ANGLES(RAD(-90), RAD(0), RAD(180))
- if SIZE == 1 then
- RightShoulder.C1 = CF(0 * SIZE, 0.5 * SIZE, -0.5*SIZE)
- LeftShoulder.C1 = CF(0 * SIZE, 0.5 * SIZE, -0.5*SIZE)
- else
- RightShoulder.C1 = CF(0 * SIZE, 0.5 * SIZE, -0.15*SIZE)
- LeftShoulder.C1 = CF(0 * SIZE, 0.5 * SIZE, -0.15*SIZE)
- end
- RightHip.C1 = CF(0.5 * SIZE, 1 * SIZE, 0 * SIZE) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(0))
- LeftHip.C1 = CF(-0.5 * SIZE, 1 * SIZE, 0 * SIZE) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(0))
- Head.Size = VT(2,1,1)*SIZE
- RootJoint.Parent = RootPart
- Neck.Parent = Torso
- RightShoulder.Parent = Torso
- LeftShoulder.Parent = Torso
- RightHip.Parent = Torso
- LeftHip.Parent = Torso
- Humanoid.Parent = Character
- end
- ReSize()
- function FindTorso(MODEL,ROOT)
- if ROOT == false then
- return MODEL:FindFirstChild("Torso") or MODEL:FindFirstChild("UpperTorso")
- else
- return MODEL:FindFirstChild("HumanoidRootPart") or MODEL:FindFirstChild("Torso") or MODEL:FindFirstChild("UpperTorso")
- end
- end
- --//=================================\\
- --|| WEAPON CREATION
- --\\=================================//
- local SKILLTEXTCOLOR = C3(1,1,1)
- local SKILLFONT = "Fantasy"
- local SKILLTEXTSIZE = 6
- local ATTACKS = {"Q-Shadow Blast","E-Chain Reaction","R-Blight Ravage","Z-The Colossus","X-And Then There Were Two"}
- local ATTACKS2 = {"Q-Sound Tremor","E-Blighted Solar Flare","R-Alchemic Chaos","Z-Revert","X-UNUSABLE"}
- local ATTACKS3 = {"Q-Double Shades","E-A Third","R-Twin Lightning","Z-UNUSABLE","X-Revert"}
- --local ATTACKSFRAME = CreateFrame(WEAPONGUI, 1, 2, UD2(0.8, 0, 0.90, 0), UD2(0.26, 0, 0.07, 0), C3(0,0,0), C3(0, 0, 0), "Skill Frame")
- --local TEXT = CreateLabel(ATTACKSFRAME, "[ATTACKS]", SKILLTEXTCOLOR, SKILLTEXTSIZE+1, SKILLFONT, 0, 2, 0.5, "Skill text")
- local GUIS = {}
- for i = 1, #ATTACKS do
- local SKILLFRAME = CreateFrame(WEAPONGUI, 1, 2, UD2(0.05, 0, 0.90-(0.04*i), 0), UD2(0.26, 0, 0.07, 0), C3(0,0,0), C3(0, 0, 0), "Skill Frame")
- local SKILLTEXT = CreateLabel(SKILLFRAME, "["..ATTACKS[i].."]", SKILLTEXTCOLOR, SKILLTEXTSIZE, SKILLFONT, 0, 2, 0, "Skill text")
- SKILLTEXT.TextXAlignment = "Left"
- table.insert(GUIS,SKILLTEXT)
- end
- --//=================================\\
- --|| DAMAGING
- --\\=================================//
- function ONESHOT(MODEL)
- MODEL:BreakJoints()
- for index, CHILD in pairs(MODEL:GetChildren()) do
- if CHILD:IsA("BasePart") and CHILD.Name ~= "HumanoidRootPart" then
- if CHILD.Name == "Head" then
- WACKYEFFECT({Time = MRANDOM(10,30)*5, EffectType = "Skull", Size = VT(CHILD.Size.Z,CHILD.Size.Y,CHILD.Size.Z)*3, Size2 = (VT(CHILD.Size.Z,CHILD.Size.Y,CHILD.Size.Z)*3)*MRANDOM(7,14)/10, Transparency = CHILD.Transparency, Transparency2 = 1, CFrame = CHILD.CFrame, MoveToPos = CHILD.Position+VT(0,MRANDOM(5,8)/1.5,0), RotationX = MRANDOM(-25,25)/35, RotationY = MRANDOM(-25,25)/35, RotationZ = MRANDOM(-25,25)/35, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = nil, SoundVolume = nil})
- else
- WACKYEFFECT({Time = MRANDOM(10,30)*5, EffectType = "Box", Size = CHILD.Size, Size2 = CHILD.Size*MRANDOM(7,14)/10, Transparency = CHILD.Transparency, Transparency2 = 1, CFrame = CHILD.CFrame, MoveToPos = CHILD.Position+VT(0,MRANDOM(5,8)/1.5,0), MRANDOM(-25,25)/35, RotationY = MRANDOM(-25,25)/35, RotationZ = MRANDOM(-25,25)/35, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = nil, SoundVolume = nil})
- end
- CHILD:remove()
- end
- end
- end
- function ApplyAoE(POSITION,RANGE)
- local KILLS = 0
- for index, CHILD in pairs(workspace:GetDescendants()) do
- if CHILD.ClassName == "Model" and CHILD ~= Character then
- local HUM = CHILD:FindFirstChildOfClass("Humanoid")
- if HUM then
- local TORSO = CHILD:FindFirstChild("Torso") or CHILD:FindFirstChild("UpperTorso")
- if TORSO then
- if (TORSO.Position - POSITION).Magnitude <= RANGE then
- ONESHOT(CHILD)
- KILLS = KILLS + 1
- end
- end
- end
- end
- end
- if KILLS > 0 then
- return true
- else
- return false
- end
- end
- --//=================================\\
- --|| NORMAL ATTACKS
- --\\=================================//
- function ShadowBlast()
- CreateSound(GROWL,Head,10,1,false)
- ATTACK = true
- Rooted = false
- local GYRO = IT("BodyGyro",RootPart)
- GYRO.D = 20
- GYRO.P = 4000
- GYRO.MaxTorque = VT(0,40000,0)
- coroutine.resume(coroutine.create(function()
- repeat
- GYRO.CFrame = CF(RootPart.Position,Mouse.Hit.p)
- Swait()
- until ATTACK == false
- GYRO:remove()
- end))
- for i=0, 0.4, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(45)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(-45)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.15*SIZE, 0.5*SIZE, -0.5*SIZE) * ANGLES(RAD(45), RAD(0), RAD(-70)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(0), RAD(-50), RAD(0)) * ANGLES(RAD(-3), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- BULLET = function(CFRAME,TIMER)
- if TIMER > 0 then
- coroutine.resume(coroutine.create(function()
- for i =1, 100 do
- Swait()
- local HIT,POS,NORMAL = Raycast(CFRAME.p,CFRAME.lookVector,1,Character)
- if HIT then
- ApplyAoE(POS,10,15,17,15,false,false)
- for i = 1, 5 do
- WACKYEFFECT({Time = MRANDOM(10,40)/2, EffectType = "Crown", Size = VT(15,0,15), Size2 = VT(31,8,31), Transparency = 0, Transparency2 = 1, CFrame = CF(POS) * ANGLES(RAD(MRANDOM(0,360)), RAD(MRANDOM(0,360)), RAD(MRANDOM(0,360))), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = ECHOBLAST, SoundPitch = 1, SoundVolume = 5})
- end
- local E = MRANDOM(5,7)
- for i = 1, E do
- local CFRAME = CF(POS) * ANGLES(RAD(0), RAD((360/E)*i), RAD(0))
- BULLET(CFRAME,TIMER - 1)
- end
- break
- else
- WACKYEFFECT({Time = MRANDOM(10,40)/2, EffectType = "Skull", Size = (VT(1,1,1)+VT(0.3,0.3,0.3)*SIN(i/4))*6, Size2 = VT(0,0,0), Transparency = 0.5, Transparency2 = 1, CFrame = CFRAME, MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = nil, SoundVolume = nil})
- CFRAME = CFRAME * CF(0,0,-1)
- end
- end
- end))
- end
- end
- BULLET(CF(RootPart.Position,Mouse.Hit.p),3)
- for i=0, 1, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(-25)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(25)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(120)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(0), RAD(60), RAD(0)) * ANGLES(RAD(-4), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- ATTACK = false
- Rooted = false
- end
- function ChainReaction()
- local HITFLOOR,HITPOS = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- if HITFLOOR then
- ATTACK = true
- Rooted = true
- UNANCHOR = false
- local RING,WELD,MESH = MagicRing(RootPart,CF(0,0,0))
- WELD:remove()
- RING.Anchored = true
- RING.CFrame = CF(HITPOS)
- local RINGON = true
- CreateSound(TURNUP,RING,10,1,false)
- coroutine.resume(coroutine.create(function()
- coroutine.resume(coroutine.create(function()
- for i = 1, 70 do
- Swait()
- MESH.Scale = MESH.Scale + VT(15,0,15)
- end
- end))
- repeat
- Swait()
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- until RINGON == false
- for i = 1, 70 do
- Swait()
- MESH.Scale = MESH.Scale - VT(15,0,15)
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- end
- RING:remove()
- end))
- for i=0, 0.6, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, -0.3*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(45), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-35), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 0.3 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-35), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 0.3 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(60), RAD(90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(25), RAD(-90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- end
- EXPLODE = function(POS)
- coroutine.resume(coroutine.create(function()
- local CFRAME = CF(POS)
- for e = 1, 16 do
- local AREA = CF(CFRAME * ANGLES(RAD(0), RAD(MRANDOM(0,360)), RAD(0)) * CF(0,MRANDOM(-25,35),MRANDOM(-75,75)).p)
- for i = 1, 3 do
- WACKYEFFECT({Time = MRANDOM(30,40), EffectType = "Sphere", Size = VT(5,15,5), Size2 = VT(0,0,0), Transparency = 0.5, Transparency2 = 1, CFrame = AREA, MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = IMPACT, SoundPitch = 1, SoundVolume = 5})
- end
- wait(0.1)
- local DETONATE = ApplyAoE(AREA.p,75)
- for i = 1, 5 do
- WACKYEFFECT({Time = MRANDOM(10,40), EffectType = "Wave", Size = VT(0,0,0), Size2 = VT(120,1,120), Transparency = 0.3, Transparency2 = 1, CFrame = AREA * ANGLES(RAD(MRANDOM(0,360)), RAD(MRANDOM(0,360)), RAD(MRANDOM(0,360))), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = 1, SoundVolume = 5})
- WACKYEFFECT({Time = MRANDOM(30,40)*3, EffectType = "Sphere", Size = VT(5,15,5)*3, Size2 = VT(15,20,15)*5, Transparency = 0.5, Transparency2 = 1, CFrame = AREA, MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = ECHOBLAST, SoundPitch = 0.8, SoundVolume = 5})
- end
- if DETONATE == true then
- EXPLODE(AREA.p)
- end
- wait(0.07)
- end
- end))
- end
- coroutine.resume(coroutine.create(function()
- local LOOP = 0
- local RESPOND = false
- for i = 1, 450 do
- Swait()
- LOOP = LOOP + 1
- local REACT = ApplyAoE(RING.Position,25)
- if REACT == true then
- RESPOND = true
- break
- else
- if LOOP >= 10 then
- for i = 1, 3 do
- WACKYEFFECT({Time = MRANDOM(10,40), EffectType = "Wave", Size = VT(15,0,15), Size2 = VT(31,1,31), Transparency = 0.9, Transparency2 = 1, CFrame = CF(RING.Position) * ANGLES(RAD(MRANDOM(0,15)), RAD(MRANDOM(0,360)), RAD(MRANDOM(0,15))), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = 1, SoundVolume = 5})
- end
- end
- end
- end
- RINGON = false
- if RESPOND == true then
- EXPLODE(RING.Position+VT(0,15,0))
- end
- end))
- for i=1, 100 do
- Swait()
- RootPart.CFrame = RootPart.CFrame * CF(0,((100-i)/100)*2,0.6)
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(45 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(35), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(35), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(25), RAD(90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(25), RAD(-90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- UNANCHOR = true
- ATTACK = false
- Rooted = false
- end
- end
- function BlightRavage()
- local HITFLOOR,HITPOS = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- if HITFLOOR then
- ATTACK = true
- Rooted = true
- local RING,WELD,MESH = MagicRing(RootPart,CF(0,0,0))
- WELD:remove()
- RING.Anchored = true
- RING.CFrame = CF(HITPOS)
- local RINGON = true
- CreateSound(TURNUP,Effects,10,0.8,false)
- coroutine.resume(coroutine.create(function()
- coroutine.resume(coroutine.create(function()
- for i = 1, 240 do
- Swait()
- MESH.Scale = MESH.Scale + VT(45,0,45)
- end
- end))
- repeat
- Swait()
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- until RINGON == false
- for i = 1, 240 do
- Swait()
- MESH.Scale = MESH.Scale - VT(45,0,45)
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- end
- RING:remove()
- end))
- for i=0, 4, 0.1 / Animation_Speed do
- Swait()
- local AREA = RootPart.CFrame * ANGLES(RAD(0), RAD(MRANDOM(0,360)), RAD(0))*CF(0,0,MRANDOM(2,18))
- local TIMER = MRANDOM(30,50)/2
- WACKYEFFECT({Time = TIMER, EffectType = "Sphere", Size = VT(3,3,3)/1.1, Size2 = VT(0,15,0)/1.1, Transparency = 0, Transparency2 = 0, CFrame = AREA, MoveToPos = AREA.p+VT(0,MRANDOM(35,60),0), RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(1,1,1), SoundID = nil, SoundPitch = 0.8, SoundVolume = 5})
- WACKYEFFECT({Time = TIMER, EffectType = "Sphere", Size = VT(3,3,3), Size2 = VT(0,15,0), Transparency = 0.5, Transparency2 = 0.5, CFrame = AREA, MoveToPos = AREA.p+VT(0,MRANDOM(35,60),0), RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = 0.8, SoundVolume = 5})
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, -0.3*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(45), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-35), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 0.3 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-35), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 0.3 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(60), RAD(90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(25), RAD(-90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- end
- CreateSound(ECHOBLAST,Effects,10,0.2,false)
- CreateSound(IMPACT,Effects,10,0.2,false)
- coroutine.resume(coroutine.create(function()
- local BOOM = CreatePart(3, Effects, "Neon", 0, 0.2, BRICKC("Really black"), "Effect", VT(0,0,0), true)
- MakeForm(BOOM,"Ball")
- local BOOM2 = CreatePart(3, Effects, "Neon", 0, 0, BRICKC("Pearl"), "Effect", VT(0,0,0), true)
- MakeForm(BOOM2,"Ball")
- for i = 1, 250 do
- Swait()
- BOOM.Size = BOOM.Size + VT(0.7,0.7,0.7)*2
- BOOM2.Size = BOOM.Size - VT(0.3,0.3,0.3)
- ApplyAoE(BOOM.Position,BOOM.Size.X/2)
- local AREA = BOOM.CFrame * ANGLES(RAD(0), RAD(MRANDOM(0,360)), RAD(0))*CF(0,0,BOOM.Size.X/1.7)
- local TIMER = MRANDOM(30,50)
- WACKYEFFECT({Time = TIMER, EffectType = "Sphere", Size = VT(3,3,3)/1.1, Size2 = VT(0,15,0)/1.1, Transparency = 0, Transparency2 = 0, CFrame = AREA, MoveToPos = AREA.p+VT(0,MRANDOM(35,60),0), RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(1,1,1), SoundID = nil, SoundPitch = 0.8, SoundVolume = 5})
- WACKYEFFECT({Time = TIMER, EffectType = "Sphere", Size = VT(3,3,3), Size2 = VT(0,15,0), Transparency = 0.5, Transparency2 = 0.5, CFrame = AREA, MoveToPos = AREA.p+VT(0,MRANDOM(35,60),0), RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = 0.8, SoundVolume = 5})
- end
- RINGON = false
- for i = 1, 20 do
- Swait()
- BOOM.Transparency = BOOM.Transparency + 0.8/20
- BOOM2.Transparency = BOOM2.Transparency + 1/20
- end
- BOOM:remove()
- BOOM2:remove()
- end))
- repeat
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(-15), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(140), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(140), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(60), RAD(0)) * ANGLES(RAD(-3), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-60), RAD(0)) * ANGLES(RAD(-3), RAD(0), RAD(0)), 1 / Animation_Speed)
- until RINGON == false
- ATTACK = false
- Rooted = false
- end
- end
- --//=================================\\
- --|| COLOSSUS ATTACKS
- --\\=================================//
- function SoundTremor()
- local HITFLOOR,HITPOS = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- if HITFLOOR then
- ATTACK = true
- Rooted = true
- for i=0, 1, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(15), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(40), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(40), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -0.5*SIZE, -0.5*SIZE) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- local RING,WELD,MESH = MagicRing(RootPart,CF(0,0,0))
- WELD:remove()
- RING.Anchored = true
- RING.CFrame = CF(HITPOS)
- local RING2,WELD,MESH2 = MagicRing(RootPart,CF(0,0,0))
- WELD:remove()
- RING2.Anchored = true
- RING2.CFrame = CF(HITPOS)
- local RINGON = true
- CreateSound(TURNUP,Effects,4,0.8,false)
- coroutine.resume(coroutine.create(function()
- coroutine.resume(coroutine.create(function()
- for i = 1, 24 do
- Swait()
- MESH.Scale = MESH.Scale + VT(125,0,125)
- MESH2.Scale = MESH.Scale/2
- end
- end))
- repeat
- Swait()
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- RING2.CFrame = RING2.CFrame * ANGLES(RAD(0), RAD(-2), RAD(0))
- until RINGON == false
- for i = 1, 24 do
- Swait()
- MESH.Scale = MESH.Scale - VT(125,0,125)
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- MESH2.Scale = MESH.Scale/2
- RING2.CFrame = RING2.CFrame * ANGLES(RAD(0), RAD(-2), RAD(0))
- end
- RING:remove()
- RING2:remove()
- end))
- local TAUNT = CreateSound(ROAR,Effects,10,1,false)
- for i=0, 4, 0.1 / Animation_Speed do
- Swait()
- TAUNT.Parent = Effects
- local HITFLOOR,HITPOS = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- if HITFLOOR and MRANDOM(1,3) == 1 then
- local AREA = CF(HITPOS) * ANGLES(RAD(0), RAD(MRANDOM(0,360)), RAD(0))*CF(0,0,MRANDOM(3,50))
- local BOULDER = CreatePart(3, Effects, "Neon", 0, 0, "Pearl", "Rocc", VT(10,10,10), true)
- BOULDER.Color = C3(0,0,0)
- BOULDER.CFrame = AREA
- MakeForm(BOULDER,"Ball")
- coroutine.resume(coroutine.create(function()
- FireArc(BOULDER,AREA*CF(0,0,MRANDOM(15,160)).p,60,10,false)
- local POS = BOULDER.Position
- for i = 1, 3 do
- WACKYEFFECT({Time = MRANDOM(10,40), EffectType = "Crown", Size = VT(15,0,15), Size2 = VT(31,1,31)*2, Transparency = 0.4, Transparency2 = 1, CFrame = CF(POS) * ANGLES(RAD(MRANDOM(0,15)), RAD(MRANDOM(0,360)), RAD(MRANDOM(0,15))), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = 1, SoundVolume = 5})
- end
- WACKYEFFECT({Time = MRANDOM(10,40), EffectType = "Sphere", Size = VT(15,15,15), Size2 = VT(51,51,51), Transparency = 0.4, Transparency2 = 1, CFrame = CF(POS), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = IMPACT, SoundPitch = 1, SoundVolume = 10})
- ApplyAoE(POS,35)
- end))
- end
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, -0.2*SIZE, -0.1*SIZE) * ANGLES(RAD(35), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(-25+MRANDOM(-(TAUNT.PlaybackLoudness/25),(TAUNT.PlaybackLoudness/25))), RAD(MRANDOM(-(TAUNT.PlaybackLoudness/15),(TAUNT.PlaybackLoudness/15))), RAD(MRANDOM(-(TAUNT.PlaybackLoudness/25),(TAUNT.PlaybackLoudness/25)))), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0.1*SIZE) * ANGLES(RAD(-55), RAD(0), RAD(42)) * ANGLES(RAD(0), RAD(-70), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0.1*SIZE) * ANGLES(RAD(-55), RAD(0), RAD(-42)) * ANGLES(RAD(0), RAD(70), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(25), RAD(75), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(45), RAD(-75), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- coroutine.resume(coroutine.create(function()
- wait(1)
- RINGON = false
- end))
- ATTACK = false
- Rooted = false
- end
- end
- function BlightedSolarFlares()
- local HITFLOOR,HITPOS = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 4*SIZE, Character)
- if HITFLOOR then
- ATTACK = true
- Rooted = true
- UNANCHOR = false
- for i=0, 0.6, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, -0.3*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(45), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-35), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 0.3 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-35), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 0.3 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(60), RAD(90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(25), RAD(-90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 0.3 / Animation_Speed)
- end
- for i=1, 120 do
- Swait()
- RootPart.CFrame = RootPart.CFrame * CF(0,((100-i)/100)*3,0.7)
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(45 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(35), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(35), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(25), RAD(90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -0.5*SIZE, -0.01*SIZE) * ANGLES(RAD(25), RAD(-90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- local A = false
- coroutine.resume(coroutine.create(function()
- repeat
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(-45), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(150), RAD(0), RAD(-12)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(150), RAD(0), RAD(12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(25), RAD(90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -0.5*SIZE, -0.01*SIZE) * ANGLES(RAD(25), RAD(-90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- until A == true
- for i=0, 0.6, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(25), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(15), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(45), RAD(0), RAD(-12)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(45), RAD(0), RAD(12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(15), RAD(90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -0.5*SIZE, -0.01*SIZE) * ANGLES(RAD(15), RAD(-90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- UNANCHOR = true
- ATTACK = false
- Rooted = false
- end))
- local RING,WELD,MESH = MagicRing(RootPart,CF(0,0,0))
- WELD:remove()
- RING.Anchored = true
- RING.CFrame = CF(RootPart.Position+VT(0,15,0))
- local RINGON = true
- CreateSound(BIGBUILDUP,Effects,10,0.8,false)
- coroutine.resume(coroutine.create(function()
- repeat
- Swait()
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- until RINGON == false
- for i = 1, 140 do
- Swait()
- MESH.Scale = MESH.Scale - VT(45,0,45)
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- end
- RING:remove()
- end))
- for i = 1, 140 do
- Swait()
- MESH.Scale = MESH.Scale + VT(45,0,45)
- end
- wait(0.1)
- A = true
- for i = 1, 16 do
- Swait(4)
- local BULLET = CreatePart(3, Effects, "Neon", 0, 0, "Pearl", "Rocc", VT(7,7,10), true)
- local POS = CF(RING.Position)*ANGLES(RAD(0),RAD(MRANDOM(0,360)),RAD(0))*CF(0,0,MRANDOM(2,45))
- BULLET.CFrame = CF(POS.p,Mouse.Hit.p)
- BULLET.Color = C3(0,0,0)
- MakeForm(BULLET,"Ball")
- coroutine.resume(coroutine.create(function()
- for i =1, 200 do
- Swait()
- local HIT,POS,NORMAL = Raycast(BULLET.Position,BULLET.CFrame.lookVector,5,Character)
- if HIT then
- for i = 1, 3 do
- WACKYEFFECT({Time = MRANDOM(10,40), EffectType = "Crown", Size = VT(15,0,15), Size2 = VT(31,1,31)*7, Transparency = 0.4, Transparency2 = 1, CFrame = CF(POS) * ANGLES(RAD(MRANDOM(0,15)), RAD(MRANDOM(0,360)), RAD(MRANDOM(0,15))), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = 1, SoundVolume = 5})
- end
- WACKYEFFECT({Time = MRANDOM(10,40), EffectType = "Sphere", Size = VT(15,15,15), Size2 = VT(60,150,60)/1.6, Transparency = 0.4, Transparency2 = 1, CFrame = CF(POS), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(1,1,1), SoundID = ECHOBLAST, SoundPitch = 1, SoundVolume = 10})
- WACKYEFFECT({Time = MRANDOM(10,40), EffectType = "Sphere", Size = VT(15,15,15), Size2 = VT(60,150,60), Transparency = 0.4, Transparency2 = 1, CFrame = CF(POS), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = IMPACT, SoundPitch = 1, SoundVolume = 10})
- ApplyAoE(POS,65)
- break
- else
- BULLET.CFrame = Clerp(BULLET.CFrame,CF(BULLET.Position,Mouse.Hit.p),0.001) * CF(0,0,-4)
- end
- end
- BULLET:remove()
- end))
- end
- RINGON = false
- end
- end
- function AlchemicChaos()
- local HITFLOOR,HITPOS = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- if HITFLOOR then
- ATTACK = true
- Rooted = true
- local GYRO = IT("BodyGyro",RootPart)
- GYRO.D = 20
- GYRO.P = 4000
- GYRO.MaxTorque = VT(0,40000,0)
- coroutine.resume(coroutine.create(function()
- repeat
- GYRO.CFrame = CF(RootPart.Position,Mouse.Hit.p)
- Swait()
- until ATTACK == false
- GYRO:remove()
- end))
- CreateSound(ALCHEMY,Effects,5,1,false)
- for i=0, 1, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-25), RAD(0), RAD(70)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-25), RAD(0), RAD(-70)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(0), RAD(80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(0), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- for i=0, 0.3, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, -0.6*SIZE, -0.8*SIZE) * ANGLES(RAD(75), RAD(0), RAD(0)), 2 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0), RAD(0), RAD(0)), 2 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.35*SIZE, 0.5*SIZE, -0.8*SIZE) * ANGLES(RAD(90), RAD(0), RAD(-12)) * RIGHTSHOULDERC0, 2 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.35*SIZE, 0.5*SIZE, -0.8*SIZE) * ANGLES(RAD(90), RAD(0), RAD(12)) * LEFTSHOULDERC0, 2 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(80), RAD(90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 2 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(60), RAD(-90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 2 / Animation_Speed)
- end
- coroutine.resume(coroutine.create(function()
- local CFRAME = RootPart.CFrame
- for i = 1, 40 do
- Swait()
- local POS = CFRAME*CF(MRANDOM(-25,25),0,-i*22)
- local HITFLOOR,HITPOS = Raycast(POS.p+VT(0,1,0), (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- if HITFLOOR then
- coroutine.resume(coroutine.create(function()
- local RING,WELD,MESH = MagicRing(RootPart,CF(0,0,0))
- WELD:remove()
- RING.Anchored = true
- RING.CFrame = CF(HITPOS)
- local RINGON = true
- coroutine.resume(coroutine.create(function()
- repeat
- Swait()
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- until RINGON == false
- for i = 1, 30 do
- Swait()
- MESH.Scale = MESH.Scale - VT(65,0,65)
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- end
- RING:remove()
- end))
- for i = 1, 30 do
- Swait()
- MESH.Scale = MESH.Scale + VT(65,0,65)
- end
- local CFRAME = CF(HITPOS) * ANGLES(RAD(0), RAD(MRANDOM(0,360)), RAD(0)) * ANGLES(RAD(MRANDOM(-15,15)), RAD(0), RAD(0))
- ApplyAoE(HITPOS,25)
- local TIMER = MRANDOM(10,40)
- WACKYEFFECT({Time = TIMER, EffectType = "Sphere", Size = VT(24,34,24), Size2 = VT(0,149,0), Transparency = 0.5, Transparency2 = 0.5, CFrame = CFRAME, MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(1,1,1), SoundID = IMPACT, SoundPitch = 1, SoundVolume = 10})
- WACKYEFFECT({Time = TIMER, EffectType = "Sphere", Size = VT(25,35,25), Size2 = VT(0,150,0), Transparency = 0.5, Transparency2 = 0.5, CFrame = CFRAME, MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = IMPACT, SoundPitch = 1, SoundVolume = 10})
- wait(1)
- RINGON = false
- end))
- end
- end
- end))
- for i=0, 1, 0.1 / Animation_Speed do
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, -0.6*SIZE, -0.8*SIZE) * ANGLES(RAD(75), RAD(0), RAD(0)), 2 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0), RAD(0), RAD(0)), 2 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.35*SIZE, 0.5*SIZE, -0.8*SIZE) * ANGLES(RAD(90), RAD(0), RAD(-12)) * RIGHTSHOULDERC0, 2 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.35*SIZE, 0.5*SIZE, -0.8*SIZE) * ANGLES(RAD(90), RAD(0), RAD(12)) * LEFTSHOULDERC0, 2 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(80), RAD(90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 2 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(60), RAD(-90), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 2 / Animation_Speed)
- end
- ATTACK = false
- Rooted = false
- end
- end
- --//=================================\\
- --|| TWINS ATTACKS
- --\\=================================//
- function DoubleShades()
- ATTACK = true
- Rooted = false
- for i=0, 1, 0.1 / Animation_Speed do
- Swait()
- for E = 1, #SHADES do
- local SHADE = SHADES[E]
- if E == 1 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- elseif E == 2 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(-SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- end
- end
- ATTACK = false
- Rooted = false
- end
- function AThird()
- ATTACK = true
- Rooted = false
- for i=0, 1, 0.1 / Animation_Speed do
- Swait()
- for E = 1, #SHADES do
- local SHADE = SHADES[E]
- if E == 1 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- elseif E == 2 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(-SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- end
- end
- ATTACK = false
- Rooted = false
- end
- function TwinLightning()
- ATTACK = true
- Rooted = false
- for i=0, 1, 0.1 / Animation_Speed do
- Swait()
- for E = 1, #SHADES do
- local SHADE = SHADES[E]
- if E == 1 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- elseif E == 2 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(-SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- end
- end
- ATTACK = false
- Rooted = false
- end
- --//=================================\\
- --|| TRANSFORMATIONS
- --\\=================================//
- function Colossus()
- local HITFLOOR,HITPOS = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- if HITFLOOR then
- ATTACK = true
- Rooted = true
- coroutine.resume(coroutine.create(function()
- if FORM == "Normal" then
- repeat
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(45), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.25*SIZE, 0.5*SIZE, -0.5*SIZE) * ANGLES(RAD(35), RAD(0), RAD(-60)) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.25*SIZE, 0.5*SIZE, -0.5*SIZE) * ANGLES(RAD(35), RAD(0), RAD(60)) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -0.3*SIZE, -0.5*SIZE) * ANGLES(RAD(-15), RAD(70), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -0.3*SIZE, -0.5*SIZE) * ANGLES(RAD(-15), RAD(-70), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 1 / Animation_Speed)
- until ATTACK == false
- else
- repeat
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE) * ANGLES(RAD(-15), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(15), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(35), RAD(0), RAD(32)) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(35), RAD(0), RAD(-32)) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(-15), RAD(70), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(-15), RAD(-70), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 1 / Animation_Speed)
- until ATTACK == false
- end
- end))
- if FORM == "Normal" then
- UNANCHOR = false
- for i = 1, 150 do
- Swait()
- RootPart.CFrame = RootPart.CFrame * CF(0,(1-((150-i)/150))*0.75,0)
- end
- end
- if FORM == "Normal" then
- local RINGS = {}
- local RING,WELD,MESH = MagicRing(RootPart,CF(0,0,0))
- WELD:remove()
- RING.Anchored = true
- RING.CFrame = CF(HITPOS)
- table.insert(RINGS,{RING,MESH,WELD})
- for i = 1, 6 do
- local RING,WELD,MESH = MagicRing(RootPart,CF(0,0,0))
- table.insert(RINGS,{RING,MESH,WELD})
- end
- Swait()
- for E = 1, #RINGS do
- if E ~= 1 then
- local A = RINGS[E][1]
- local C = RINGS[E][3]
- C:remove()
- A.Anchored = true
- A.CFrame = RootPart.CFrame*ANGLES(RAD(MRANDOM(0,360)),RAD(MRANDOM(0,360)),RAD(MRANDOM(0,360)))
- end
- end
- CreateSound(BIGBUILDUP,Effects,10,1,false)
- coroutine.resume(coroutine.create(function()
- repeat
- Swait()
- for E = 1, #RINGS do
- local A = RINGS[E][1]
- local B = RINGS[E][2]
- A.CFrame = A.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- end
- until ATTACK == false
- for i = 1, 150 do
- Swait()
- for E = 1, #RINGS do
- local A = RINGS[E][1]
- local B = RINGS[E][2]
- B.Scale = B.Scale - VT(7,0,7)*2
- A.CFrame = A.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- end
- end
- for E = 1, #RINGS do
- local A = RINGS[E][1]
- local B = RINGS[E][2]
- A:remove()
- end
- end))
- for i = 1, 150 do
- Swait()
- for E = 1, #RINGS do
- local A = RINGS[E][1]
- local B = RINGS[E][2]
- B.Scale = B.Scale + VT(7,0,7)*2
- end
- end
- CreateSound(ROAR,Effects,10,1,false)
- for i = 1, 140 do
- Swait()
- SIZE = SIZE + (1-((140-i)/140))*0.08
- ReSize()
- end
- FORM = "Colossus"
- Speed = 16*4
- Humanoid.JumpPower = 200
- else
- for i = 1, 140 do
- Swait()
- SIZE = SIZE - (1-((140-i)/140))*0.08
- ReSize()
- end
- FORM = "Normal"
- Speed = 16
- Humanoid.JumpPower = 50
- SIZE = 1
- ReSize()
- end
- UNANCHOR = true
- ATTACK = false
- Rooted = false
- end
- end
- function Twins()
- SHADEDIST = 5
- local HITFLOOR,HITPOS = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- if HITFLOOR then
- UNANCHOR = false
- ATTACK = true
- Rooted = true
- local RING,WELD,MESH = MagicRing(RootPart,CF(0,0,0))
- WELD:remove()
- RING.Anchored = true
- RING.CFrame = CF(HITPOS)
- coroutine.resume(coroutine.create(function()
- coroutine.resume(coroutine.create(function()
- for i = 1, 70 do
- Swait()
- MESH.Scale = MESH.Scale + VT(15,0,15)
- end
- end))
- repeat
- Swait()
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(45), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.25*SIZE, 0.5*SIZE, -0.5*SIZE) * ANGLES(RAD(35), RAD(0), RAD(-60)) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.25*SIZE, 0.5*SIZE, -0.5*SIZE) * ANGLES(RAD(35), RAD(0), RAD(60)) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -0.3*SIZE, -0.5*SIZE) * ANGLES(RAD(-15), RAD(70), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -0.3*SIZE, -0.5*SIZE) * ANGLES(RAD(-15), RAD(-70), RAD(0)) * ANGLES(RAD(-2), RAD(0), RAD(0)), 1 / Animation_Speed)
- until ATTACK == false
- for i = 1, 70 do
- Swait()
- MESH.Scale = MESH.Scale - VT(15,0,15)
- RING.CFrame = RING.CFrame * ANGLES(RAD(0), RAD(2), RAD(0))
- end
- RING:remove()
- end))
- if FORM == "Normal" then
- CreateSound(BUILDUP,Effects,10,1,false)
- wait(2)
- TRANS = 1
- CreateSound(ECHOBLAST,Effects,8,1,false)
- for i = 1, 4 do
- WACKYEFFECT({Time = MRANDOM(20,30)*2, EffectType = "Wave", Size = VT(5,2,5), Size2 = VT(35+i,2,35+i), Transparency = 0, Transparency2 = 1, CFrame = CF(HITPOS), MoveToPos = nil, RotationX = 0, RotationY = i, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = nil, SoundVolume = nil})
- end
- WACKYEFFECT({Time = MRANDOM(20,30)*2, EffectType = "Sphere", Size = VT(5,5,5), Size2 = VT(15,15,15), Transparency = 0, Transparency2 = 1, CFrame = CF(RootPart.Position), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = nil, SoundVolume = nil})
- local CLONE1 = CLONE:Clone()
- local CLONE2 = CLONE:Clone()
- CLONE1.Parent = Character
- CLONE2.Parent = Character
- local R1 = CLONE1.HumanoidRootPart
- local T1 = CLONE1.Torso
- local R2 = CLONE2.HumanoidRootPart
- local T2 = CLONE2.Torso
- R1.Anchored = true
- R2.Anchored = true
- R1.CFrame = RootPart.CFrame
- R2.CFrame = RootPart.CFrame
- table.insert(SHADES,{CLONE1,R1["RootJoint"],T1["Neck"],T1["Right Shoulder"],T1["Left Shoulder"],T1["Right Hip"],T1["Left Hip"]})
- table.insert(SHADES,{CLONE2,R2["RootJoint"],T2["Neck"],T2["Right Shoulder"],T2["Left Shoulder"],T2["Right Hip"],T2["Left Hip"]})
- coroutine.resume(coroutine.create(function()
- repeat
- Swait()
- for E = 1, #SHADES do
- local SHADE = SHADES[E]
- if E == 1 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- elseif E == 2 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(-SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- end
- until ATTACK == false
- end))
- wait(1)
- FORM = "Twins"
- Speed = 45
- else
- SHADEDIST = 7
- for i=0, 1.5, 0.1 / Animation_Speed do
- Swait()
- for E = 1, #SHADES do
- local SHADE = SHADES[E]
- if E == 1 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(75)) * ANGLES(RAD(0), RAD(-25), RAD(0)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(-75)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- elseif E == 2 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(-SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(-75)) * ANGLES(RAD(0), RAD(25), RAD(0)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(75)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- end
- end
- SHADEDIST = 0
- for i=0, 0.35, 0.1 / Animation_Speed do
- Swait()
- for E = 1, #SHADES do
- local SHADE = SHADES[E]
- if E == 1 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(SHADEDIST,0,0),0.4)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(85)) * ANGLES(RAD(0), RAD(-25), RAD(0)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- elseif E == 2 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(-SHADEDIST,0,0),0.4)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.2 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(-85)) * ANGLES(RAD(0), RAD(25), RAD(0)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- end
- end
- SHADES[1][1]:remove()
- SHADES[2][1]:remove()
- SHADES = {}
- TRANS = 0.5
- CreateSound(GROWL,Head,10,1,false)
- CreateSound(ECHOBLAST,Effects,8,0.6,false)
- CreateSound(ECHOBLAST,Effects,8,0.8,false)
- CreateSound(ECHOBLAST,Effects,8,1,false)
- for i = 1, 4 do
- WACKYEFFECT({Time = MRANDOM(20,30)*2, EffectType = "Wave", Size = VT(5,2,5), Size2 = VT(35+i,2,35+i), Transparency = 0, Transparency2 = 1, CFrame = CF(HITPOS), MoveToPos = nil, RotationX = 0, RotationY = i, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = nil, SoundVolume = nil})
- end
- WACKYEFFECT({Time = MRANDOM(20,30)*2, EffectType = "Sphere", Size = VT(5,5,5), Size2 = VT(15,15,15), Transparency = 0, Transparency2 = 1, CFrame = CF(RootPart.Position), MoveToPos = nil, RotationX = 0, RotationY = 0, RotationZ = 0, Material = "Neon", Color = C3(0,0,0), SoundID = nil, SoundPitch = nil, SoundVolume = nil})
- FORM = "Normal"
- Speed = 16
- end
- UNANCHOR = true
- ATTACK = false
- Rooted = false
- end
- end
- --//=================================\\
- --|| ASSIGN THINGS TO KEYS
- --\\=================================//
- function MouseDown(Mouse)
- if ATTACK == false then
- end
- end
- function MouseUp(Mouse)
- HOLD = false
- end
- function KeyDown(Key)
- KEYHOLD = true
- if Key == "q" and ATTACK == false then
- if FORM == "Normal" then
- ShadowBlast()
- elseif FORM == "Colossus" then
- SoundTremor()
- elseif FORM == "Twins" then
- DoubleShades()
- end
- end
- if Key == "e" and ATTACK == false then
- if FORM == "Normal" then
- ChainReaction()
- elseif FORM == "Colossus" then
- BlightedSolarFlares()
- elseif FORM == "Twins" then
- AThird()
- end
- end
- if Key == "r" and ATTACK == false then
- if FORM == "Normal" then
- BlightRavage()
- elseif FORM == "Colossus" then
- AlchemicChaos()
- elseif FORM == "Twins" then
- TwinLightning()
- end
- end
- if Key == "z" and ATTACK == false then
- if FORM ~= "Twins" then
- Colossus()
- end
- end
- if Key == "x" and ATTACK == false then
- if FORM ~= "Colossus" then
- Twins()
- end
- end
- end
- function KeyUp(Key)
- KEYHOLD = false
- end
- Mouse.Button1Down:connect(function(NEWKEY)
- MouseDown(NEWKEY)
- end)
- Mouse.Button1Up:connect(function(NEWKEY)
- MouseUp(NEWKEY)
- end)
- Mouse.KeyDown:connect(function(NEWKEY)
- KeyDown(NEWKEY)
- end)
- Mouse.KeyUp:connect(function(NEWKEY)
- KeyUp(NEWKEY)
- end)
- --//=================================\\
- --\\=================================//
- function unanchor()
- for _, c in pairs(Character:GetChildren()) do
- if c:IsA("BasePart") and c ~= RootPart then
- c.Anchored = false
- end
- end
- if UNANCHOR == true then
- RootPart.Anchored = false
- else
- RootPart.Anchored = true
- end
- end
- --//=================================\\
- --|| WRAP THE WHOLE SCRIPT UP
- --\\=================================//
- Humanoid.Changed:connect(function(Jump)
- if Jump == "Jump" and (Disable_Jump == true) then
- Humanoid.Jump = false
- end
- end)
- while true do
- Swait()
- script.Parent = WEAPONGUI
- ANIMATE.Parent = nil
- for _,v in next, Humanoid:GetPlayingAnimationTracks() do
- v:Stop();
- end
- SINE = SINE + CHANGE
- local TORSOVELOCITY = (RootPart.Velocity * VT(1, 0, 1)).magnitude
- local TORSOVERTICALVELOCITY = RootPart.Velocity.y
- local HITFLOOR = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 3.7*SIZE, Character)
- local WALKSPEEDVALUE = 5
- if ANIM == "Walk" and TORSOVELOCITY > 1 and FORM ~= "Twins" then
- RootJoint.C1 = Clerp(RootJoint.C1, ROOTC0 * CF(0, 0, -0.15 * COS(SINE / (WALKSPEEDVALUE / 2))*SIZE) * ANGLES(RAD(0), RAD(0) - RootPart.RotVelocity.Y / 75, RAD(0)), 2 / Animation_Speed)
- Neck.C1 = Clerp(Neck.C1, CF(0, -0.5*SIZE, 0) * ANGLES(RAD(-90), RAD(0), RAD(180)) * ANGLES(RAD(2.5 * SIN(SINE / (WALKSPEEDVALUE / 2))), RAD(0), RAD(0) - Head.RotVelocity.Y / 30), 0.6 / Animation_Speed)
- RightHip.C1 = Clerp(RightHip.C1, CF(0.5*SIZE, 0.875*SIZE - 0.125 * SIN(SINE / WALKSPEEDVALUE)*SIZE - 0.15 * COS(SINE / WALKSPEEDVALUE*2), -0.125 * COS(SINE / WALKSPEEDVALUE) +0.2*SIZE- 0.2*SIZE * COS(SINE / WALKSPEEDVALUE)) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0) - RightLeg.RotVelocity.Y / 75, RAD(0), RAD(76 * COS(SINE / WALKSPEEDVALUE))), 0.8 / Animation_Speed)
- LeftHip.C1 = Clerp(LeftHip.C1, CF(-0.5*SIZE, 0.875*SIZE + 0.125 * SIN(SINE / WALKSPEEDVALUE)*SIZE - 0.15 * COS(SINE / WALKSPEEDVALUE*2), 0.125 * COS(SINE / WALKSPEEDVALUE) +0.2*SIZE+ 0.2*SIZE * COS(SINE / WALKSPEEDVALUE)) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0) + LeftLeg.RotVelocity.Y / 75, RAD(0), RAD(76 * COS(SINE / WALKSPEEDVALUE))), 0.8 / Animation_Speed)
- elseif (ANIM ~= "Walk") or (TORSOVELOCITY < 1) or FORM == "Twins" then
- RootJoint.C1 = Clerp(RootJoint.C1, ROOTC0 * CF(0, 0, 0) * ANGLES(RAD(0), RAD(0), RAD(0)), 0.2 / Animation_Speed)
- Neck.C1 = Clerp(Neck.C1, CF(0, -0.5*SIZE, 0) * ANGLES(RAD(-90), RAD(0), RAD(180)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightHip.C1 = Clerp(RightHip.C1, CF(0.5*SIZE, 1*SIZE, 0) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C1 = Clerp(LeftHip.C1, CF(-0.5*SIZE, 1*SIZE, 0) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- if FORM ~= "Twins" then
- if TORSOVERTICALVELOCITY > 1 and HITFLOOR == nil then
- ANIM = "Jump"
- if ATTACK == false then
- RootJoint.C0 = Clerp(RootJoint.C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0*SIZE, 0*SIZE, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(-20), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-40), RAD(0), RAD(20)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-40), RAD(0), RAD(-20)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.3*SIZE) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(-5), RAD(0), RAD(-20)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, -0.3*SIZE) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(-5), RAD(0), RAD(20)), 1 / Animation_Speed)
- end
- elseif TORSOVERTICALVELOCITY < -1 and HITFLOOR == nil then
- ANIM = "Fall"
- if ATTACK == false then
- RootJoint.C0 = Clerp(RootJoint.C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0*SIZE, 0*SIZE, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(20), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(35), RAD(0), RAD(30)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(35), RAD(0), RAD(-30)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -0.3*SIZE, -0.5*SIZE) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(20)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 1 / Animation_Speed)
- end
- elseif TORSOVELOCITY < 1 and HITFLOOR ~= nil then
- ANIM = "Idle"
- if ATTACK == false then
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0 + 0.05*SIZE * COS(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(25)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(-25)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(0), RAD(60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(0), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- elseif TORSOVELOCITY > 1 and HITFLOOR ~= nil then
- ANIM = "Walk"
- if ATTACK == false then
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, -0.1*SIZE) * ANGLES(RAD(15), RAD(0), RAD(10 * SIN(SINE / WALKSPEEDVALUE))), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(5 - 1 * SIN(SINE / (WALKSPEEDVALUE / 2))), RAD(0), RAD(-10 * SIN(SINE / WALKSPEEDVALUE))), 1/ Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(60 * COS(SINE / WALKSPEEDVALUE)), RAD(0), RAD(5)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(-60 * COS(SINE / WALKSPEEDVALUE)), RAD(0), RAD(-5)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE , -1*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(80), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(-15)), 2 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(-80), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(15)), 2 / Animation_Speed)
- end
- end
- else
- Swait()
- RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0*SIZE, 0*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(0), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- RightHip.C0 = Clerp(RightHip.C0, CF(1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- LeftHip.C0 = Clerp(LeftHip.C0, CF(-1*SIZE, -1*SIZE, -0.01*SIZE) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(0)), 1 / Animation_Speed)
- if #SHADES ~= 0 and ATTACK == false then
- for E = 1, #SHADES do
- local SHADE = SHADES[E]
- if E == 1 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.4 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- elseif E == 2 and SHADE[1].HumanoidRootPart then
- SHADE[1].HumanoidRootPart.CFrame = Clerp(SHADE[1].HumanoidRootPart.CFrame,RootPart.CFrame*CF(-SHADEDIST,0,0),0.2)
- SHADE[2].C0 = Clerp(SHADE[2].C0, ROOTC0 * CF(0*SIZE, 0*SIZE, 0.4 + 0.1*SIZE * SIN(SINE / 12)) * ANGLES(RAD(0), RAD(0), RAD(-25)), 1 / Animation_Speed)
- SHADE[3].C0 = Clerp(SHADE[3].C0, NECKC0 * CF(0, 0, 0 + ((1*SIZE) - 1)) * ANGLES(RAD(0 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(25)), 1 / Animation_Speed)
- SHADE[4].C0 = Clerp(SHADE[4].C0, CF(1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(42 - 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(60), RAD(0)) * RIGHTSHOULDERC0, 1 / Animation_Speed)
- SHADE[5].C0 = Clerp(SHADE[5].C0, CF(-1.5*SIZE, 0.5*SIZE, 0*SIZE) * ANGLES(RAD(30 - 7 * SIN(SINE / 6)), RAD(0), RAD(-42 + 7 * COS(SINE / 12))) * ANGLES(RAD(0), RAD(-60), RAD(0)) * LEFTSHOULDERC0, 1 / Animation_Speed)
- SHADE[6].C0 = Clerp(SHADE[6].C0, CF(1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(80), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- SHADE[7].C0 = Clerp(SHADE[7].C0, CF(-1*SIZE, -1*SIZE - 0.05*SIZE * COS(SINE / 12), -0.01*SIZE) * ANGLES(RAD(-15), RAD(-60), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 1 / Animation_Speed)
- end
- end
- end
- end
- unanchor()
- Humanoid.MaxHealth = 5e5
- Humanoid.Health = 5e5
- if Rooted == false then
- Disable_Jump = false
- Humanoid.WalkSpeed = Speed
- elseif Rooted == true then
- Disable_Jump = true
- Humanoid.WalkSpeed = 0
- end
- for _, c in pairs(CLONE:GetChildren()) do
- if c.ClassName == "Part" and c.Name ~= "Eye" then
- c.Material = "Neon"
- if c.Name ~= "HumanoidRootPart" then
- c.Transparency = TRANS
- end
- c.CanCollide = false
- if c:FindFirstChildOfClass("ParticleEmitter") then
- c:FindFirstChildOfClass("ParticleEmitter"):remove()
- end
- c.Color = C3(0,0,0)
- if c.Name == "Head" then
- if c:FindFirstChild("face") then
- c.face.Texture = "http://www.roblox.com/asset/?id=536552092"
- c.face.Transparency = TRANS
- end
- end
- elseif c.ClassName == "CharacterMesh" or c.ClassName == "Accessory" or c.Name == "Body Colors" or c.ClassName == "Humanoid" then
- c:remove()
- elseif (c.ClassName == "Shirt" or c.ClassName == "Pants") and c.Name ~= "Cloth" then
- c:remove()
- end
- end
- for _, c in pairs(Character:GetChildren()) do
- if c.ClassName == "Part" and c.Name ~= "Eye" then
- c.Material = "Neon"
- if c ~= RootPart then
- c.Transparency = TRANS
- end
- if c:FindFirstChildOfClass("ParticleEmitter") then
- c:FindFirstChildOfClass("ParticleEmitter"):remove()
- end
- c.Color = C3(0,0,0)
- if c == Head then
- if c:FindFirstChild("face") then
- c.face.Texture = "http://www.roblox.com/asset/?id=536552092"
- c.face.Transparency = TRANS
- end
- end
- elseif c.ClassName == "CharacterMesh" or c.ClassName == "Accessory" or c.Name == "Body Colors" then
- c:remove()
- elseif (c.ClassName == "Shirt" or c.ClassName == "Pants") and c.Name ~= "Cloth" then
- c:remove()
- end
- end
- BMUSIC.SoundId = "rbxassetid://177031949"
- BMUSIC.Looped = true
- BMUSIC.Pitch = 1
- BMUSIC.Volume = 7
- BMUSIC.Playing = true
- BMUSIC.Parent = Character
- Humanoid.Name = "Shadowmax"
- if FORM == "Normal" then
- for i = 1, #GUIS do
- GUIS[i].Text = "["..ATTACKS[i].."]"
- end
- elseif FORM == "Colossus" then
- for i = 1, #GUIS do
- GUIS[i].Text = "["..ATTACKS2[i].."]"
- end
- elseif FORM == "Twins" then
- for i = 1, #GUIS do
- GUIS[i].Text = "["..ATTACKS3[i].."]"
- end
- end
- end
- --//=================================\\
- --\\=================================//
- --//====================================================\\--
- --|| END OF SCRIPT
- --\\====================================================//--
Add Comment
Please, Sign In to add comment