Advertisement
MarcAndrew

Untitled

Mar 22nd, 2018
341
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. --//====================================================\\--
  2. --|| CREATED BY SHACKLUSTER, EDIT BY AINGOAM
  3. --\\====================================================//--
  4.  
  5.  
  6.  
  7. wait(0.2)
  8.  
  9.  
  10.  
  11. Player = game:GetService("Players").LocalPlayer
  12. PlayerGui = Player.PlayerGui
  13. Cam = workspace.CurrentCamera
  14. Backpack = Player.Backpack
  15. Character = Player.Character
  16. Humanoid = Character.Humanoid
  17. Mouse = Player:GetMouse()
  18. RootPart = Character["HumanoidRootPart"]
  19. Torso = Character["Torso"]
  20. Head = Character["Head"]
  21. RightArm = Character["Right Arm"]
  22. LeftArm = Character["Left Arm"]
  23. RightLeg = Character["Right Leg"]
  24. LeftLeg = Character["Left Leg"]
  25. RootJoint = RootPart["RootJoint"]
  26. Neck = Torso["Neck"]
  27. RightShoulder = Torso["Right Shoulder"]
  28. LeftShoulder = Torso["Left Shoulder"]
  29. RightHip = Torso["Right Hip"]
  30. LeftHip = Torso["Left Hip"]
  31. local sick = Instance.new("Sound",Torso)
  32. sick.SoundId = "rbxassetid://145655556"
  33. sick.Looped = true
  34. sick.Pitch = 1
  35. sick.Volume = 8
  36. sick.TimePosition = 16.3
  37. sick:Play()
  38.  
  39. local naeeym2 = Instance.new("BillboardGui",Character)
  40. naeeym2.AlwaysOnTop = true
  41. naeeym2.Size = UDim2.new(5,35,2,35)
  42. naeeym2.StudsOffset = Vector3.new(0,3,0)
  43. naeeym2.Adornee = Character.Head
  44. naeeym2.Name = "Name"
  45. naeeym2.MaxDistance = 200
  46. local tecks2 = Instance.new("TextLabel",naeeym2)
  47. tecks2.BackgroundTransparency = 1
  48. tecks2.TextScaled = true
  49. tecks2.BorderSizePixel = 0
  50. tecks2.Text = "Βĺâçķ C͎̕o̼̹͆d͓͋͜e̝̞"
  51. tecks2.Font = "Antique"
  52. tecks2.TextSize = 30
  53. tecks2.TextStrokeTransparency = 1
  54. tecks2.TextColor3 = Color3.new(0,0,0)
  55. tecks2.TextStrokeColor3 = Color3.new(0,0,0)
  56. tecks2.Size = UDim2.new(1,0,0.5,0)
  57. tecks2.Parent = naeeym2
  58.  
  59. IT = Instance.new
  60. CF = CFrame.new
  61. VT = Vector3.new
  62. RAD = math.rad
  63. C3 = Color3.new
  64. UD2 = UDim2.new
  65. BRICKC = BrickColor.new
  66. ANGLES = CFrame.Angles
  67. EULER = CFrame.fromEulerAnglesXYZ
  68. COS = math.cos
  69. ACOS = math.acos
  70. SIN = math.sin
  71. ASIN = math.asin
  72. ABS = math.abs
  73. MRANDOM = math.random
  74. FLOOR = math.floor
  75.  
  76. function CreateMesh(MESH, PARENT, MESHTYPE, MESHID, TEXTUREID, SCALE, OFFSET)
  77. local NEWMESH = IT(MESH)
  78. if MESH == "SpecialMesh" then
  79. NEWMESH.MeshType = MESHTYPE
  80. if MESHID ~= "nil" and MESHID ~= "" then
  81. NEWMESH.MeshId = "http://www.roblox.com/asset/?id="..MESHID
  82. end
  83. if TEXTUREID ~= "nil" and TEXTUREID ~= "" then
  84. NEWMESH.TextureId = "http://www.roblox.com/asset/?id="..TEXTUREID
  85. end
  86. end
  87. NEWMESH.Offset = OFFSET or VT(0, 0, 0)
  88. NEWMESH.Scale = SCALE
  89. NEWMESH.Parent = PARENT
  90. return NEWMESH
  91. end
  92.  
  93. function CreatePart(FORMFACTOR, PARENT, MATERIAL, REFLECTANCE, TRANSPARENCY, BRICKCOLOR, NAME, SIZE)
  94. local NEWPART = IT("Part")
  95. NEWPART.formFactor = FORMFACTOR
  96. NEWPART.Reflectance = REFLECTANCE
  97. NEWPART.Transparency = TRANSPARENCY
  98. NEWPART.CanCollide = false
  99. NEWPART.Locked = true
  100. NEWPART.BrickColor = BRICKC(tostring(BRICKCOLOR))
  101. NEWPART.Name = NAME
  102. NEWPART.Size = SIZE
  103. NEWPART.Position = Torso.Position
  104. NEWPART.Material = MATERIAL
  105. NEWPART:BreakJoints()
  106. NEWPART.Parent = PARENT
  107. return NEWPART
  108. end
  109.  
  110.  
  111. --//=================================\\
  112. --|| CUSTOMIZATION
  113. --\\=================================//
  114.  
  115. Class_Name = "₱Ɽł₴₥.exe"
  116. Weapon_Name = "Add-ons"
  117.  
  118. Custom_Colors = {
  119. Custom_Color_1 = BRICKC("Toothpaste"); --1st color for the weapon.
  120. Custom_Color_2 = BRICKC("Toothpaste"); --2nd color for the weapon.
  121.  
  122. Custom_Color_3 = BRICKC("Toothpaste"); --Color for the abilities.
  123. Custom_Color_4 = BRICKC("Toothpaste"); --Color for the secondary bar.
  124. Custom_Color_5 = BRICKC("Toothpaste"); --Color for the mana bar.
  125. Custom_Color_6 = BRICKC("Toothpaste"); --Color for the health bar.
  126. Custom_Color_7 = BRICKC("Toothpaste"); --Color for the stun bar.
  127.  
  128. Custom_Color_8 = BRICKC("Toothpaste"); --Background for the mana bar.
  129. Custom_Color_9 = BRICKC("Toothpaste"); --Background for the secondary mana bar.
  130. Custom_Color_10 = BRICKC("Toothpaste"); --Background for the stun bar.
  131. Custom_Color_11 = BRICKC("Toothpaste"); --Background for the health bar.
  132. Custom_Color_12 = BRICKC("Toothpaste"); --Background for the abilities.
  133. }
  134.  
  135.  
  136. Player_Size = 1 --Size of the player.
  137. Animation_Speed = 3
  138. Frame_Speed = 1 / 60 -- (1 / 30) OR (1 / 60)
  139.  
  140. local Speed = 36
  141. local Effects2 = {}
  142.  
  143. --//=================================\\
  144. --|| END OF CUSTOMIZATION
  145. --\\=================================//
  146.  
  147. local function weldBetween(a, b)
  148. local weldd = Instance.new("ManualWeld")
  149. weldd.Part0 = a
  150. weldd.Part1 = b
  151. weldd.C0 = CFrame.new()
  152. weldd.C1 = b.CFrame:inverse() * a.CFrame
  153. weldd.Parent = a
  154. return weldd
  155. end
  156.  
  157. function createaccessory(attachmentpart,mesh,texture,scale,offset,color)
  158. local acs = Instance.new("Part")
  159. acs.CanCollide = false
  160. acs.Anchored = false
  161. acs.Size = Vector3.new(0,0,0)
  162. acs.CFrame = attachmentpart.CFrame
  163. acs.Parent = Character
  164. acs.BrickColor = color
  165. local meshs = Instance.new("SpecialMesh")
  166. meshs.MeshId = mesh
  167. meshs.TextureId = texture
  168. meshs.Parent = acs
  169. meshs.Scale = scale
  170. meshs.Offset = offset
  171. weldBetween(attachmentpart,acs)
  172. end
  173.  
  174. function createbodypart(TYPE,COLOR,PART,OFFSET,SIZE)
  175. if TYPE == "Gem" then
  176. local acs = CreatePart(3, Character, "Neon", 0, 0, COLOR, "Part", VT(0,0,0))
  177. acs.Anchored = false
  178. acs.CanCollide = false
  179. acs.CFrame = PART.CFrame
  180. local acs2 = CreateMesh("SpecialMesh", acs, "FileMesh", "9756362", "", SIZE, OFFSET)
  181. weldBetween(PART,acs)
  182. elseif TYPE == "Skull" then
  183. local acs = CreatePart(3, Character, "Neon", 0, 0, COLOR, "Part", VT(0,0,0))
  184. acs.Anchored = false
  185. acs.CanCollide = false
  186. acs.CFrame = PART.CFrame
  187. local acs2 = CreateMesh("SpecialMesh", acs, "FileMesh", "4770583", "", SIZE, OFFSET)
  188. weldBetween(PART,acs)
  189. elseif TYPE == "Eye" then
  190. local acs = CreatePart(3, Character, "Neon", 0, 0, COLOR, "Part", VT(0,0,0))
  191. acs.Anchored = false
  192. acs.CanCollide = false
  193. acs.CFrame = PART.CFrame
  194. local acs2 = CreateMesh("SpecialMesh", acs, "Sphere", "", "", SIZE, OFFSET)
  195. weldBetween(PART,acs)
  196. end
  197. end
  198.  
  199. --//=================================\\
  200. --|| USEFUL VALUES
  201. --\\=================================//
  202.  
  203. local ROOTC0 = CF(0, 0, 0) * ANGLES(RAD(-90), RAD(0), RAD(180))
  204. local NECKC0 = CF(0, 1, 0) * ANGLES(RAD(-90), RAD(0), RAD(180))
  205. local RIGHTSHOULDERC0 = CF(-0.5, 0, 0) * ANGLES(RAD(0), RAD(90), RAD(0))
  206. local LEFTSHOULDERC0 = CF(0.5, 0, 0) * ANGLES(RAD(0), RAD(-90), RAD(0))
  207. local CO1 = 0
  208. local CO2 = 0
  209. local CO3 = 0
  210. local CO4 = 0
  211. local CHANGEDEFENSE = 0
  212. local CHANGEDAMAGE = 0
  213. local CHANGEMOVEMENT = 0
  214. local ANIM = "Idle"
  215. local ATTACK = false
  216. local EQUIPPED = false
  217. local HOLD = false
  218. local COMBO = 1
  219. local LASTPOINT = nil
  220. local BLCF = nil
  221. local SCFR = nil
  222. local STAGGERHITANIM = false
  223. local STAGGERANIM = false
  224. local STUNANIM = false
  225. local CRITCHANCENUMBER = 0
  226. local IDLENUMBER = 0
  227. local DONUMBER = 0
  228. local HANDIDLE = false
  229. local SINE = 0
  230. local CHANGE = 2 / Animation_Speed
  231. local WALKINGANIM = false
  232. local WALK = 0
  233. local KEYHOLD = false
  234. local DISABLEJUMPING = false
  235. local HASBEENBLOCKED = false
  236. local STUNDELAYNUMBER = 0
  237. local MANADELAYNUMBER = 0
  238. local SECONDARYMANADELAYNUMBER = 0
  239. local ROBLOXIDLEANIMATION = IT("Animation")
  240. ROBLOXIDLEANIMATION.Name = "Roblox Idle Animation"
  241. ROBLOXIDLEANIMATION.AnimationId = "http://www.roblox.com/asset/?id=180435571"
  242. --ROBLOXIDLEANIMATION.Parent = Humanoid
  243. local WEAPONGUI = IT("ScreenGui", nil)
  244. WEAPONGUI.Name = "Weapon GUI"
  245. local WEAPONTOOL = IT("HopperBin", nil)
  246. WEAPONTOOL.Name = Weapon_Name
  247. local Weapon = IT("Model")
  248. Weapon.Name = Weapon_Name
  249. local Effects = IT("Folder", Weapon)
  250. Effects.Name = "Effects"
  251. local ANIMATOR = Humanoid.Animator
  252. local ANIMATE = Character.Animate
  253. local HITPLAYERSOUNDS = {--[["199149137", "199149186", "199149221", "199149235", "199149269", "199149297"--]]"263032172", "263032182", "263032200", "263032221", "263032252", "263033191"}
  254. local HITARMORSOUNDS = {"199149321", "199149338", "199149367", "199149409", "199149452"}
  255. local HITWEAPONSOUNDS = {"199148971", "199149025", "199149072", "199149109", "199149119"}
  256. local HITBLOCKSOUNDS = {"199148933", "199148947"}
  257. local CUTSOUNDS = {"645750958","645747150"}
  258. local VICIOUSWOOSH = "658941933"
  259. local RELEASESOUND = "565538688"
  260. local CHARGESOUND = "565538601"
  261. local UNANCHOR = true
  262. local MAGICPARTICLE = "341277531"
  263.  
  264. --//=================================\\
  265. --\\=================================//
  266.  
  267. --//=================================\\
  268. --|| STATS
  269. --\\=================================//
  270.  
  271. if Character:FindFirstChild("Stats") ~= nil then
  272. Character:FindFirstChild("Stats").Parent = nil
  273. end
  274.  
  275. local Stats = IT("Folder", nil)
  276. Stats.Name = "Stats"
  277. local ChangeStat = IT("Folder", Stats)
  278. ChangeStat.Name = "ChangeStat"
  279. local Defense = IT("NumberValue", Stats)
  280. Defense.Name = "Defense"
  281. Defense.Value = 1
  282. local Movement = IT("NumberValue", Stats)
  283. Movement.Name = "Movement"
  284. Movement.Value = 1
  285. local Damage = IT("NumberValue", Stats)
  286. Damage.Name = "Damage"
  287. Damage.Value = 1
  288. local Mana = IT("NumberValue", Stats)
  289. Mana.Name = "Mana"
  290. Mana.Value = 0
  291. local SecondaryMana = IT("NumberValue", Stats)
  292. SecondaryMana.Name = "SecondaryMana"
  293. SecondaryMana.Value = 0
  294. local CanCrit = IT("BoolValue", Stats)
  295. CanCrit.Name = "CanCrit"
  296. CanCrit.Value = false
  297. local CritChance = IT("NumberValue", Stats)
  298. CritChance.Name = "CritChance"
  299. CritChance.Value = 20
  300. local CanPenetrateArmor = IT("BoolValue", Stats)
  301. CanPenetrateArmor.Name = "CanPenetrateArmor"
  302. CanPenetrateArmor.Value = false
  303. local AntiTeamKill = IT("BoolValue", Stats)
  304. AntiTeamKill.Name = "AntiTeamKill"
  305. AntiTeamKill.Value = false
  306. local Rooted = IT("BoolValue", Stats)
  307. Rooted.Name = "Rooted"
  308. Rooted.Value = false
  309. local Block = IT("BoolValue", Stats)
  310. Block.Name = "Block"
  311. Block.Value = false
  312. local RecentEnemy = IT("ObjectValue", Stats)
  313. RecentEnemy.Name = "RecentEnemy"
  314. RecentEnemy.Value = nil
  315. local StaggerHit = IT("BoolValue", Stats)
  316. StaggerHit.Name = "StaggerHit"
  317. StaggerHit.Value = false
  318. local Stagger = IT("BoolValue", Stats)
  319. Stagger.Name = "Stagger"
  320. Stagger.Value = false
  321. local Stun = IT("BoolValue", Stats)
  322. Stun.Name = "Stun"
  323. Stun.Value = false
  324. local StunValue = IT("NumberValue", Stats)
  325. StunValue.Name = "StunValue"
  326. StunValue.Value = 0
  327.  
  328.  
  329. --//=================================\\
  330. --\\=================================//
  331.  
  332.  
  333.  
  334.  
  335.  
  336. --//=================================\\
  337. --|| DEBUFFS / BUFFS
  338. --\\=================================//
  339.  
  340. local DEFENSECHANGE1 = IT("NumberValue", ChangeStat)
  341. DEFENSECHANGE1.Name = "ChangeDefense"
  342. DEFENSECHANGE1.Value = 0
  343.  
  344. local MOVEMENTCHANGE1 = IT("NumberValue", nil)
  345. MOVEMENTCHANGE1.Name = "ChangeMovement"
  346. MOVEMENTCHANGE1.Value = 0
  347.  
  348. --//=================================\\
  349. --\\=================================//
  350.  
  351.  
  352.  
  353.  
  354.  
  355. --//=================================\\
  356. --|| SAZERENOS' ARTIFICIAL HEARTBEAT
  357. --\\=================================//
  358.  
  359. ArtificialHB = Instance.new("BindableEvent", script)
  360. ArtificialHB.Name = "ArtificialHB"
  361.  
  362. script:WaitForChild("ArtificialHB")
  363.  
  364. frame = Frame_Speed
  365. tf = 0
  366. allowframeloss = false
  367. tossremainder = false
  368. lastframe = tick()
  369. script.ArtificialHB:Fire()
  370.  
  371. game:GetService("RunService").Heartbeat:connect(function(s, p)
  372. tf = tf + s
  373. if tf >= frame then
  374. if allowframeloss then
  375. script.ArtificialHB:Fire()
  376. lastframe = tick()
  377. else
  378. for i = 1, math.floor(tf / frame) do
  379. script.ArtificialHB:Fire()
  380. end
  381. lastframe = tick()
  382. end
  383. if tossremainder then
  384. tf = 0
  385. else
  386. tf = tf - frame * math.floor(tf / frame)
  387. end
  388. end
  389. end)
  390.  
  391. --//=================================\\
  392. --\\=================================//
  393.  
  394.  
  395.  
  396.  
  397.  
  398. --//=================================\\
  399. --|| SOME FUNCTIONS
  400. --\\=================================//
  401.  
  402. function Raycast(POSITION, DIRECTION, RANGE, IGNOREDECENDANTS)
  403. return workspace:FindPartOnRay(Ray.new(POSITION, DIRECTION.unit * RANGE), IGNOREDECENDANTS)
  404. end
  405.  
  406. function PositiveAngle(NUMBER)
  407. if NUMBER >= 0 then
  408. NUMBER = 0
  409. end
  410. return NUMBER
  411. end
  412.  
  413. function NegativeAngle(NUMBER)
  414. if NUMBER <= 0 then
  415. NUMBER = 0
  416. end
  417. return NUMBER
  418. end
  419.  
  420. function Swait(NUMBER)
  421. if NUMBER == 0 or NUMBER == nil then
  422. ArtificialHB.Event:wait()
  423. else
  424. for i = 1, NUMBER do
  425. ArtificialHB.Event:wait()
  426. end
  427. end
  428. end
  429.  
  430. function QuaternionFromCFrame(cf)
  431. local mx, my, mz, m00, m01, m02, m10, m11, m12, m20, m21, m22 = cf:components()
  432. local trace = m00 + m11 + m22
  433. if trace > 0 then
  434. local s = math.sqrt(1 + trace)
  435. local recip = 0.5 / s
  436. return (m21 - m12) * recip, (m02 - m20) * recip, (m10 - m01) * recip, s * 0.5
  437. else
  438. local i = 0
  439. if m11 > m00 then
  440. i = 1
  441. end
  442. if m22 > (i == 0 and m00 or m11) then
  443. i = 2
  444. end
  445. if i == 0 then
  446. local s = math.sqrt(m00 - m11 - m22 + 1)
  447. local recip = 0.5 / s
  448. return 0.5 * s, (m10 + m01) * recip, (m20 + m02) * recip, (m21 - m12) * recip
  449. elseif i == 1 then
  450. local s = math.sqrt(m11 - m22 - m00 + 1)
  451. local recip = 0.5 / s
  452. return (m01 + m10) * recip, 0.5 * s, (m21 + m12) * recip, (m02 - m20) * recip
  453. elseif i == 2 then
  454. local s = math.sqrt(m22 - m00 - m11 + 1)
  455. local recip = 0.5 / s return (m02 + m20) * recip, (m12 + m21) * recip, 0.5 * s, (m10 - m01) * recip
  456. end
  457. end
  458. end
  459.  
  460. function QuaternionToCFrame(px, py, pz, x, y, z, w)
  461. local xs, ys, zs = x + x, y + y, z + z
  462. local wx, wy, wz = w * xs, w * ys, w * zs
  463. local xx = x * xs
  464. local xy = x * ys
  465. local xz = x * zs
  466. local yy = y * ys
  467. local yz = y * zs
  468. local zz = z * zs
  469. 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))
  470. end
  471.  
  472. function QuaternionSlerp(a, b, t)
  473. local cosTheta = a[1] * b[1] + a[2] * b[2] + a[3] * b[3] + a[4] * b[4]
  474. local startInterp, finishInterp;
  475. if cosTheta >= 0.0001 then
  476. if (1 - cosTheta) > 0.0001 then
  477. local theta = ACOS(cosTheta)
  478. local invSinTheta = 1 / SIN(theta)
  479. startInterp = SIN((1 - t) * theta) * invSinTheta
  480. finishInterp = SIN(t * theta) * invSinTheta
  481. else
  482. startInterp = 1 - t
  483. finishInterp = t
  484. end
  485. else
  486. if (1 + cosTheta) > 0.0001 then
  487. local theta = ACOS(-cosTheta)
  488. local invSinTheta = 1 / SIN(theta)
  489. startInterp = SIN((t - 1) * theta) * invSinTheta
  490. finishInterp = SIN(t * theta) * invSinTheta
  491. else
  492. startInterp = t - 1
  493. finishInterp = t
  494. end
  495. end
  496. 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
  497. end
  498.  
  499. function Clerp(a, b, t)
  500. local qa = {QuaternionFromCFrame(a)}
  501. local qb = {QuaternionFromCFrame(b)}
  502. local ax, ay, az = a.x, a.y, a.z
  503. local bx, by, bz = b.x, b.y, b.z
  504. local _t = 1 - t
  505. return QuaternionToCFrame(_t * ax + t * bx, _t * ay + t * by, _t * az + t * bz, QuaternionSlerp(qa, qb, t))
  506. end
  507.  
  508. function CreateFrame(PARENT, TRANSPARENCY, BORDERSIZEPIXEL, POSITION, SIZE, COLOR, BORDERCOLOR, NAME)
  509. local frame = IT("Frame")
  510. frame.BackgroundTransparency = TRANSPARENCY
  511. frame.BorderSizePixel = BORDERSIZEPIXEL
  512. frame.Position = POSITION
  513. frame.Size = SIZE
  514. frame.BackgroundColor3 = COLOR
  515. frame.BorderColor3 = BORDERCOLOR
  516. frame.Name = NAME
  517. frame.Parent = PARENT
  518. return frame
  519. end
  520.  
  521. function CreateLabel(PARENT, TEXT, TEXTCOLOR, TEXTFONTSIZE, TEXTFONT, TRANSPARENCY, BORDERSIZEPIXEL, STROKETRANSPARENCY, NAME)
  522. local label = IT("TextLabel")
  523. label.BackgroundTransparency = 1
  524. label.Size = UD2(1, 0, 1, 0)
  525. label.Position = UD2(0, 0, 0, 0)
  526. label.TextColor3 = C3(255, 255, 255)
  527. label.TextStrokeTransparency = STROKETRANSPARENCY
  528. label.TextTransparency = TRANSPARENCY
  529. label.FontSize = TEXTFONTSIZE
  530. label.Font = TEXTFONT
  531. label.BorderSizePixel = BORDERSIZEPIXEL
  532. label.TextScaled = true
  533. label.Text = TEXT
  534. label.Name = NAME
  535. label.Parent = PARENT
  536. return label
  537. end
  538.  
  539. function NoOutlines(PART)
  540. PART.TopSurface, PART.BottomSurface, PART.LeftSurface, PART.RightSurface, PART.FrontSurface, PART.BackSurface = 10, 10, 10, 10, 10, 10
  541. end
  542.  
  543.  
  544. function CreateWeldOrSnapOrMotor(TYPE, PARENT, PART0, PART1, C0, C1)
  545. local NEWWELD = IT(TYPE)
  546. NEWWELD.Part0 = PART0
  547. NEWWELD.Part1 = PART1
  548. NEWWELD.C0 = C0
  549. NEWWELD.C1 = C1
  550. NEWWELD.Parent = PARENT
  551. return NEWWELD
  552. end
  553.  
  554. function CreateSound(ID, PARENT, VOLUME, PITCH, DOESLOOP)
  555. local NEWSOUND = nil
  556. coroutine.resume(coroutine.create(function()
  557. NEWSOUND = IT("Sound", PARENT)
  558. NEWSOUND.Volume = VOLUME
  559. NEWSOUND.Pitch = PITCH
  560. NEWSOUND.SoundId = "http://www.roblox.com/asset/?id="..ID
  561. --Swait()
  562. NEWSOUND:play()
  563. if DOESLOOP == false then
  564. repeat Swait() until NEWSOUND.Playing == false
  565. NEWSOUND:remove()
  566. elseif DOESLOOP == true then
  567. NEWSOUND.Looped = true
  568. end
  569. end))
  570. return NEWSOUND
  571. end
  572.  
  573. function CFrameFromTopBack(at, top, back)
  574. local right = top:Cross(back)
  575. 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)
  576. end
  577.  
  578. function CreateWave(inair,size,doesrotate,rotatedirection,waitt,part,offset,color)
  579. local wave = CreatePart(3, Effects, "Neon", 0, 0.5, BRICKC(color), "Effect", VT(0,0,0))
  580. local mesh = IT("SpecialMesh",wave)
  581. mesh.MeshType = "FileMesh"
  582. wave.Anchored = true
  583. mesh.MeshId = "http://www.roblox.com/asset/?id=20329976"
  584. mesh.Scale = VT(size,size,size)
  585. mesh.Offset = VT(0,0,-size/8)
  586. wave.CFrame = CF(part.p) * CF(0,offset,0) * ANGLES(RAD(inair),RAD(0),RAD(0))
  587. coroutine.resume(coroutine.create(function(PART)
  588. for i = 1, waitt do
  589. Swait()
  590. mesh.Scale = mesh.Scale + VT(size/5,0,size/5)
  591. mesh.Offset = VT(0,0,-(mesh.Scale.X/8))
  592. if doesrotate == true then
  593. wave.CFrame = wave.CFrame * CFrame.fromEulerAnglesXYZ(0, rotatedirection, 0)
  594. end
  595. wave.Transparency = wave.Transparency + (0.5/waitt)
  596. if wave.Transparency > 0.99 then
  597. wave:remove()
  598. end
  599. end
  600. end))
  601. end
  602.  
  603. function CreateSwirl(inair,size,doesrotate,rotatedirection,waitt,part,offset,color)
  604. local wave = CreatePart(3, Effects, "Neon", 0, 0.5, BRICKC(color), "Effect", VT(0,0,0))
  605. local mesh = IT("SpecialMesh",wave)
  606. mesh.MeshType = "FileMesh"
  607. wave.Anchored = true
  608. mesh.MeshId = "http://www.roblox.com/asset/?id=1051557"
  609. mesh.Scale = VT(size,size,size)
  610. wave.CFrame = CF(part.Position) * CF(0,offset,0) * ANGLES(RAD(inair),RAD(0),RAD(0))
  611. coroutine.resume(coroutine.create(function(PART)
  612. for i = 1, waitt do
  613. Swait()
  614. mesh.Scale = mesh.Scale + VT(size/5,size/5,size/5)
  615. if doesrotate == true then
  616. wave.CFrame = wave.CFrame * CFrame.fromEulerAnglesXYZ(0, rotatedirection, 0)
  617. end
  618. wave.Transparency = wave.Transparency + (0.5/waitt)
  619. if wave.Transparency > 0.99 then
  620. wave:remove()
  621. end
  622. end
  623. end))
  624. end
  625.  
  626. function CreateTornado(inair,size,doesrotate,rotatedirection,waitt,part,offset,color)
  627. local wave = CreatePart(3, Effects, "Neon", 0, 0.5, BRICKC(color), "Effect", VT(0,0,0))
  628. local mesh = IT("SpecialMesh",wave)
  629. mesh.MeshType = "FileMesh"
  630. wave.Anchored = true
  631. mesh.MeshId = "http://www.roblox.com/asset/?id=102638417"
  632. mesh.Scale = VT(size,size,size)
  633. wave.CFrame = CF(part.Position) * CF(0,offset,0) * ANGLES(RAD(inair),RAD(0),RAD(0))
  634. coroutine.resume(coroutine.create(function(PART)
  635. for i = 1, waitt do
  636. Swait()
  637. mesh.Scale = mesh.Scale + VT(size/5,0,size/5)
  638. if doesrotate == true then
  639. wave.CFrame = wave.CFrame * CFrame.fromEulerAnglesXYZ(0, rotatedirection, 0)
  640. end
  641. wave.Transparency = wave.Transparency + (0.5/waitt)
  642. if wave.Transparency > 0.99 then
  643. wave:remove()
  644. end
  645. end
  646. end))
  647. end
  648.  
  649. function CreateRing(inair,size,doesrotate,rotatedirection,waitt,part,offset,spin1,spin2,color)
  650. local wave = CreatePart(3, Effects, "Neon", 0, 0.5, BRICKC(color), "Effect", VT(0,0,0))
  651. local mesh = IT("SpecialMesh",wave)
  652. mesh.MeshType = "FileMesh"
  653. mesh.MeshId = "http://www.roblox.com/asset/?id=3270017"
  654. mesh.Scale = VT(size,size,size)
  655. wave.Anchored = true
  656. mesh.Offset = VT(0,0,0)
  657. wave.CFrame = CF(part.Position) * CF(0,offset,0) * ANGLES(RAD(inair),RAD(0),RAD(0))
  658. coroutine.resume(coroutine.create(function(PART)
  659. for i = 1, waitt do
  660. Swait()
  661. mesh.Scale = mesh.Scale + VT(size/5,size/5,size/5)
  662. if doesrotate == true then
  663. wave.CFrame = wave.CFrame * CFrame.fromEulerAnglesXYZ(spin2, rotatedirection, spin1)
  664. end
  665. wave.Transparency = wave.Transparency + (0.5/waitt)
  666. if wave.Transparency > 0.99 then
  667. wave:remove()
  668. end
  669. end
  670. end))
  671. end
  672.  
  673. function MagicSphere(size,waitt,part,color)
  674. local wave = CreatePart(3, Effects, "Neon", 0, 0, BRICKC(color), "Effect", VT(0,0,0))
  675. local mesh = IT("SpecialMesh",wave)
  676. mesh.MeshType = "Sphere"
  677. wave.Anchored = true
  678. mesh.Scale = VT(size,size,size)
  679. mesh.Offset = VT(0,0,0)
  680. wave.CFrame = part * ANGLES(RAD(0),RAD(0),RAD(0))
  681. coroutine.resume(coroutine.create(function(PART)
  682. for i = 1, waitt do
  683. Swait()
  684. mesh.Scale = mesh.Scale + VT(size/5,size/5,size/5)
  685. wave.Transparency = wave.Transparency + (1/waitt)
  686. if wave.Transparency > 0.99 then
  687. wave:remove()
  688. end
  689. end
  690. end))
  691. end
  692.  
  693. function MagicBlock(size,waitt,part,offset,color)
  694. local wave = CreatePart(3, Effects, "Neon", 0, 0, BRICKC(color), "Effect", VT(size,size,size))
  695. local mesh = IT("BlockMesh",wave)
  696. wave.Anchored = true
  697. wave.CFrame = CF(part.Position) * CF(0,offset,0) * ANGLES(RAD(0),RAD(0),RAD(0))
  698. coroutine.resume(coroutine.create(function(PART)
  699. for i = 1, waitt do
  700. Swait()
  701. mesh.Scale = mesh.Scale + VT(size/5,size/5,size/5)
  702. wave.CFrame = CF(wave.Position) * ANGLES(RAD(math(-360,360)),RAD(math(-360,360)),RAD(math(-360,360)))
  703. wave.Transparency = wave.Transparency + (1/waitt)
  704. if wave.Transparency > 0.99 then
  705. wave:remove()
  706. end
  707. end
  708. end))
  709. end
  710.  
  711. local EyeSizes={
  712. NumberSequenceKeypoint.new(0,0.5,0),
  713. NumberSequenceKeypoint.new(1,0.2,0)
  714. }
  715. local EyeTrans={
  716. NumberSequenceKeypoint.new(0,0,0),
  717. NumberSequenceKeypoint.new(1,1,0)
  718. }
  719. local PE=Instance.new("ParticleEmitter")
  720. PE.LightEmission=0.3
  721. PE.Size=NumberSequence.new(EyeSizes)
  722. PE.Transparency=NumberSequence.new(EyeTrans)
  723. PE.Rotation=NumberRange.new(0,360)
  724. PE.LockedToPart = false
  725. PE.Speed = NumberRange.new(0,0,0)
  726. PE.ZOffset = 0.3
  727. PE.Rate = 999
  728. PE.Name = "Particles"
  729.  
  730. function CreateParticles(art,text,accel,drag,lifetime,type,isenabledbydefault,locked)
  731. local particle = nil
  732. coroutine.resume(coroutine.create(function(PART)
  733. particle = PE:Clone()
  734. Swait()
  735. particle.Rate = 999
  736. particle.Parent = art
  737. particle.Acceleration = accel
  738. if type == "Fire" then
  739. local EyeSizes={
  740. NumberSequenceKeypoint.new(0,0.5,0.3),
  741. NumberSequenceKeypoint.new(1,0.2,0.2)
  742. }
  743. particle.Size = NumberSequence.new(EyeSizes)
  744. elseif type == "Smoke" then
  745. local EyeSizes={
  746. NumberSequenceKeypoint.new(0,0.5,0),
  747. NumberSequenceKeypoint.new(1,5,0.5)
  748. }
  749. particle.Size = NumberSequence.new(EyeSizes)
  750. elseif type == "Solid" then
  751. local EyeSizes={
  752. NumberSequenceKeypoint.new(0,0.5,0),
  753. NumberSequenceKeypoint.new(1,0.5,0)
  754. }
  755. particle.Size = NumberSequence.new(EyeSizes)
  756. end
  757. particle.Lifetime=NumberRange.new(lifetime)
  758. particle.Drag = drag
  759. if locked == true then
  760. particle.LockedToPart = true
  761. end
  762. particle.Texture = "http://www.roblox.com/asset/?id="..text
  763. particle.Enabled = isenabledbydefault
  764. end))
  765. return particle
  766. end
  767.  
  768. local EyeSizes={
  769. NumberSequenceKeypoint.new(0,0.5,0),
  770. NumberSequenceKeypoint.new(1,0.2,0)
  771. }
  772. local EyeTrans={
  773. NumberSequenceKeypoint.new(0,0,0),
  774. NumberSequenceKeypoint.new(1,1,0)
  775. }
  776. local PE2=Instance.new("ParticleEmitter")
  777. PE2.LightEmission=0.8
  778. PE2.Size=NumberSequence.new(EyeSizes)
  779. PE2.Transparency=NumberSequence.new(EyeTrans)
  780. PE2.Rotation=NumberRange.new(0,360)
  781. PE2.LockedToPart = false
  782. PE2.Speed = NumberRange.new(0,0,0)
  783. PE2.ZOffset = 0.3
  784. PE2.Rate = 999
  785. PE2.VelocitySpread = 90000
  786. PE2.Name = "Particles"
  787.  
  788. function CreateParticles2(art,accel,drag,lifetime,type,isenabledbydefault,locked,size,speed)
  789. local particle = nil
  790. coroutine.resume(coroutine.create(function(PART)
  791. particle = PE2:Clone()
  792. Swait()
  793. particle.Rate = 999
  794. particle.Parent = art
  795. particle.Acceleration = accel
  796. if type == "Fire" then
  797. local EyeSizes={
  798. NumberSequenceKeypoint.new(0,size,size/2),
  799. NumberSequenceKeypoint.new(1,size/4,size/8)
  800. }
  801. particle.Size = NumberSequence.new(EyeSizes)
  802. elseif type == "Smoke" then
  803. local EyeSizes={
  804. NumberSequenceKeypoint.new(0,0.5,0),
  805. NumberSequenceKeypoint.new(1,5,0.5)
  806. }
  807. particle.Size = NumberSequence.new(EyeSizes)
  808. elseif type == "Solid" then
  809. local EyeSizes={
  810. NumberSequenceKeypoint.new(0,0.5,0),
  811. NumberSequenceKeypoint.new(1,0.5,0)
  812. }
  813. particle.Size = NumberSequence.new(EyeSizes)
  814. end
  815. particle.Lifetime=NumberRange.new(lifetime)
  816. particle.Drag = drag
  817. if locked == true then
  818. particle.LockedToPart = true
  819. end
  820. particle.Speed = NumberRange.new(speed,speed,speed)
  821. particle.Texture = "http://www.roblox.com/asset/?id="..MAGICPARTICLE
  822. particle.Enabled = isenabledbydefault
  823. --particle.Color = ColorSequence.new(Color3.new(255, 255, 255))
  824. end))
  825. return particle
  826. end
  827. local Decal = IT("Decal")
  828.  
  829. function CreateMagicCircle(size,doesrotate,rotatedirection,waitt,cframe,alwaysfade)
  830. local sinkhole = IT("Part")
  831. sinkhole.Size = VT(size,0,size)
  832. sinkhole.CFrame = cframe
  833. --sinkhole.Orientation = VT(0,0,0)
  834. sinkhole.Parent = Effects
  835. sinkhole.Material = "Neon"
  836. sinkhole.Color = C3(255, 255, 255)
  837. sinkhole.Anchored = true
  838. sinkhole.CanCollide = false
  839. sinkhole.Transparency = 1
  840. local decal = Decal:Clone()
  841. decal.Parent = sinkhole
  842. decal.Face = "Top"
  843. decal.Texture = "http://www.roblox.com/asset/?id=1531669882"
  844. local decal2 = Decal:Clone()
  845. decal2.Parent = sinkhole
  846. decal2.Face = "Bottom"
  847. decal2.Texture = "http://www.roblox.com/asset/?id=1531669882"
  848. coroutine.resume(coroutine.create(function(PART)
  849. for i = 1, waitt do
  850. Swait()
  851. if doesrotate == true then
  852. sinkhole.CFrame = sinkhole.CFrame * CFrame.fromEulerAnglesXYZ(0, rotatedirection, 0)
  853. end
  854. if alwaysfade == true then
  855. decal.Transparency = decal.Transparency + (1/waitt)
  856. decal2.Transparency = decal.Transparency + (1/waitt)
  857. end
  858. if i > waitt-11 and (alwaysfade ~= true) then
  859. decal.Transparency = decal.Transparency + 0.1
  860. decal2.Transparency = decal.Transparency + 0.1
  861. end
  862. end
  863. sinkhole.Parent = nil
  864. end))
  865. return sinkhole
  866. end
  867.  
  868. --//=================================\\
  869. --\\=================================//
  870.  
  871.  
  872. --//=================================\\
  873. --|| WEAPON CREATION
  874. --\\=================================//
  875.  
  876. if Player_Size ~= 1 then
  877. for _, v in pairs (Weapon:GetChildren()) do
  878. if v.ClassName == "Motor" or v.ClassName == "Weld" or v.ClassName == "Snap" then
  879. local p1 = v.Part1
  880. v.Part1 = nil
  881. local cf1, cf2, cf3, cf4, cf5, cf6, cf7, cf8, cf9, cf10, cf11, cf12 = v.C1:components()
  882. v.C1 = CF(cf1 * Player_Size, cf2 * Player_Size, cf3 * Player_Size, cf4, cf5, cf6, cf7, cf8, cf9, cf10, cf11, cf12)
  883. v.Part1 = p1
  884. elseif v.ClassName == "Part" then
  885. for _, b in pairs (v:GetChildren()) do
  886. if b.ClassName == "SpecialMesh" or b.ClassName == "BlockMesh" then
  887. b.Scale = VT(b.Scale.x * Player_Size, b.Scale.y * Player_Size, b.Scale.z * Player_Size)
  888. end
  889. end
  890. end
  891. end
  892. end
  893.  
  894. Swait()
  895.  
  896. local Plate = IT("Part",Weapon)
  897. Plate.Size = VT(1,0.1,1)
  898. Plate.Transparency = 1
  899. Plate.CanCollide = false
  900. Plate.CFrame = LeftLeg.CFrame * CF(0,-1.1,0)
  901. CreateParticles(Plate,MAGICPARTICLE,VT(0,2,0),2,2,"Fire",true,true)
  902. weldBetween(LeftLeg,Plate)
  903.  
  904. local Plate = IT("Part",Weapon)
  905. Plate.Size = VT(1,0.1,1)
  906. Plate.Transparency = 1
  907. Plate.CanCollide = false
  908. Plate.CFrame = RightLeg.CFrame * CF(0,-1.1,0)
  909. CreateParticles(Plate,MAGICPARTICLE,VT(0,2,0),2,2,"Fire",true,true)
  910. weldBetween(RightLeg,Plate)
  911.  
  912. local Plate = IT("Part",Weapon)
  913. Plate.Size = VT(1,0.1,1)
  914. Plate.Transparency = 1
  915. Plate.CanCollide = false
  916. Plate.CFrame = RightArm.CFrame * CF(0,-1.1,0)
  917. CreateParticles(Plate,MAGICPARTICLE,VT(0,2,0),2,2,"Fire",true,true)
  918. weldBetween(RightArm,Plate)
  919.  
  920. local Plate = IT("Part",Weapon)
  921. Plate.Size = VT(1,0.1,1)
  922. Plate.Transparency = 1
  923. Plate.CanCollide = false
  924. Plate.CFrame = LeftArm.CFrame * CF(0,-1.1,0)
  925. CreateParticles(Plate,MAGICPARTICLE,VT(0,2,0),2,2,"Fire",true,true)
  926. weldBetween(LeftArm,Plate)
  927.  
  928. local eye = IT("Part",Weapon)
  929. eye.Size = VT(0.2,0.2,0.2)
  930. eye.Shape = "Ball"
  931. eye.CFrame = Head.CFrame * CF(0.125,0.2,-0.55)
  932. eye.Material = "Neon"
  933. eye.BrickColor = BRICKC("Really black")
  934. weldBetween(Head,eye)
  935.  
  936.  
  937.  
  938.  
  939. for _, c in pairs(Weapon:GetChildren()) do
  940. if c.ClassName == "Part" then
  941. c.CustomPhysicalProperties = PhysicalProperties.new(0, 0, 0, 0, 0)
  942. end
  943. end
  944.  
  945. Weapon.Parent = Character
  946.  
  947. Humanoid.Died:connect(function()
  948. ATTACK = true
  949. end)
  950.  
  951. print(Class_Name.." loaded.")
  952.  
  953. --//=================================\\
  954. --\\=================================//
  955.  
  956.  
  957.  
  958.  
  959.  
  960. --//=================================\\
  961. --|| DAMAGE FUNCTIONS
  962. --\\=================================//
  963.  
  964. function StatLabel(LABELTYPE, CFRAME, TEXT, COLOR)
  965. local STATPART = CreatePart(3, Effects, "Neon", 0, 1, "Toothpaste", "Effect", VT())
  966. STATPART.CFrame = CF(CFRAME.p + VT(0, 1.5, 0))
  967. local BODYGYRO = IT("BodyGyro", STATPART)
  968. local BODYPOSITION = IT("BodyPosition", STATPART)
  969. BODYPOSITION.P = 2000
  970. BODYPOSITION.D = 100
  971. BODYPOSITION.maxForce = VT(math.huge, math.huge, math.huge)
  972. if LABELTYPE == "Normal" then
  973. BODYPOSITION.position = STATPART.Position + VT(MRANDOM(-2, 2), 6, MRANDOM(-2, 2))
  974. elseif LABELTYPE == "Debuff" then
  975. BODYPOSITION.position = STATPART.Position + VT(MRANDOM(-2, 2), 8, MRANDOM(-2, 2))
  976. elseif LABELTYPE == "Interruption" then
  977. BODYPOSITION.position = STATPART.Position + VT(MRANDOM(-2,2), 8, MRANDOM(-2, 2))
  978. end
  979. game:GetService("Debris"):AddItem(STATPART ,5)
  980. local BILLBOARDGUI = Instance.new("BillboardGui", STATPART)
  981. BILLBOARDGUI.Adornee = STATPART
  982. BILLBOARDGUI.Size = UD2(2.5, 0, 2.5 ,0)
  983. BILLBOARDGUI.StudsOffset = VT(-2, 2, 0)
  984. BILLBOARDGUI.AlwaysOnTop = false
  985. local TEXTLABEL = Instance.new("TextLabel", BILLBOARDGUI)
  986. TEXTLABEL.BackgroundTransparency = 1
  987. TEXTLABEL.Size = UD2(2.5, 0, 2.5, 0)
  988. TEXTLABEL.Text = TEXT
  989. TEXTLABEL.Font = "SciFi"
  990. TEXTLABEL.FontSize="Size42"
  991. TEXTLABEL.TextColor3 = COLOR
  992. TEXTLABEL.TextStrokeTransparency = 1
  993. TEXTLABEL.TextScaled = true
  994. TEXTLABEL.TextWrapped = true
  995. coroutine.resume(coroutine.create(function(THEPART, THEBODYPOSITION, THETEXTLABEL)
  996. wait(0.2)
  997. for i=1, 5 do
  998. wait()
  999. THEBODYPOSITION.Position = THEPART.Position - VT(0, 0.5 ,0)
  1000. end
  1001. wait(1.2)
  1002. for i=1, 5 do
  1003. wait()
  1004. THETEXTLABEL.TextTransparency = THETEXTLABEL.TextTransparency + 0.2
  1005. THETEXTLABEL.TextStrokeTransparency = THETEXTLABEL.TextStrokeTransparency + 0.2
  1006. THEBODYPOSITION.position = THEPART.Position + VT(0, 0.5, 0)
  1007. end
  1008. THEPART.Parent = nil
  1009. end),STATPART, BODYPOSITION, TEXTLABEL)
  1010. end
  1011.  
  1012.  
  1013. --//=================================\\
  1014. --|| DAMAGING
  1015. --\\=================================//
  1016.  
  1017. function dealdamage(hit,min,max,maxstrength,beserk,critrate,critmultiplier)
  1018. if hit.Parent:FindFirstChildOfClass("Humanoid") and hit.Parent:FindFirstChild("HitBy"..Player.Name) == nil then
  1019. local humanoid = hit.Parent:FindFirstChildOfClass("Humanoid")
  1020. local dmg = math.random(min,max)
  1021. if humanoid.Health > 0 then
  1022. if beserk == true then
  1023. humanoid.Health = 0
  1024. else
  1025. CreateSound("260430060", hit, 1.2, MRANDOM(7, 12) / 10)
  1026. hit.Velocity = CFrame.new(Torso.Position,hit.Position).lookVector*5*maxstrength
  1027. if math.random(1,100) < critrate+1 then
  1028. humanoid.Health = humanoid.Health - dmg*critmultiplier
  1029. StatLabel("Normal", hit.CFrame * CF(0, 0 + (hit.Size.z - 1), 0), "CRIT/"..dmg*critmultiplier, C3(255/255, 0, 0))
  1030. else
  1031. humanoid.Health = humanoid.Health - dmg
  1032. StatLabel("Normal", hit.CFrame * CF(0, 0 + (hit.Size.z - 1), 0), dmg, C3(0, 0, 0))
  1033. end
  1034. local defence = Instance.new("BoolValue",hit.Parent)
  1035. defence.Name = ("HitBy"..Player.Name)
  1036. game:GetService("Debris"):AddItem(defence, 0.5)
  1037. end
  1038. end
  1039. end
  1040. end
  1041.  
  1042. function AoEDamage(position,radius,min,max,maxstrength,beserk,critrate,critmultiplier,CanBeDodgedByJumping)
  1043. local dmg = math.random(min,max)
  1044. for i,v in ipairs(workspace:GetChildren()) do
  1045. if v:FindFirstChild("HitBy"..Player.Name) == nil then
  1046. local body = v:GetChildren()
  1047. for part = 1, #body do
  1048. if(v:FindFirstChild("HitBy"..Player.Name) == nil and (body[part].ClassName == "Part" or body[part].ClassName == "MeshPart") and v ~= Character) then
  1049. if(body[part].Position - position).Magnitude < radius then
  1050. if v.ClassName == "Model" then
  1051. if v:FindFirstChild("Humanoid") then
  1052. if v.Humanoid.Health ~= 0 then
  1053. if CanBeDodgedByJumping == true then
  1054. if body[part].Position.Y < position.Y+5 then
  1055. if math.random(1,100) < critrate+1 then
  1056. v.Humanoid.Health = v.Humanoid.Health - dmg*critmultiplier
  1057. StatLabel("Normal", body[part].CFrame * CF(0, 0 + (body[part].Size.z - 1), 0), "CRIT/"..dmg*critmultiplier, C3(255/255, 0, 0))
  1058. else
  1059. v.Humanoid.Health = v.Humanoid.Health - dmg
  1060. StatLabel("Normal", body[part].CFrame * CF(0, 0 + (body[part].Size.z - 1), 0), dmg, C3(0, 0, 0))
  1061. end
  1062. local defence = Instance.new("BoolValue",v)
  1063. defence.Name = ("HitBy"..Player.Name)
  1064. game:GetService("Debris"):AddItem(defence, 0.5)
  1065. end
  1066. else
  1067. if beserk == true then
  1068. v.Humanoid.Health = 0
  1069. end
  1070. if math.random(1,100) < critrate+1 then
  1071. v.Humanoid.Health = v.Humanoid.Health - dmg*critmultiplier
  1072. StatLabel("Normal", body[part].CFrame * CF(0, 0 + (body[part].Size.z - 1), 0), "CRIT/"..dmg*critmultiplier, C3(255/255, 0, 0))
  1073. else
  1074. v.Humanoid.Health = v.Humanoid.Health - dmg
  1075. StatLabel("Normal", body[part].CFrame * CF(0, 0 + (body[part].Size.z - 1), 0), dmg, C3(0, 0, 0))
  1076. end
  1077. local defence = Instance.new("BoolValue",v)
  1078. defence.Name = ("HitBy"..Player.Name)
  1079. game:GetService("Debris"):AddItem(defence, 0.5)
  1080. end
  1081. end
  1082. end
  1083. end
  1084. body[part].Velocity = CFrame.new(position,body[part].Position).lookVector*5*maxstrength
  1085. end
  1086. end
  1087. end
  1088. if v.ClassName == "Part" then
  1089. if v.Anchored == false and (v.Position - position).Magnitude < radius then
  1090. v.Velocity = CFrame.new(position,v.Position).lookVector*5*maxstrength
  1091. end
  1092. end
  1093. end
  1094. end
  1095. end
  1096.  
  1097. function attractnearest(postype,position,range,maxstrength,last)
  1098. if postype == "Vector" then
  1099. for i,v in ipairs(workspace:GetChildren()) do
  1100. local body = v:GetChildren()
  1101. for part = 1, #body do
  1102. if((body[part].ClassName == "Part" or body[part].ClassName == "MeshPart") and v ~= Character) then
  1103. if(body[part].Position - position).Magnitude < range then
  1104. if body[part]:FindFirstChild("ATTRACT") == nil then
  1105. local bv = Instance.new("BodyVelocity")
  1106. bv.maxForce = Vector3.new(1e9, 1e9, 1e9)
  1107. bv.velocity = CF(body[part].Position,position).lookVector*maxstrength
  1108. bv.Parent = body[part]
  1109. bv.Name = "ATTRACT"
  1110. else
  1111. coroutine.resume(coroutine.create(function()
  1112. for i = 1, last/5 do
  1113. Swait(5)
  1114. body[part].ATTRACT.velocity = CF(body[part].Position,position).lookVector*maxstrength
  1115. end
  1116. body[part].ATTRACT:remove()
  1117. end))
  1118. end
  1119. end
  1120. end
  1121. end
  1122. if v.ClassName == "Part" then
  1123. if v.Anchored == false and (v.Position - position).Magnitude < range then
  1124. if v:FindFirstChild("ATTRACT") == nil then
  1125. local bv = Instance.new("BodyVelocity")
  1126. bv.maxForce = Vector3.new(1e9, 1e9, 1e9)
  1127. bv.velocity = CF(v.Position,position).lookVector*maxstrength
  1128. bv.Parent = v
  1129. bv.Name = "ATTRACT"
  1130. else
  1131. coroutine.resume(coroutine.create(function()
  1132. for i = 1, last/5 do
  1133. Swait(5)
  1134. v.ATTRACT.velocity = CF(v.Position,position).lookVector*maxstrength
  1135. end
  1136. v.ATTRACT:remove()
  1137. end))
  1138. end
  1139. end
  1140. end
  1141. end
  1142. elseif postype == "Part" then
  1143. for i,v in ipairs(workspace:GetChildren()) do
  1144. local body = v:GetChildren()
  1145. for part = 1, #body do
  1146. if((body[part].ClassName == "Part" or body[part].ClassName == "MeshPart") and v ~= Character) then
  1147. if(body[part].Position - position.Position).Magnitude < range then
  1148. if body[part]:FindFirstChild("ATTRACT") == nil then
  1149. local bv = Instance.new("BodyVelocity")
  1150. bv.maxForce = Vector3.new(1e9, 1e9, 1e9)
  1151. bv.velocity = CF(body[part].Position,position.Position).lookVector*maxstrength
  1152. bv.Parent = body[part]
  1153. bv.Name = "ATTRACT"
  1154. else
  1155. coroutine.resume(coroutine.create(function()
  1156. for i = 1, last/5 do
  1157. Swait(5)
  1158. body[part].ATTRACT.velocity = CF(body[part].Position,position.Position).lookVector*maxstrength
  1159. end
  1160. body[part].ATTRACT:remove()
  1161. end))
  1162. end
  1163. end
  1164. end
  1165. end
  1166. if v.ClassName == "Part" then
  1167. if v.Anchored == false and (v.Position - position.Position).Magnitude < range then
  1168. if v:FindFirstChild("ATTRACT") == nil then
  1169. local bv = Instance.new("BodyVelocity")
  1170. bv.maxForce = Vector3.new(1e9, 1e9, 1e9)
  1171. bv.velocity = CF(v.Position,position.Position).lookVector*maxstrength
  1172. bv.Parent = v
  1173. bv.Name = "ATTRACT"
  1174. else
  1175. coroutine.resume(coroutine.create(function()
  1176. for i = 1, last/5 do
  1177. Swait(5)
  1178. v.ATTRACT.velocity = CF(v.Position,position.Position).lookVector*maxstrength
  1179. end
  1180. v.ATTRACT:remove()
  1181. end))
  1182. end
  1183. end
  1184. end
  1185. end
  1186. end
  1187. end
  1188.  
  1189. function killnearest(position,range,maxstrength,candestroy)
  1190. for i,v in ipairs(workspace:GetChildren()) do
  1191. local body = v:GetChildren()
  1192. for part = 1, #body do
  1193. if((body[part].ClassName == "Part" or body[part].ClassName == "MeshPart") and v ~= Character) then
  1194. if(body[part].Position - position).Magnitude < range then
  1195. if v.ClassName == "Model" then
  1196. v:BreakJoints()
  1197. end
  1198. if candestroy == true then
  1199. table.insert(Effects2,{body[part],"Disappear",0.02,2,2,2,2})
  1200. end
  1201. body[part].Velocity = CFrame.new(position,body[part].Position).lookVector*5*maxstrength
  1202. end
  1203. end
  1204. end
  1205. if v.ClassName == "Part" then
  1206. if v.Anchored == false and (v.Position - position).Magnitude < range then
  1207. if candestroy == true then
  1208. table.insert(Effects2,{v,"Disappear",0.02,2,2,2,2})
  1209. end
  1210. v.Velocity = CFrame.new(position,v.Position).lookVector*5*maxstrength
  1211. end
  1212. end
  1213. end
  1214. end
  1215.  
  1216. --//=================================\\
  1217. --|| ATTACK FUNCTIONS AND STUFF
  1218. --\\=================================//
  1219.  
  1220. function CheckTableForString(Table, String)
  1221. for i, v in pairs(Table) do
  1222. if string.find(string.lower(String), string.lower(v)) then
  1223. return true
  1224. end
  1225. end
  1226. return false
  1227. end
  1228.  
  1229. function CheckIntangible(Hit)
  1230. local ProjectileNames = {"Water", "Arrow", "Projectile", "Effect", "Rail", "Lightning", "Bullet"}
  1231. if Hit and Hit.Parent then
  1232. if ((not Hit.CanCollide or CheckTableForString(ProjectileNames, Hit.Name)) and not Hit.Parent:FindFirstChild("Humanoid")) then
  1233. return true
  1234. end
  1235. end
  1236. return false
  1237. end
  1238.  
  1239. Debris = game:GetService("Debris")
  1240.  
  1241. function CastZapRay(StartPos, Vec, Length, Ignore, DelayIfHit)
  1242. local Direction = CFrame.new(StartPos, Vec).lookVector
  1243. local Ignore = ((type(Ignore) == "table" and Ignore) or {Ignore})
  1244. local RayHit, RayPos, RayNormal = game:GetService("Workspace"):FindPartOnRayWithIgnoreList(Ray.new(StartPos, Direction * Length), Ignore)
  1245. if RayHit and CheckIntangible(RayHit) then
  1246. if DelayIfHit then
  1247. wait()
  1248. end
  1249. RayHit, RayPos, RayNormal = CastZapRay((RayPos + (Vec * 0.01)), Vec, (Length - ((StartPos - RayPos).magnitude)), Ignore, DelayIfHit)
  1250. end
  1251. return RayHit, RayPos, RayNormal
  1252. end
  1253.  
  1254. function turnto(pos)
  1255. RootPart.CFrame = CF(RootPart.Position,VT(pos.X,RootPart.Position.Y,pos.Z))
  1256. end
  1257.  
  1258. function GraviBomb()
  1259. ATTACK = true
  1260. for i=0, 1, 0.1 / Animation_Speed do
  1261. Swait()
  1262. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(5), RAD(0), RAD(-40)), 0.4 / Animation_Speed)
  1263. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(0), RAD(0), RAD(35)) * ANGLES(RAD(2.5), RAD(0), RAD(0)), 0.4 / Animation_Speed)
  1264. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(70), RAD(0), RAD(45)) * RIGHTSHOULDERC0, 0.4 / Animation_Speed)
  1265. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.75 * Player_Size, -0.5 * Player_Size) * ANGLES(RAD(90), RAD(0), RAD(50)) * ANGLES(RAD(80), RAD(-20), RAD(-30)) * LEFTSHOULDERC0, 0.4 / Animation_Speed)
  1266. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size, -1 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(-20)), 0.2 / Animation_Speed)
  1267. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 0.2 / Animation_Speed)
  1268. end
  1269. MagicSphere(25,25,LeftArm.CFrame*CF(0,-1,0),"Toothpaste")
  1270. MagicSphere(20,25,LeftArm.CFrame*CF(0,-1,0),"Toothpaste")
  1271. coroutine.resume(coroutine.create(function()
  1272. local cframe = CF(Mouse.Hit.p)
  1273. local circle = CreateMagicCircle(75,true,0.05,120,cframe,false)
  1274. for i = 1, 5 do
  1275. CreateSound(CUTSOUNDS[MRANDOM(1, #CUTSOUNDS)], Effects, 2, 1)
  1276. local sphere = IT("Part",Effects)
  1277. sphere.Shape = "Ball"
  1278. sphere.Size = VT(50,50,50)
  1279. sphere.Anchored = true
  1280. sphere.CanCollide = false
  1281. sphere.Material = "Neon"
  1282. sphere.BrickColor = BRICKC("Toothpaste")
  1283. sphere.Transparency = 0
  1284. sphere.CFrame = cframe
  1285. for i = 1, 10 do
  1286. Swait(2)
  1287. attractnearest("Vector",cframe.p,75,50,10)
  1288. sphere.CFrame = cframe
  1289. sphere.Size = sphere.Size - VT(5,5,5)
  1290. sphere.CFrame = cframe
  1291. end
  1292. sphere:remove()
  1293. end
  1294. local scale = 5
  1295. coroutine.resume(coroutine.create(function()
  1296. CreateSound(RELEASESOUND, Effects, 2, 1)
  1297. MagicSphere(100,125,cframe,"Toothpaste")
  1298. MagicSphere(75,125,cframe,"Toothpaste")
  1299. CreateSwirl(180,6,true,0.3,225,circle,0,"Toothpaste")
  1300. CreateSwirl(180,4,true,0.3,225,circle,0,"Toothpaste")
  1301. CreateSwirl(180,2,true,0.3,225,circle,0,"Toothpaste")
  1302. for i = 1, 15 do
  1303. Swait()
  1304. killnearest(cframe.p,25,150)
  1305. end
  1306. end))
  1307. end))
  1308. for i=0, 1, 0.1 / Animation_Speed do
  1309. Swait()
  1310. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(5), RAD(0), RAD(-30)), 0.4 / Animation_Speed)
  1311. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(0), RAD(0), RAD(25)) * ANGLES(RAD(5), RAD(0), RAD(0)), 0.4 / Animation_Speed)
  1312. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(70), RAD(0), RAD(45)) * RIGHTSHOULDERC0, 0.4 / Animation_Speed)
  1313. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.25 * Player_Size, -0.25 * Player_Size) * ANGLES(RAD(90), RAD(0), RAD(-20 + MRANDOM(-2.5, 2.5))) * ANGLES(RAD(70 + MRANDOM(-2.5, 2.5)), RAD(40), RAD(0)) * LEFTSHOULDERC0, 0.4 / Animation_Speed)
  1314. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size, -1 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(-20)), 0.2 / Animation_Speed)
  1315. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 0.2 / Animation_Speed)
  1316. end
  1317. ATTACK = false
  1318. end
  1319.  
  1320. function GraviSpear()
  1321. ATTACK = true
  1322. for i=0, 1.5, 0.1 / Animation_Speed do
  1323. Swait()
  1324. turnto(Mouse.Hit.p)
  1325. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(75)), 0.4 / Animation_Speed)
  1326. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(0), RAD(0), RAD(-75)), 0.2 / Animation_Speed)
  1327. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(90)) * RIGHTSHOULDERC0, 0.15 / Animation_Speed)
  1328. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(25), RAD(-25)) * LEFTSHOULDERC0, 0.15 / Animation_Speed)
  1329. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size, -1 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(-20)), 0.2 / Animation_Speed)
  1330. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 0.2 / Animation_Speed)
  1331. end
  1332. local spear = IT("Part",Effects)
  1333. spear.Anchored = true
  1334. spear.CanCollide = false
  1335. spear.Shape = "Ball"
  1336. spear.Size = VT(0,0,0)
  1337. spear.Material = "Neon"
  1338. spear.Transparency = 0.2
  1339. spear.BrickColor = BRICKC("Toothpaste")
  1340. spear.CFrame = RightArm.CFrame * CF(0,-4,0)
  1341. local inner = spear:Clone()
  1342. inner.Parent = spear
  1343. inner.Size = VT(0,0,0)
  1344. inner.BrickColor = BRICKC("Toothpaste")
  1345. inner.CFrame = spear.CFrame
  1346. for i = 1, 10 do
  1347. Swait()
  1348. turnto(Mouse.Hit.p)
  1349. spear.CFrame = RightArm.CFrame * CF(0,-4,0)
  1350. inner.CFrame = spear.CFrame
  1351. spear.Size = spear.Size + VT(0.4,0.4,0.4)
  1352. inner.Size = inner.Size + VT(0.35,0.35,0.35)
  1353. end
  1354. CreateParticles2(inner,VT(0,255,255),5,1,"Fire",true,true,1,8)
  1355. MagicSphere(25,25,RightArm.CFrame*CF(0,-1,0),"Toothpaste")
  1356. MagicSphere(20,25,RightArm.CFrame*CF(0,-1,0),"Toothpaste")
  1357. CreateSound(CUTSOUNDS[MRANDOM(1, #CUTSOUNDS)], RightArm, 6, 1)
  1358. local bv = Instance.new("BodyVelocity")
  1359. bv.maxForce = Vector3.new(1e9, 1e9, 1e9)
  1360. bv.velocity = CF(spear.Position,Mouse.Hit.p).lookVector*65
  1361. bv.Parent = spear
  1362. bv.Name = "MOVE"
  1363. weldBetween(spear,inner)
  1364. spear.Anchored = false
  1365. inner.Anchored = false
  1366. local harm = spear.Touched:Connect(function(hit)
  1367. if hit.Parent ~= Character and hit.Parent ~= Weapon and hit.Parent ~= Effects then
  1368. local cframe = spear.CFrame
  1369. coroutine.resume(coroutine.create(function()
  1370. spear.Parent = nil
  1371. coroutine.resume(coroutine.create(function()
  1372. CreateSound(RELEASESOUND, Effects, 2, 1)
  1373. MagicSphere(60,125,cframe,"Toothpaste")
  1374. MagicSphere(50,125,cframe,"Toothpaste")
  1375. CreateSwirl(0,6,true,0.3,125,spear,0,"Toothpaste")
  1376. CreateSwirl(0,4,true,0.3,125,spear,0,"Toothpaste")
  1377. CreateSwirl(0,2,true,0.3,125,spear,0,"Toothpaste")
  1378. for i = 1, 15 do
  1379. Swait()
  1380. killnearest(cframe.p,15,150)
  1381. end
  1382. end))
  1383. end))
  1384. end
  1385. end)
  1386. coroutine.resume(coroutine.create(function()
  1387. repeat
  1388. Swait()
  1389. CreateSwirl(0,2,true,0.3,25,spear,0,"Toothpaste")
  1390. attractnearest("Part",spear,65,70,5)
  1391. until spear.Parent == nil
  1392. end))
  1393. ATTACK = false
  1394. end
  1395.  
  1396. function WarpSpear()
  1397. ATTACK = true
  1398. for i=0, 1.5, 0.1 / Animation_Speed do
  1399. Swait()
  1400. turnto(Mouse.Hit.p)
  1401. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(75)), 0.4 / Animation_Speed)
  1402. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(0), RAD(0), RAD(-75)), 0.2 / Animation_Speed)
  1403. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(90)) * RIGHTSHOULDERC0, 0.15 / Animation_Speed)
  1404. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(25), RAD(-25)) * LEFTSHOULDERC0, 0.15 / Animation_Speed)
  1405. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size, -1 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(-20)), 0.2 / Animation_Speed)
  1406. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 0.2 / Animation_Speed)
  1407. end
  1408. local spear = IT("Part",Effects)
  1409. spear.Anchored = true
  1410. spear.CanCollide = false
  1411. spear.Shape = "Ball"
  1412. spear.Size = VT(0,0,0)
  1413. spear.Material = "Neon"
  1414. spear.Transparency = 0.2
  1415. spear.BrickColor = BRICKC("Toothpaste")
  1416. spear.CFrame = RightArm.CFrame * CF(0,-4,0)
  1417. local inner = spear:Clone()
  1418. inner.Parent = spear
  1419. inner.Size = VT(0,0,0)
  1420. inner.BrickColor = BRICKC("Toothpaste")
  1421. inner.CFrame = spear.CFrame
  1422. for i = 1, 5 do
  1423. Swait()
  1424. turnto(Mouse.Hit.p)
  1425. spear.CFrame = RightArm.CFrame * CF(0,-4,0)
  1426. inner.CFrame = spear.CFrame
  1427. spear.Size = spear.Size + VT(0.4,0.4,0.4)
  1428. inner.Size = inner.Size + VT(0.35,0.35,0.35)
  1429. end
  1430. MagicSphere(25,25,RightArm.CFrame*CF(0,-1,0),"Toothpaste")
  1431. MagicSphere(20,25,RightArm.CFrame*CF(0,-1,0),"Toothpaste")
  1432. CreateSound(CUTSOUNDS[MRANDOM(1, #CUTSOUNDS)], RightArm, 6, 1)
  1433. local bv = Instance.new("BodyVelocity")
  1434. bv.maxForce = Vector3.new(1e9, 1e9, 1e9)
  1435. bv.velocity = CF(spear.Position,Mouse.Hit.p).lookVector*100
  1436. bv.Parent = spear
  1437. bv.Name = "MOVE"
  1438. weldBetween(spear,inner)
  1439. spear.Anchored = false
  1440. inner.Anchored = false
  1441. local HIT = false
  1442. local harm = spear.Touched:Connect(function(hit)
  1443. if HIT == false and hit.Parent ~= Character and hit.Parent ~= Weapon and hit.Parent ~= Effects then
  1444. local cframe = spear.CFrame
  1445. HIT = true
  1446. coroutine.resume(coroutine.create(function()
  1447. spear.Parent = nil
  1448. RootPart.CFrame = CF(spear.Position,Mouse.Hit.p)
  1449. coroutine.resume(coroutine.create(function()
  1450. CreateSound(RELEASESOUND, Effects, 2, 1.5)
  1451. MagicSphere(30,105,cframe,"Toothpaste")
  1452. MagicSphere(25,105,cframe,"Toothpaste")
  1453. for i = 1, 15 do
  1454. Swait()
  1455. killnearest(cframe.p,7.5,150)
  1456. end
  1457. end))
  1458. end))
  1459. end
  1460. end)
  1461. coroutine.resume(coroutine.create(function()
  1462. Swait(75)
  1463. if HIT == false then
  1464. local cframe = spear.CFrame
  1465. HIT = true
  1466. coroutine.resume(coroutine.create(function()
  1467. spear.Parent = nil
  1468. RootPart.CFrame = CF(spear.Position,Mouse.Hit.p)
  1469. coroutine.resume(coroutine.create(function()
  1470. CreateSound(RELEASESOUND, Effects, 2, 1.5)
  1471. MagicSphere(30,105,cframe,"Toothpaste")
  1472. MagicSphere(25,105,cframe,"Toothpaste")
  1473. for i = 1, 15 do
  1474. Swait()
  1475. killnearest(cframe.p,7.5,150)
  1476. end
  1477. end))
  1478. end))
  1479. end
  1480. end))
  1481. coroutine.resume(coroutine.create(function()
  1482. local loop = 0
  1483. repeat
  1484. Swait()
  1485. loop = loop + 1
  1486. if loop == 4 then
  1487. MagicSphere(25,15,spear.CFrame,"Toothpaste")
  1488. end
  1489. if loop == 7 then
  1490. loop = 0
  1491. MagicSphere(25,15,spear.CFrame,"Toothpaste")
  1492. end
  1493. attractnearest("Part",spear,12.5,50,5)
  1494. until spear.Parent == nil
  1495. end))
  1496. ATTACK = false
  1497. end
  1498.  
  1499. function GravityGlobe()
  1500. ATTACK = true
  1501. Rooted = true
  1502. for i=0, 1, 0.1 / Animation_Speed do
  1503. Swait()
  1504. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(5), RAD(0), RAD(-40)), 0.4 / Animation_Speed)
  1505. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(0), RAD(0), RAD(35)) * ANGLES(RAD(2.5), RAD(0), RAD(0)), 0.4 / Animation_Speed)
  1506. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(70), RAD(0), RAD(45)) * RIGHTSHOULDERC0, 0.4 / Animation_Speed)
  1507. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.75 * Player_Size, -0.5 * Player_Size) * ANGLES(RAD(90), RAD(0), RAD(50)) * ANGLES(RAD(80), RAD(-20), RAD(-30)) * LEFTSHOULDERC0, 0.4 / Animation_Speed)
  1508. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size, -1 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(-20)), 0.2 / Animation_Speed)
  1509. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 0.2 / Animation_Speed)
  1510. end
  1511. coroutine.resume(coroutine.create(function()
  1512. CreateMagicCircle(100,true,0.02,50,CF(RootPart.Position) * CF(0,-2.8,0),true)
  1513. local cframe = RootPart.CFrame
  1514. CreateSound(RELEASESOUND, Effects, 2, 1)
  1515. local sphere = IT("Part",Effects)
  1516. sphere.Shape = "Ball"
  1517. sphere.Size = VT(0,0,0)
  1518. sphere.Anchored = true
  1519. sphere.CanCollide = false
  1520. sphere.Material = "Neon"
  1521. sphere.Transparency = 0.5
  1522. sphere.BrickColor = BRICKC("Toothpaste")
  1523. sphere.CFrame = cframe
  1524. local sphere2 = IT("Part",Effects)
  1525. sphere2.Shape = "Ball"
  1526. sphere2.Size = VT(0,0,0)
  1527. sphere2.Anchored = true
  1528. sphere2.CanCollide = false
  1529. sphere2.Material = "Neon"
  1530. sphere2.Transparency = 0.3
  1531. sphere2.BrickColor = BRICKC("Toothpaste")
  1532. sphere2.CFrame = cframe
  1533. for i = 1, 10 do
  1534. Swait(2)
  1535. attractnearest("Vector",cframe.p,50,50,10)
  1536. sphere.CFrame = cframe
  1537. sphere.Size = sphere.Size + VT(4,4,4)
  1538. sphere2.CFrame = cframe
  1539. sphere2.Size = sphere2.Size + VT(3.5,3.5,3.5)
  1540. killnearest(cframe.p,15,0)
  1541. end
  1542. local scale = 0.2
  1543. local mode = "shrink"
  1544. for i = 1, 350 do
  1545. Swait()
  1546. if mode == "shrink" then
  1547. scale = scale + scale
  1548. if scale >= - 65 then
  1549. mode = "grow"
  1550. end
  1551. elseif mode == "grow" then
  1552. scale = scale + -scale*2
  1553. if scale <= - 65 then
  1554. mode = "shrink"
  1555. end
  1556. end
  1557. CreateRing(180,5,true,0,50,sphere,0,scale,scale,"Toothpaste")
  1558. sphere.Size = sphere.Size + VT(scale,scale,scale)
  1559. attractnearest("Vector",cframe.p,50,50,5)
  1560. killnearest(cframe.p,15,0)
  1561. end
  1562. for i = 1, 10 do
  1563. Swait(2)
  1564. sphere.CFrame = cframe
  1565. sphere.Size = sphere.Size - VT(5,5,5)
  1566. sphere.CFrame = cframe
  1567. sphere2.CFrame = cframe
  1568. sphere2.Size = sphere2.Size - VT(3.5,3.5,3.5)
  1569. end
  1570. sphere:remove()
  1571. sphere2:remove()
  1572. end))
  1573. for i=0, 1, 0.1 / Animation_Speed do
  1574. Swait()
  1575. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(5), RAD(0), RAD(-30)), 0.4 / Animation_Speed)
  1576. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(0), RAD(0), RAD(25)) * ANGLES(RAD(5), RAD(0), RAD(0)), 0.4 / Animation_Speed)
  1577. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(70), RAD(0), RAD(45)) * RIGHTSHOULDERC0, 0.4 / Animation_Speed)
  1578. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.25 * Player_Size, -0.25 * Player_Size) * ANGLES(RAD(90), RAD(0), RAD(-20 + MRANDOM(-2.5, 2.5))) * ANGLES(RAD(70 + MRANDOM(-2.5, 2.5)), RAD(40), RAD(0)) * LEFTSHOULDERC0, 0.4 / Animation_Speed)
  1579. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size, -1 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(-20)), 0.2 / Animation_Speed)
  1580. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 0.2 / Animation_Speed)
  1581. end
  1582. Rooted = false
  1583. ATTACK = false
  1584. end
  1585.  
  1586. function GravityBeam()
  1587. ATTACK = true
  1588. Rooted = true
  1589. for i=0, 1.5, 0.1 / Animation_Speed do
  1590. Swait()
  1591. turnto(Mouse.Hit.p)
  1592. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(75)), 0.4 / Animation_Speed)
  1593. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(0), RAD(0), RAD(-75)), 0.2 / Animation_Speed)
  1594. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(90)) * RIGHTSHOULDERC0, 0.15 / Animation_Speed)
  1595. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(25), RAD(-25)) * LEFTSHOULDERC0, 0.15 / Animation_Speed)
  1596. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size, -1 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(-20)), 0.2 / Animation_Speed)
  1597. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 0.2 / Animation_Speed)
  1598. end
  1599. local startpos = RightArm.CFrame*CF(0,-1.5,0).p
  1600. local loop = 0
  1601. local loopsound = CreateSound(CHARGESOUND, RightArm, 10, 1, true)
  1602. local loopsound2 = CreateSound("487214658", Effects, 1, 0, true)
  1603. local pos = nil
  1604. repeat
  1605. if loop < 150 then
  1606. Swait()
  1607. loop = loop + 1
  1608. turnto(Mouse.Hit.p)
  1609. MagicSphere(15,25,RightArm.CFrame*CF(0,-1,0),"Toothpaste")
  1610. MagicSphere(12,25,RightArm.CFrame*CF(0,-1,0),"Toothpaste")
  1611. else
  1612. loopsound2.Pitch = 1
  1613. loopsound:Stop()
  1614. startpos = RightArm.CFrame*CF(0,-1.5,0).p
  1615. turnto(Mouse.Hit.p)
  1616. MagicSphere(35,25,CF(startpos),"Toothpaste")
  1617. MagicSphere(32,25,CF(startpos),"Toothpaste")
  1618. local RayHit, RayPos, RayNormal = CastZapRay(startpos, Mouse.Hit.p, 150, Character, false)
  1619. local distance = (startpos - RayPos).magnitude
  1620. local laser = Instance.new("Part",Effects)
  1621. laser.Transparency = 0.5
  1622. laser.CanCollide = false
  1623. laser.Anchored = true
  1624. laser.BrickColor = BrickColor.new("Toothpaste")
  1625. laser.Material = "Neon"
  1626. laser.formFactor = Enum.FormFactor.Custom
  1627. laser.Size = Vector3.new(2.5, 2.5, distance)
  1628. laser.CFrame = CFrame.new(startpos, RayPos) * CFrame.new(0, 0, -distance/2)
  1629. local laser2 = Instance.new("Part",Effects)
  1630. laser2.Transparency = 0
  1631. laser2.CanCollide = false
  1632. laser2.Anchored = true
  1633. laser2.BrickColor = BrickColor.new("Toothpaste")
  1634. laser2.Material = "Neon"
  1635. laser2.formFactor = Enum.FormFactor.Custom
  1636. laser2.Size = Vector3.new(2, 2, distance)
  1637. laser2.CFrame = CFrame.new(startpos, RayPos) * CFrame.new(0, 0, -distance/2)
  1638. killnearest(RayPos,5,150,true)
  1639. MagicSphere(350,2,CF(RayPos),"Toothpaste")
  1640. MagicSphere(320,2,CF(RayPos),"Toothpaste")
  1641. if RayHit ~= nil then
  1642. CreateWave(0,5,false,0,25,CF(RayPos),0,"Toothpaste")
  1643. end
  1644. attractnearest("Vector",RayPos,40,50,10)
  1645. pos = RayPos
  1646. Swait()
  1647. laser2:remove()
  1648. laser:remove()
  1649. end
  1650. until KEYHOLD == false
  1651. if loop == 150 then
  1652. local cframe = CF(pos)
  1653. coroutine.resume(coroutine.create(function()
  1654. coroutine.resume(coroutine.create(function()
  1655. CreateSound(RELEASESOUND, Effects, 2, 1)
  1656. MagicSphere(500,55,cframe,"Toothpaste")
  1657. MagicSphere(450,55,cframe,"Toothpaste")
  1658. for i = 1, 15 do
  1659. Swait()
  1660. killnearest(cframe.p,75,150)
  1661. end
  1662. end))
  1663. end))
  1664. end
  1665. loopsound2:remove()
  1666. loopsound:remove()
  1667. Rooted = false
  1668. ATTACK = false
  1669. end
  1670.  
  1671. --//=================================\\
  1672. --|| ASSIGN THINGS TO KEYS
  1673. --\\=================================//
  1674.  
  1675. Humanoid.Changed:connect(function(Jump)
  1676. if Jump == "Jump" and (Disable_Jump == true or DISABLEJUMPING == true) then
  1677. Humanoid.Jump = false
  1678. end
  1679. end)
  1680.  
  1681. function MouseDown(Mouse)
  1682. if ATTACK == false then
  1683. end
  1684. end
  1685.  
  1686. function MouseUp(Mouse)
  1687. HOLD = false
  1688. end
  1689.  
  1690. function KeyDown(Key)
  1691. KEYHOLD = true
  1692. if Key == "q" and ATTACK == false then
  1693. GraviBomb()
  1694. end
  1695.  
  1696. if Key == "e" and ATTACK == false then
  1697. GraviSpear()
  1698. end
  1699.  
  1700. if Key == "r" and ATTACK == false then
  1701. GravityGlobe()
  1702. end
  1703.  
  1704. if Key == "g" and ATTACK == false then
  1705. GravityBeam()
  1706. end
  1707.  
  1708. if Key == "x" and ATTACK == false then
  1709. end
  1710.  
  1711. if Key == "c" and ATTACK == false then
  1712. WarpSpear()
  1713. end
  1714.  
  1715. if Key == "t" and ATTACK == false then
  1716. CreateSound("305685800", Head, 10, 1 ,false)
  1717. end
  1718. end
  1719.  
  1720. function KeyUp(Key)
  1721. KEYHOLD = false
  1722. end
  1723.  
  1724. Mouse.Button1Down:connect(function(NEWKEY)
  1725. MouseDown(NEWKEY)
  1726. end)
  1727. Mouse.Button1Up:connect(function(NEWKEY)
  1728. MouseUp(NEWKEY)
  1729. end)
  1730. Mouse.KeyDown:connect(function(NEWKEY)
  1731. KeyDown(NEWKEY)
  1732. end)
  1733. Mouse.KeyUp:connect(function(NEWKEY)
  1734. KeyUp(NEWKEY)
  1735. end)
  1736.  
  1737. --//=================================\\
  1738. --\\=================================//
  1739.  
  1740.  
  1741. function unanchor()
  1742. if UNANCHOR == true then
  1743. g = Character:GetChildren()
  1744. for i = 1, #g do
  1745. if g[i].ClassName == "Part" then
  1746. g[i].Anchored = false
  1747. end
  1748. end
  1749. end
  1750. end
  1751.  
  1752.  
  1753. --//=================================\\
  1754. --|| WRAP THE WHOLE SCRIPT UP
  1755. --\\=================================//
  1756.  
  1757. Humanoid.Changed:connect(function(Jump)
  1758. if Jump == "Jump" and (Disable_Jump == true or DISABLEJUMPING == true) then
  1759. Humanoid.Jump = false
  1760. end
  1761. end)
  1762.  
  1763. ANIMATE.Parent = nil
  1764. local IDLEANIMATION = Humanoid:LoadAnimation(ROBLOXIDLEANIMATION)
  1765. IDLEANIMATION:Play()
  1766.  
  1767. while true do
  1768. Swait()
  1769. SINE = SINE + CHANGE
  1770. local TORSOVELOCITY = (RootPart.Velocity * VT(1, 0, 1)).magnitude
  1771. local TORSOVERTICALVELOCITY = RootPart.Velocity.y
  1772. local LV = Torso.CFrame:pointToObjectSpace(Torso.Velocity - Torso.Position)
  1773. local HITFLOOR = Raycast(RootPart.Position, (CF(RootPart.Position, RootPart.Position + VT(0, -1, 0))).lookVector, 4 * Player_Size, Character)
  1774. local WALKSPEEDVALUE = 6 / (Humanoid.WalkSpeed / 16)
  1775. if ANIM == "Walk" and TORSOVELOCITY > 1 then
  1776. RootJoint.C1 = Clerp(RootJoint.C1, ROOTC0 * CF(0, 0, -0.1 * COS(SINE / (WALKSPEEDVALUE / 2)) * Player_Size) * ANGLES(RAD(0), RAD(0) - RootPart.RotVelocity.Y / 75, RAD(0)), 0.2 * (Humanoid.WalkSpeed / 16) / Animation_Speed)
  1777. Neck.C1 = Clerp(Neck.C1, CF(0 * Player_Size, -0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(-90), RAD(0), RAD(180)) * ANGLES(RAD(2.5 * SIN(SINE / (WALKSPEEDVALUE / 2))), RAD(0), RAD(0) - Head.RotVelocity.Y / 30), 0.2 * (Humanoid.WalkSpeed / 16) / Animation_Speed)
  1778. --RightHip.C1 = Clerp(RightHip.C1, CF(0.5 * Player_Size, 0.875 * Player_Size - 0.125 * SIN(SINE / WALKSPEEDVALUE) * Player_Size, -0.125 * COS(SINE / WALKSPEEDVALUE) * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0) - RightLeg.RotVelocity.Y / 75, RAD(0), RAD(60 * COS(SINE / WALKSPEEDVALUE))), 0.2 * (Humanoid.WalkSpeed / 16) / Animation_Speed)
  1779. --LeftHip.C1 = Clerp(LeftHip.C1, CF(-0.5 * Player_Size, 0.875 * Player_Size + 0.125 * SIN(SINE / WALKSPEEDVALUE) * Player_Size, 0.125 * COS(SINE / WALKSPEEDVALUE) * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0) + LeftLeg.RotVelocity.Y / 75, RAD(0), RAD(60 * COS(SINE / WALKSPEEDVALUE))), 0.2 * (Humanoid.WalkSpeed / 16) / Animation_Speed)
  1780. elseif (ANIM ~= "Walk") or (TORSOVELOCITY < 1) then
  1781. RootJoint.C1 = Clerp(RootJoint.C1, ROOTC0 * CF(0, 0, 0) * ANGLES(RAD(0), RAD(0), RAD(0)), 0.2 / Animation_Speed)
  1782. Neck.C1 = Clerp(Neck.C1, CF(0 * Player_Size, -0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(-90), RAD(0), RAD(180)) * ANGLES(RAD(0), RAD(0), RAD(0)), 0.2 / Animation_Speed)
  1783. --RightHip.C1 = Clerp(RightHip.C1, CF(0.5 * Player_Size, 1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(0)), 0.2 / Animation_Speed)
  1784. ----LeftHip.C1 = Clerp(LeftHip.C1, CF(-0.5 * Player_Size, 1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(0)), 0.2 / Animation_Speed)
  1785. end
  1786. if TORSOVERTICALVELOCITY > 1 and HITFLOOR == nil then
  1787. ANIM = "Jump"
  1788. if ATTACK == false then
  1789. RootJoint.C0 = Clerp(RootJoint.C0, ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(0)), 0.2 / Animation_Speed)
  1790. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(-20), RAD(0), RAD(0)), 0.2 / Animation_Speed)
  1791. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(-40), RAD(0), RAD(20)) * RIGHTSHOULDERC0, 0.2 / Animation_Speed)
  1792. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(-40), RAD(0), RAD(-20)) * LEFTSHOULDERC0, 0.2 / Animation_Speed)
  1793. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -1 * Player_Size, -0.3 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(-5), RAD(0), RAD(-20)), 0.2 / Animation_Speed)
  1794. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, -0.3 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(-5), RAD(0), RAD(20)), 0.2 / Animation_Speed)
  1795. end
  1796. elseif TORSOVERTICALVELOCITY < -1 and HITFLOOR == nil then
  1797. ANIM = "Fall"
  1798. if ATTACK == false then
  1799. RootJoint.C0 = Clerp(RootJoint.C0, ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(0)), 0.2 / Animation_Speed)
  1800. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(20), RAD(0), RAD(0)), 0.2 / Animation_Speed)
  1801. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(60)) * RIGHTSHOULDERC0, 0.2 / Animation_Speed)
  1802. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(-60)) * LEFTSHOULDERC0, 0.2 / Animation_Speed)
  1803. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(20)), 0.2 / Animation_Speed)
  1804. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -1 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0), RAD(0), RAD(10)), 0.2 / Animation_Speed)
  1805. end
  1806. elseif TORSOVELOCITY < 1 and HITFLOOR ~= nil then
  1807. ANIM = "Idle"
  1808. if ATTACK == false then
  1809. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size + 0.05 * COS(SINE / 12) * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(0)), 0.15 / Animation_Speed)
  1810. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(15 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 0.15 / Animation_Speed)
  1811. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(12)) * RIGHTSHOULDERC0, 0.15 / Animation_Speed)
  1812. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(0), RAD(0), RAD(-12)) * LEFTSHOULDERC0, 0.15 / Animation_Speed)
  1813. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size - 0 * Player_Size, -0.2 * Player_Size) * ANGLES(RAD(0), RAD(70), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 0.15 / Animation_Speed)
  1814. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -0.8 * Player_Size - 0.2 * COS(SINE / 12) * Player_Size, -0.01 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 0.15 / Animation_Speed)
  1815. end
  1816. elseif TORSOVELOCITY > 1 and HITFLOOR ~= nil then
  1817. ANIM = "Walk"
  1818. WALK = WALK + 1 / Animation_Speed
  1819. if WALK >= 15 - (5 * (Humanoid.WalkSpeed / 16 / Player_Size)) then
  1820. WALK = 0
  1821. if WALKINGANIM == true then
  1822. WALKINGANIM = false
  1823. elseif WALKINGANIM == false then
  1824. WALKINGANIM = true
  1825. end
  1826. end
  1827. --RightHip.C1 = Clerp(RightHip.C1, CF(0.5 * Player_Size, 0.875 * Player_Size - 0.125 * SIN(SINE / WALKSPEEDVALUE) * Player_Size, -0.125 * COS(SINE / WALKSPEEDVALUE) * Player_Size) * ANGLES(RAD(0), RAD(90), RAD(0)) * ANGLES(RAD(0) - RightLeg.RotVelocity.Y / 75, RAD(0), RAD(60 * COS(SINE / WALKSPEEDVALUE))), 0.2 * (Humanoid.WalkSpeed / 16) / Animation_Speed)
  1828. --LeftHip.C1 = Clerp(LeftHip.C1, CF(-0.5 * Player_Size, 0.875 * Player_Size + 0.125 * SIN(SINE / WALKSPEEDVALUE) * Player_Size, 0.125 * COS(SINE / WALKSPEEDVALUE) * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(0) + LeftLeg.RotVelocity.Y / 75, RAD(0), RAD(60 * COS(SINE / WALKSPEEDVALUE))), 0.2 * (Humanoid.WalkSpeed / 16) / Animation_Speed)
  1829. if ATTACK == false then
  1830. RootJoint.C0 = Clerp(RootJoint.C0,ROOTC0 * CF(0 * Player_Size, 0 * Player_Size, 0.7 * Player_Size) * ANGLES(RAD(25), RAD(0), RAD(0)), 0.15 / Animation_Speed*3)
  1831. Neck.C0 = Clerp(Neck.C0, NECKC0 * CF(0 * Player_Size, 0 * Player_Size, 0 + ((1 * Player_Size) - 1)) * ANGLES(RAD(-5 - 2.5 * SIN(SINE / 12)), RAD(0), RAD(0)), 0.15 / Animation_Speed)
  1832. RightShoulder.C0 = Clerp(RightShoulder.C0, CF(1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(-40), RAD(0), RAD(20)) * RIGHTSHOULDERC0, 0.2 / Animation_Speed)
  1833. LeftShoulder.C0 = Clerp(LeftShoulder.C0, CF(-1.5 * Player_Size, 0.5 * Player_Size, 0 * Player_Size) * ANGLES(RAD(-40), RAD(0), RAD(-20)) * LEFTSHOULDERC0, 0.2 / Animation_Speed)
  1834. RightHip.C0 = Clerp(RightHip.C0, CF(1 * Player_Size, -0.3 * Player_Size - 0 * Player_Size, -0.2 * Player_Size) * ANGLES(RAD(0), RAD(70), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 0.15 / Animation_Speed)
  1835. LeftHip.C0 = Clerp(LeftHip.C0, CF(-1 * Player_Size, -0.8 * Player_Size - 0.2 * COS(SINE / 12) * Player_Size, -0.01 * Player_Size) * ANGLES(RAD(0), RAD(-90), RAD(0)) * ANGLES(RAD(-8), RAD(0), RAD(0)), 0.15 / Animation_Speed)
  1836. end
  1837. end
  1838. if #Effects2>0 then
  1839. for e=1,#Effects2 do
  1840. if Effects2[e]~=nil then
  1841. local Thing=Effects2[e]
  1842. if Thing~=nil then
  1843. local Part=Thing[1]
  1844. local Mode=Thing[2]
  1845. local Delay=Thing[3]
  1846. local IncX=Thing[4]
  1847. local IncY=Thing[5]
  1848. local IncZ=Thing[6]
  1849. local Part2=Thing[8]
  1850. if Thing[1].Transparency<=1 then
  1851. if Thing[2]=="Block1" then
  1852. Thing[1].CFrame=Thing[1].CFrame
  1853. Mesh=Thing[1].Mesh
  1854. Mesh.Scale=Mesh.Scale+VT(Thing[4],Thing[5],Thing[6])
  1855. Thing[1].Transparency=Thing[1].Transparency+Thing[3]
  1856. elseif Thing[2]=="Cylinder" then
  1857. Mesh=Thing[1].Mesh
  1858. Mesh.Scale=Mesh.Scale+VT(Thing[4],Thing[5],Thing[6])
  1859. Thing[1].Transparency=Thing[1].Transparency+Thing[3]
  1860. elseif Thing[2]=="Blood" then
  1861. Mesh=Thing[7]
  1862. Thing[1].CFrame=Thing[1].CFrame*CF(0,.5,0)
  1863. Mesh.Scale=Mesh.Scale+VT(Thing[4],Thing[5],Thing[6])
  1864. Thing[1].Transparency=Thing[1].Transparency+Thing[3]
  1865. elseif Thing[2]=="Elec" then
  1866. Mesh=Thing[1].Mesh
  1867. Mesh.Scale=Mesh.Scale+VT(Thing[7],Thing[8],Thing[9])
  1868. Thing[1].Transparency=Thing[1].Transparency+Thing[3]
  1869. elseif Thing[2]=="Disappear" then
  1870. Thing[1].Transparency=Thing[1].Transparency+Thing[3]
  1871. end
  1872. else
  1873. Part.Parent=nil
  1874. table.remove(Effects2,e)
  1875. end
  1876. end
  1877. end
  1878. end
  1879. end
  1880. unanchor()
  1881. Humanoid.MaxHealth = "inf"
  1882. Humanoid.Health = "inf"
  1883. if Rooted == false then
  1884. Disable_Jump = false
  1885. Humanoid.WalkSpeed = Speed
  1886. elseif Rooted == true then
  1887. Disable_Jump = true
  1888. Humanoid.WalkSpeed = 0
  1889. end
  1890.  
  1891. --CreateMagicCircle(2 ,false,0,3,LeftLeg.CFrame * CF(0,-1.2,0),true)
  1892. end
  1893.  
  1894. --bird wings Gifted by TXrangers222, Local Script!
  1895. --Jump Two Time
  1896. --Down Press Q
  1897. --Wings Spin Press A Two Time
  1898. --Wings Spin Press D Two Time
  1899.  
  1900. script.Parent = nil
  1901.  
  1902. function fly()
  1903.  
  1904. for i,v in pairs(script:GetChildren()) do
  1905.  
  1906. pcall(function() v.Value = "" end)
  1907.  
  1908. game:GetService("Debris"):AddItem(v,.1)
  1909.  
  1910. end
  1911.  
  1912. function weld(p0,p1,c0,c1,par)
  1913.  
  1914. local w = Instance.new("Weld",p0 or par)
  1915.  
  1916. w.Part0 = p0
  1917.  
  1918. w.Part1 = p1
  1919.  
  1920. w.C0 = c0 or CFrame.new()
  1921.  
  1922. w.C1 = c1 or CFrame.new()
  1923.  
  1924. return w
  1925.  
  1926. end
  1927.  
  1928. local motors = {}
  1929.  
  1930. function motor(p0,p1,c0,c1,des,vel,par)
  1931.  
  1932. local w = Instance.new("Motor6D",p0 or par)
  1933.  
  1934. w.Part0 = p0
  1935.  
  1936. w.Part1 = p1
  1937.  
  1938. w.C0 = c0 or CFrame.new()
  1939.  
  1940. w.C1 = c1 or CFrame.new()
  1941.  
  1942. w.MaxVelocity = tonumber(vel) or .05
  1943.  
  1944. w.DesiredAngle = tonumber(des) or 0
  1945.  
  1946. return w
  1947.  
  1948. end
  1949.  
  1950. function lerp(a,b,c)
  1951.  
  1952. return a+(b-a)*c
  1953.  
  1954. end
  1955.  
  1956. function clerp(c1,c2,al)
  1957.  
  1958. local com1 = {c1.X,c1.Y,c1.Z,c1:toEulerAnglesXYZ()}
  1959.  
  1960. local com2 = {c2.X,c2.Y,c2.Z,c2:toEulerAnglesXYZ()}
  1961.  
  1962. for i,v in pairs(com1) do
  1963.  
  1964. com1[i] = lerp(v,com2[i],al)
  1965.  
  1966. end
  1967.  
  1968. return CFrame.new(com1[1],com1[2],com1[3]) * CFrame.Angles(select(4,unpack(com1)))
  1969.  
  1970. end
  1971.  
  1972. function ccomplerp(c1,c2,al)
  1973.  
  1974. local com1 = {c1:components()}
  1975.  
  1976. local com2 = {c2:components()}
  1977.  
  1978. for i,v in pairs(com1) do
  1979.  
  1980. com1[i] = lerp(v,com2[i],al)
  1981.  
  1982. end
  1983.  
  1984. return CFrame.new(unpack(com1))
  1985.  
  1986. end
  1987.  
  1988. function tickwave(time,length,offset)
  1989.  
  1990. return (math.abs((tick()+(offset or 0))%time-time/2)*2-time/2)/time/2*length
  1991.  
  1992. end
  1993.  
  1994. function invcol(c)
  1995.  
  1996. c = c.Color
  1997.  
  1998. return BrickColor.new(Color3.new(1-c.b,1-c.g,1-c.r))
  1999.  
  2000. end
  2001.  
  2002. local oc = oc or function(...) return ... end
  2003.  
  2004. local plr = game.Players.LocalPlayer
  2005.  
  2006. local char = plr.Character
  2007.  
  2008. local tor = char.Torso
  2009.  
  2010. local hum = char.Humanoid
  2011.  
  2012. hum.PlatformStand = false
  2013.  
  2014. pcall(function()
  2015.  
  2016. char.Wings:Destroy()
  2017.  
  2018. end)
  2019.  
  2020. pcall(function()
  2021.  
  2022. char.Angel:Destroy() -- hat
  2023.  
  2024. end)
  2025.  
  2026. local mod = Instance.new("Model",char)
  2027.  
  2028. mod.Name = "Wings"
  2029.  
  2030. local special = {
  2031.  
  2032. --antiboomz0r = {"Really black","Institutional white",0,0,false,Color3.new(1,1,.95),Color3.new(1,1,.6)},
  2033.  
  2034. antiboomz0r = {"New Yeller",nil,0.4,0.7,true,Color3.new(1,1,.95),Color3.new(1,1,.6)},
  2035.  
  2036. --antiboomz0r = {"Cyan","Toothpaste",0,0,false,Color3.new(1,0,0),Color3.new(0,0,0)},
  2037.  
  2038. taart = {"Royal purple",nil,.4,.4,true},
  2039.  
  2040. mitta = {"Black",nil,0,0,false},
  2041.  
  2042. penjuin3 = {"White",nil,0,0,false},
  2043.  
  2044. thepc8110 = {"Black","Bright red",.5,0,false,Color3.new(1,0,0),Color3.new(0,0,0)},
  2045.  
  2046. nonspeaker = {"Cyan","Toothpaste",0,0,false,Color3.new(1,0,0),Color3.new(0,0,0)},
  2047.  
  2048. littleau999 = {"Reddish brown",1030,0,0,false},
  2049.  
  2050. unscripter = {"Really black","Really black",.2,0,true,Color3.new(0,0,0),Color3.new(0,0,0)},
  2051.  
  2052. oxcool1 = {"Really black","White",.2,0,false,Color3.new(0,0,0),Color3.new(0,0,0)},
  2053.  
  2054. krodmiss = {"Really black",nil,0,0,false},
  2055.  
  2056. }
  2057.  
  2058. local topcolor = invcol(char.Torso.BrickColor)
  2059.  
  2060. local feacolor = char.Torso.BrickColor
  2061.  
  2062. local ptrans = 0
  2063.  
  2064. local pref = 0
  2065.  
  2066. local fire = false
  2067.  
  2068. local fmcol = Color3.new()
  2069.  
  2070. local fscol = Color3.new()
  2071.  
  2072. local spec = special[plr.Name:lower()]
  2073.  
  2074. if spec then
  2075.  
  2076. topcolor,feacolor,ptrans,pref,fire,fmcol,fscol = spec[1] and BrickColor.new(spec[1]) or topcolor,spec[2] and BrickColor.new(spec[2]) or feacolor,spec[3],spec[4],spec[5],spec[6],spec[7]
  2077.  
  2078. end
  2079.  
  2080. local part = Instance.new("Part")
  2081.  
  2082. part.FormFactor = "Custom"
  2083.  
  2084. part.Size = Vector3.new(.2,.2,.2)
  2085.  
  2086. part.TopSurface,part.BottomSurface = 0,0
  2087.  
  2088. part.CanCollide = false
  2089.  
  2090. part.BrickColor = topcolor
  2091.  
  2092. part.Transparency = ptrans
  2093.  
  2094. part.Reflectance = pref
  2095.  
  2096. local ef = Instance.new("Fire",fire and part or nil)
  2097.  
  2098. ef.Size = .15
  2099.  
  2100. ef.Color = fmcol or Color3.new()
  2101.  
  2102. ef.SecondaryColor = fscol or Color3.new()
  2103.  
  2104. part:BreakJoints()
  2105.  
  2106.  
  2107. function newpart()
  2108.  
  2109. local clone = part:Clone()
  2110.  
  2111. clone.Parent = mod
  2112.  
  2113. clone:BreakJoints()
  2114.  
  2115. return clone
  2116.  
  2117. end
  2118.  
  2119. local feath = newpart()
  2120.  
  2121. feath.BrickColor = feacolor
  2122.  
  2123. feath.Transparency = 0
  2124.  
  2125. Instance.new("SpecialMesh",feath).MeshType = "Sphere"
  2126.  
  2127. function newfeather()
  2128.  
  2129. local clone = feath:Clone()
  2130.  
  2131. clone.Parent = mod
  2132.  
  2133. clone:BreakJoints()
  2134.  
  2135. return clone
  2136.  
  2137. end
  2138.  
  2139.  
  2140. ---------- RIGHT WING
  2141.  
  2142. local r1 = newpart()
  2143.  
  2144. r1.Size = Vector3.new(.3,1.5,.3)*1.2
  2145.  
  2146. local rm1 = motor(tor,r1,CFrame.new(.35,.6,.4) * CFrame.Angles(0,0,math.rad(-60)) * CFrame.Angles(math.rad(30),math.rad(-25),0),CFrame.new(0,-.8,0),.1)
  2147.  
  2148. local r2 = newpart()
  2149.  
  2150. r2.Size = Vector3.new(.4,1.8,.4)*1.2
  2151.  
  2152. local rm2 = motor(r1,r2,CFrame.new(0,.75,0) * CFrame.Angles(0,0,math.rad(50)) * CFrame.Angles(math.rad(-30),math.rad(15),0),CFrame.new(0,-.9,0),.1)
  2153.  
  2154. local r3 = newpart()
  2155.  
  2156. r3.Size = Vector3.new(.3,2.2,.3)*1.2
  2157.  
  2158. local rm3 = motor(r2,r3,CFrame.new(.1,.9,0) * CFrame.Angles(0,0,math.rad(-140)) * CFrame.Angles(math.rad(-3),0,0),CFrame.new(0,-1.1,0),.1)
  2159.  
  2160. local r4 = newpart()
  2161.  
  2162. r4.Size = Vector3.new(.25,1.2,.25)*1.2
  2163.  
  2164. local rm4 = motor(r3,r4,CFrame.new(0,1.1,0) * CFrame.Angles(0,0,math.rad(-10)) * CFrame.Angles(math.rad(-3),0,0),CFrame.new(0,-.6,0),.1)
  2165.  
  2166. local feather = newfeather()
  2167.  
  2168. feather.Mesh.Scale = Vector3.new(1,1,1)
  2169.  
  2170. feather.Size = Vector3.new(.4,3,.3)
  2171.  
  2172. weld(r4,feather,CFrame.new(-.1,-.3,0),CFrame.new(0,-1.5,0))
  2173.  
  2174. feather = newfeather()
  2175.  
  2176. feather.Mesh.Scale = Vector3.new(1,1,1)
  2177.  
  2178. feather.Size = Vector3.new(.4,2.3,.3)
  2179.  
  2180. weld(r4,feather,CFrame.new(.1,-.1,0) * CFrame.Angles(0,math.random()*.1,0),CFrame.new(0,-1.1,0))
  2181.  
  2182. feather = newfeather()
  2183.  
  2184. feather.Mesh.Scale = Vector3.new(1,1,1)
  2185.  
  2186. feather.Size = Vector3.new(.35,2.2,.25)
  2187.  
  2188. weld(r4,feather,CFrame.new(.1,-.3,0) * CFrame.Angles(0,math.random()*.1,math.rad(-10)),CFrame.new(0,-1.1,0))
  2189.  
  2190. local rf3 = {}
  2191.  
  2192. for i=0,7 do
  2193.  
  2194. feather = newfeather()
  2195.  
  2196. feather.Mesh.Scale = Vector3.new(1,1,1)
  2197.  
  2198. feather.Size = Vector3.new(.45,2.2,.35)
  2199.  
  2200. table.insert(rf3,motor(r3,feather,CFrame.new(.05,1-i*.285,0) * CFrame.Angles(0,math.random()*.1,math.rad(-25-i*2)),CFrame.new(0,-feather.Size.Y/2,0)))
  2201.  
  2202. end
  2203.  
  2204. local rf2 = {}
  2205.  
  2206. for i=0,6 do
  2207.  
  2208. feather = newfeather()
  2209.  
  2210. feather.Mesh.Scale = Vector3.new(1,1,1)
  2211.  
  2212. feather.Size = Vector3.new(.45,2.2-i*.08,.3)
  2213.  
  2214. table.insert(rf2,motor(r2,feather,CFrame.new(.05,.75-i*.26,0) * CFrame.Angles(0,math.random()*.1,math.rad(-75-i*4)),CFrame.new(0,-feather.Size.Y/2,0)))
  2215.  
  2216. end
  2217.  
  2218. local rf1 = {}
  2219.  
  2220. for i=0,6 do
  2221.  
  2222. feather = newfeather()
  2223.  
  2224. feather.Mesh.Scale = Vector3.new(1,1,1)
  2225.  
  2226. feather.Size = Vector3.new(.37,1.65-i*.06,.25)
  2227.  
  2228. table.insert(rf1,motor(r1,feather,CFrame.new(.05,.63-i*.21,0) * CFrame.Angles(0,math.random()*.05,math.rad(-75)),CFrame.new(0,-feather.Size.Y/2,0)))
  2229.  
  2230. end
  2231.  
  2232. ---------- LEFT WING
  2233.  
  2234. local l1 = newpart()
  2235.  
  2236. l1.Size = Vector3.new(.3,1.5,.3)*1.2
  2237.  
  2238. local lm1 = motor(tor,l1,CFrame.new(-.35,.6,.4) * CFrame.Angles(0,0,math.rad(60)) * CFrame.Angles(math.rad(30),math.rad(25),0) * CFrame.Angles(0,-math.pi,0),CFrame.new(0,-.8,0) ,.1)
  2239.  
  2240. local l2 = newpart()
  2241.  
  2242. l2.Size = Vector3.new(.4,1.8,.4)*1.2
  2243.  
  2244. local lm2 = motor(l1,l2,CFrame.new(0,.75,0) * CFrame.Angles(0,0,math.rad(50)) * CFrame.Angles(math.rad(30),math.rad(-15),0),CFrame.new(0,-.9,0),.1)
  2245.  
  2246. local l3 = newpart()
  2247.  
  2248. l3.Size = Vector3.new(.3,2.2,.3)*1.2
  2249.  
  2250. local lm3 = motor(l2,l3,CFrame.new(.1,.9,0) * CFrame.Angles(0,0,math.rad(-140)) * CFrame.Angles(math.rad(3),0,0),CFrame.new(0,-1.1,0),.1)
  2251.  
  2252. local l4 = newpart()
  2253.  
  2254. l4.Size = Vector3.new(.25,1.2,.25)*1.2
  2255.  
  2256. local lm4 = motor(l3,l4,CFrame.new(0,1.1,0) * CFrame.Angles(0,0,math.rad(-10)) * CFrame.Angles(math.rad(3),0,0),CFrame.new(0,-.6,0),.1)
  2257.  
  2258. local feather = newfeather()
  2259.  
  2260. feather.Mesh.Scale = Vector3.new(1,1,1)
  2261.  
  2262. feather.Size = Vector3.new(.4,3,.3)
  2263.  
  2264. weld(l4,feather,CFrame.new(-.1,-.3,0),CFrame.new(0,-1.5,0))
  2265.  
  2266. feather = newfeather()
  2267.  
  2268. feather.Mesh.Scale = Vector3.new(1,1,1)
  2269.  
  2270. feather.Size = Vector3.new(.4,2.3,.3)
  2271.  
  2272. weld(l4,feather,CFrame.new(.1,-.1,0) * CFrame.Angles(0,math.random()*.1,0),CFrame.new(0,-1.1,0))
  2273.  
  2274. feather = newfeather()
  2275.  
  2276. feather.Mesh.Scale = Vector3.new(1,1,1)
  2277.  
  2278. feather.Size = Vector3.new(.35,2.2,.25)
  2279.  
  2280. weld(l4,feather,CFrame.new(.1,-.3,0) * CFrame.Angles(0,math.random()*.1,math.rad(-10)),CFrame.new(0,-1.1,0))
  2281.  
  2282. local lf3 = {}
  2283.  
  2284. for i=0,7 do
  2285.  
  2286. feather = newfeather()
  2287.  
  2288. feather.Mesh.Scale = Vector3.new(1,1,1)
  2289.  
  2290. feather.Size = Vector3.new(.45,2.2,.35)
  2291.  
  2292. table.insert(lf3,motor(l3,feather,CFrame.new(.05,1-i*.285,0) * CFrame.Angles(0,math.random()*.1,math.rad(-25-i*2)),CFrame.new(0,-feather.Size.Y/2,0)))
  2293.  
  2294. end
  2295.  
  2296. local lf2 = {}
  2297.  
  2298. for i=0,6 do
  2299.  
  2300. feather = newfeather()
  2301.  
  2302. feather.Mesh.Scale = Vector3.new(1,1,1)
  2303.  
  2304. feather.Size = Vector3.new(.45,2.2-i*.08,.3)
  2305.  
  2306. table.insert(lf2,motor(l2,feather,CFrame.new(.05,.75-i*.26,0) * CFrame.Angles(0,math.random()*.1,math.rad(-75-i*4)),CFrame.new(0,-feather.Size.Y/2,0)))
  2307.  
  2308. end
  2309.  
  2310. local lf1 = {}
  2311.  
  2312. for i=0,6 do
  2313.  
  2314. feather = newfeather()
  2315.  
  2316. feather.Mesh.Scale = Vector3.new(1,1,1)
  2317.  
  2318. feather.Size = Vector3.new(.37,1.65-i*.06,.25)
  2319.  
  2320. table.insert(lf1,motor(l1,feather,CFrame.new(.05,.63-i*.21,0) * CFrame.Angles(0,math.random()*.05,math.rad(-75)),CFrame.new(0,-feather.Size.Y/2,0)))
  2321.  
  2322. end
  2323.  
  2324. local rwing = {rm1,rm2,rm3,rm4}
  2325.  
  2326. local lwing = {lm1,lm2,lm3,lm4}
  2327.  
  2328. local oc0 = {}
  2329.  
  2330. for i,v in pairs(rwing) do
  2331.  
  2332. oc0[v] = v.C0
  2333.  
  2334. end
  2335.  
  2336. for i,v in pairs(lwing) do
  2337.  
  2338. oc0[v] = v.C0
  2339.  
  2340. end
  2341.  
  2342. function gotResized()
  2343.  
  2344. if lastsize then
  2345.  
  2346. if tor.Size == lastsize then return end -- This shouldn't happen?
  2347.  
  2348. local scaleVec = tor.Size/lastsize
  2349.  
  2350. for i,v in pairs(oc0) do
  2351.  
  2352. oc0[i] = v-v.p+scaleVec*v.p
  2353.  
  2354. end
  2355.  
  2356. lastsize = tor.Size
  2357.  
  2358. end
  2359.  
  2360. lastsize = tor.Size
  2361.  
  2362. end
  2363.  
  2364. tor.Changed:connect(function(p)
  2365.  
  2366. if p == "Size" then
  2367.  
  2368. gotResized()
  2369.  
  2370. end
  2371.  
  2372. end)
  2373.  
  2374. gotResized()
  2375.  
  2376. local idle = {0,0.5,-.2,0; .05,.05,.1,.05; -.6,-1.5,.1,0;}--0,.3,0,0
  2377.  
  2378. local outlow = {-.7,-.2,1.8,0; .3,.05,.1,.05; .2,0,0,0}
  2379.  
  2380. local outhigh = {.5,-.2,1.8,0; .3,.05,.1,.05; .2,0,0,0}
  2381.  
  2382. local veryhigh = {.9,-.3,1.9,0; .3,.05,.1,.05; .2,0,0,0}
  2383.  
  2384. local flap1 = {-.3,.3,1.1,-.2; .3,.05,.1,.05; .2,-.6,0,0}
  2385.  
  2386. local divebomb = {0,.2,.4,-.7; .3,.05,.1,.05; 0,-.5,-.6,0}
  2387.  
  2388.  
  2389. function setwings(tab,time)
  2390.  
  2391. time = time or 10
  2392.  
  2393. for i=1,4 do
  2394.  
  2395. rwing[i].DesiredAngle = tab[i]
  2396.  
  2397. lwing[i].DesiredAngle = tab[i]
  2398.  
  2399. rwing[i].MaxVelocity = math.abs(tab[i]-rwing[i].CurrentAngle)/time
  2400.  
  2401. lwing[i].MaxVelocity = math.abs(tab[i]-lwing[i].CurrentAngle)/time
  2402.  
  2403. local rcf = oc0[rwing[i]] * (tab[12+i] or CFrame.new())
  2404.  
  2405. local lcf = oc0[lwing[i]] * (tab[12+i] or CFrame.new())
  2406.  
  2407. end
  2408.  
  2409. for i,v in pairs(rf1) do
  2410.  
  2411. v.DesiredAngle = tab[9]
  2412.  
  2413. v.MaxVelocity = math.abs(v.DesiredAngle-v.CurrentAngle)/time
  2414.  
  2415. end
  2416.  
  2417. for i,v in pairs(lf1) do
  2418.  
  2419. v.DesiredAngle = tab[9]
  2420.  
  2421. v.MaxVelocity = math.abs(v.DesiredAngle-v.CurrentAngle)/time
  2422.  
  2423. end
  2424.  
  2425. for i,v in pairs(rf2) do
  2426.  
  2427. v.DesiredAngle = tab[10]
  2428.  
  2429. v.MaxVelocity = math.abs(v.DesiredAngle-v.CurrentAngle)/time
  2430.  
  2431. end
  2432.  
  2433. for i,v in pairs(lf2) do
  2434.  
  2435. v.DesiredAngle = tab[10]
  2436.  
  2437. v.MaxVelocity = math.abs(v.DesiredAngle-v.CurrentAngle)/time
  2438.  
  2439. end
  2440.  
  2441. for i,v in pairs(rf3) do
  2442.  
  2443. v.DesiredAngle = tab[11]
  2444.  
  2445. v.MaxVelocity = math.abs(v.DesiredAngle-v.CurrentAngle)/time
  2446.  
  2447. end
  2448.  
  2449. for i,v in pairs(lf3) do
  2450.  
  2451. v.DesiredAngle = tab[11]
  2452.  
  2453. v.MaxVelocity = math.abs(v.DesiredAngle-v.CurrentAngle)/time
  2454.  
  2455. end
  2456.  
  2457. end
  2458.  
  2459. setwings(outhigh,1)
  2460.  
  2461. flying = false
  2462.  
  2463. moving = false
  2464.  
  2465. for i,v in pairs(tor:GetChildren()) do
  2466.  
  2467. if v.ClassName:lower():match("body") then
  2468.  
  2469. v:Destroy()
  2470.  
  2471. end
  2472.  
  2473. end
  2474.  
  2475. local ctor = tor:Clone()
  2476.  
  2477. ctor:ClearAllChildren()
  2478.  
  2479. ctor.Name = "cTorso"
  2480.  
  2481. ctor.Transparency = 1
  2482.  
  2483. ctor.CanCollide = false
  2484.  
  2485. ctor.FormFactor = "Custom"
  2486.  
  2487. ctor.Size = Vector3.new(.2,.2,.2)
  2488.  
  2489. ctor.Parent = mod
  2490.  
  2491. weld(tor,ctor)
  2492.  
  2493. local bg = Instance.new("BodyGyro",ctor)
  2494.  
  2495. bg.maxTorque = Vector3.new()
  2496.  
  2497. bg.P = 15000
  2498.  
  2499. bg.D = 1000
  2500.  
  2501. local bv = Instance.new("BodyVelocity",ctor)
  2502.  
  2503. bv.maxForce = Vector3.new()
  2504.  
  2505. bv.P = 15000
  2506.  
  2507. vel = Vector3.new()
  2508.  
  2509. cf = CFrame.new()
  2510.  
  2511. flspd = 0
  2512.  
  2513.  
  2514. keysdown = {}
  2515.  
  2516. keypressed = {}
  2517.  
  2518. ktime = {}
  2519.  
  2520. descendtimer = 0
  2521.  
  2522. jumptime = tick()
  2523.  
  2524. hum.Jumping:connect(function()
  2525.  
  2526. jumptime = tick()
  2527.  
  2528. end)
  2529.  
  2530. cam = workspace.CurrentCamera
  2531.  
  2532. kd = plr:GetMouse().KeyDown:connect(oc(function(key)
  2533.  
  2534. keysdown[key] = true
  2535.  
  2536. keypressed[key] = true
  2537.  
  2538. if key == "q" then
  2539.  
  2540. descendtimer = tick()
  2541.  
  2542. elseif key == " " and not hum.Jump then
  2543.  
  2544. jumptime = tick()
  2545.  
  2546. elseif (key == "a" or key == "d") and ktime[key] and tick()-ktime[key] < .3 and math.abs(reqrotx) < .3 then
  2547.  
  2548. reqrotx = key == "a" and math.pi*2 or -math.pi*2
  2549.  
  2550. end
  2551.  
  2552. ktime[key] = tick()
  2553.  
  2554. end))
  2555.  
  2556. ku = plr:GetMouse().KeyUp:connect(function(key)
  2557.  
  2558. keysdown[key] = false
  2559.  
  2560. if key == " " then
  2561.  
  2562. descendtimer = tick()
  2563.  
  2564. end
  2565.  
  2566. end)
  2567.  
  2568. function mid(a,b,c)
  2569.  
  2570. return math.max(a,math.min(b,c or -a))
  2571.  
  2572. end
  2573.  
  2574. function bn(a)
  2575.  
  2576. return a and 1 or 0
  2577.  
  2578. end
  2579.  
  2580. function gm(tar)
  2581.  
  2582. local m = 0
  2583.  
  2584. for i,v in pairs(tar:GetChildren()) do
  2585.  
  2586. if v:IsA("BasePart") then
  2587.  
  2588. m = m + v:GetMass()
  2589.  
  2590. end
  2591.  
  2592. m = m + gm(v)
  2593.  
  2594. end
  2595.  
  2596. return m
  2597.  
  2598. end
  2599.  
  2600. reqrotx = 0
  2601.  
  2602. local grav = 196.2
  2603.  
  2604. local con
  2605.  
  2606. con = game:GetService("RunService").Stepped:connect(oc(function()
  2607.  
  2608. --[[if not mod:IsDescendantOf(workspace) then
  2609.  
  2610. pcall(function() kd:disconnect() end)
  2611.  
  2612. pcall(function() ku:disconnect() end)
  2613.  
  2614. bg:Destroy()
  2615.  
  2616. bv:Destroy()
  2617.  
  2618. con:disconnect()
  2619.  
  2620. script:Destroy()
  2621.  
  2622. return
  2623.  
  2624. end]]
  2625.  
  2626. local obvel = tor.CFrame:vectorToObjectSpace(tor.Velocity)
  2627.  
  2628. local sspd, uspd,fspd = obvel.X,obvel.Y,obvel.Z
  2629.  
  2630. if flying then
  2631.  
  2632. local lfldir = fldir
  2633.  
  2634. fldir = cam.CoordinateFrame:vectorToWorldSpace(Vector3.new(bn(keysdown.d)-bn(keysdown.a),0,bn(keysdown.s)-bn(keysdown.w))).unit
  2635.  
  2636. local lmoving = moving
  2637.  
  2638. moving = fldir.magnitude > .1
  2639.  
  2640. if lmoving and not moving then
  2641.  
  2642. idledir = lfldir*Vector3.new(1,0,1)
  2643.  
  2644. descendtimer = tick()
  2645.  
  2646. end
  2647.  
  2648. local dbomb = fldir.Y < -.6 or (moving and keysdown["1"])
  2649.  
  2650. if moving and keysdown["0"] and lmoving then
  2651.  
  2652. fldir = (Vector3.new(lfldir.X,math.min(fldir.Y,lfldir.Y+.01)-.1,lfldir.Z)+(fldir*Vector3.new(1,0,1))*.05).unit
  2653.  
  2654. end
  2655.  
  2656. local down = tor.CFrame:vectorToWorldSpace(Vector3.new(0,-1,0))
  2657.  
  2658. local descending = (not moving and keysdown["q"] and not keysdown[" "])
  2659.  
  2660. cf = ccomplerp(cf,CFrame.new(tor.Position,tor.Position+(not moving and idledir or fldir)),keysdown["0"] and .02 or .07)
  2661.  
  2662. local gdown = not dbomb and cf.lookVector.Y < -.2 and tor.Velocity.unit.Y < .05
  2663.  
  2664. hum.PlatformStand = true
  2665.  
  2666. bg.maxTorque = Vector3.new(1,1,1)*9e5
  2667.  
  2668. local rotvel = CFrame.new(Vector3.new(),tor.Velocity):toObjectSpace(CFrame.new(Vector3.new(),fldir)).lookVector
  2669.  
  2670. bg.cframe = cf * CFrame.Angles(not moving and -.1 or -math.pi/2+.2,moving and mid(-2.5,rotvel.X/1.5) + reqrotx or 0,0)
  2671.  
  2672. reqrotx = reqrotx - reqrotx/10
  2673.  
  2674. bv.maxForce = Vector3.new(1,1,1)*9e4*.5
  2675.  
  2676. local anioff =(bn(keysdown[" "])-bn(keysdown["q"]))/2
  2677.  
  2678. local ani = tickwave(1.5-anioff,1)
  2679.  
  2680. bv.velocity = bv.velocity:Lerp(Vector3.new(0,bn(not moving)*-ani*15+(descending and math.min(20,tick()-descendtimer)*-8 or bn(keysdown[" "])-bn(keysdown["q"]))*15,0)+vel,.6)
  2681.  
  2682. vel = moving and cf.lookVector*flspd or Vector3.new()
  2683.  
  2684. flspd = math.min(120,lerp(flspd,moving and (fldir.Y<0 and flspd+(-fldir.Y)*grav/60 or math.max(50,flspd-fldir.Y*grav/300)) or 60,.4))
  2685.  
  2686. setwings(moving and (gdown and outlow or dbomb and divebomb) or (descending and veryhigh or flap1),15)
  2687.  
  2688. for i=1,4 do
  2689.  
  2690. --CFrame.Angles(-.5+bn(i==3)*2.4+bn(i==4)*.5,.1+bn(i==2)*.5-bn(i==3)*1.1,bn(i==3)*.1)
  2691.  
  2692. rwing[i].C0 = clerp(rwing[i].C0,oc0[rwing[i]] * (gdown and CFrame.new() or dbomb and CFrame.Angles(-.5+bn(i==3)*.4+bn(i==4)*.5,.1+bn(i==2)*.5-bn(i==3)*1.1,bn(i==3)*.1) or descending and CFrame.Angles(.3,0,0) or CFrame.Angles((i*.1+1.5)*ani,ani*-.5,1*ani)),descending and .8 or .2)
  2693.  
  2694. lwing[i].C0 = clerp(lwing[i].C0,oc0[lwing[i]] * (gdown and CFrame.new() or dbomb and CFrame.Angles(-(-.5+bn(i==3)*.4+bn(i==4)*.5),-(.1+bn(i==2)*.5-bn(i==3)*1.1),bn(i==3)*.1) or descending and CFrame.Angles(-.3,0,0) or CFrame.Angles(-(i*.1+1.5)*ani,ani*.5,1*ani)),descending and .8 or .2)
  2695.  
  2696. end
  2697.  
  2698. local hit,ray = workspace:FindPartOnRayWithIgnoreList(Ray.new(tor.Position,Vector3.new(0,-3.5+math.min(0,bv.velocity.y)/30,0)),{char})
  2699.  
  2700. if hit and down.Y < -.85 and tick()-flystart > 1 then
  2701.  
  2702. flying = false
  2703.  
  2704. hum.PlatformStand = false
  2705.  
  2706. tor.Velocity = Vector3.new()
  2707.  
  2708. end
  2709.  
  2710. else
  2711.  
  2712. bg.maxTorque = Vector3.new()
  2713.  
  2714. bv.maxForce = Vector3.new()
  2715.  
  2716. local ani = tickwave(walking and .8 or 4.5,1)
  2717.  
  2718. setwings(idle,10)
  2719.  
  2720. local x,y,z = fspd/160,uspd/700,sspd/900
  2721.  
  2722. for i=1,4 do
  2723.  
  2724. rwing[i].C0 = clerp(rwing[i].C0,oc0[rwing[i]] * CFrame.Angles(ani*.1 + -mid(-.1,x),0 + -mid(-.1,y) + bn(i==2)*.6,ani*.02 + -mid(-.1,z)),.2)
  2725.  
  2726. lwing[i].C0 = clerp(lwing[i].C0,oc0[lwing[i]] * CFrame.Angles(ani*-.05 + mid(-.1,x),0 + mid(-.1,y) + -bn(i==2)*.6,ani*.02 + mid(-.1,z)),.2)
  2727.  
  2728. end
  2729.  
  2730. if keypressed[" "] and not flying and (tick()-jumptime > .05 and (tick()-jumptime < 3 or hum.Jump)) then
  2731.  
  2732. vel = Vector3.new(0,50,0)
  2733.  
  2734. bv.velocity = vel
  2735.  
  2736. idledir = cam.CoordinateFrame.lookVector*Vector3.new(1,0,1)
  2737.  
  2738. cf = tor.CFrame * CFrame.Angles(-.01,0,0)
  2739.  
  2740. tor.CFrame = cf
  2741.  
  2742. bg.cframe = cf
  2743.  
  2744. flystart = tick()
  2745.  
  2746. flying = true
  2747.  
  2748. end
  2749.  
  2750. end
  2751.  
  2752. keypressed = {}
  2753.  
  2754. end))
  2755.  
  2756.  
  2757.  
  2758. end fly()
  2759.  
  2760. --Bird Wings By TXrangers222
  2761.  
  2762. --//=================================\\
  2763. --\\=================================//
  2764.  
  2765.  
  2766.  
  2767.  
  2768.  
  2769. --//====================================================\\--
  2770. --|| END OF SCRIPT
  2771. --\\====================================================//--
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement