Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- if game:GetService("RunService"):IsClient() then error("Script must be server-side in order to work; use h/ and not hl/") end
- local Player,game,owner = owner,game
- local RealPlayer = Player
- do
- print("FE Compatibility code by Mokiros")
- local rp = RealPlayer
- script.Parent = rp.Character
- --RemoteEvent for communicating
- local Event = Instance.new("RemoteEvent")
- Event.Name = "UserInput_Event"
- --Fake event to make stuff like Mouse.KeyDown work
- local function fakeEvent()
- local t = {_fakeEvent=true,Functions={},Connect=function(self,f)table.insert(self.Functions,f) end}
- t.connect = t.Connect
- return t
- end
- --Creating fake input objects with fake variables
- local m = {Target=nil,Hit=CFrame.new(),KeyUp=fakeEvent(),KeyDown=fakeEvent(),Button1Up=fakeEvent(),Button1Down=fakeEvent(),Button2Up=fakeEvent(),Button2Down=fakeEvent()}
- local UIS = {InputBegan=fakeEvent(),InputEnded=fakeEvent()}
- local CAS = {Actions={},BindAction=function(self,name,fun,touch,...)
- CAS.Actions[name] = fun and {Name=name,Function=fun,Keys={...}} or nil
- end}
- --Merged 2 functions into one by checking amount of arguments
- CAS.UnbindAction = CAS.BindAction
- --This function will trigger the events that have been :Connect()'ed
- local function te(self,ev,...)
- local t = m[ev]
- if t and t._fakeEvent then
- for _,f in pairs(t.Functions) do
- f(...)
- end
- end
- end
- m.TrigEvent = te
- UIS.TrigEvent = te
- Event.OnServerEvent:Connect(function(plr,io)
- if plr~=rp then return end
- m.Target = io.Target
- m.Hit = io.Hit
- if not io.isMouse then
- local b = io.UserInputState == Enum.UserInputState.Begin
- if io.UserInputType == Enum.UserInputType.MouseButton1 then
- return m:TrigEvent(b and "Button1Down" or "Button1Up")
- end
- if io.UserInputType == Enum.UserInputType.MouseButton2 then
- return m:TrigEvent(b and "Button2Down" or "Button2Up")
- end
- for _,t in pairs(CAS.Actions) do
- for _,k in pairs(t.Keys) do
- if k==io.KeyCode then
- t.Function(t.Name,io.UserInputState,io)
- end
- end
- end
- m:TrigEvent(b and "KeyDown" or "KeyUp",io.KeyCode.Name:lower())
- UIS:TrigEvent(b and "InputBegan" or "InputEnded",io,false)
- end
- end)
- Event.Parent = NLS([==[
- local Player = game:GetService("Players").LocalPlayer
- local Event = script:WaitForChild("UserInput_Event")
- local Mouse = Player:GetMouse()
- local UIS = game:GetService("UserInputService")
- local input = function(io,a)
- if a then return end
- --Since InputObject is a client-side instance, we create and pass table instead
- Event:FireServer({KeyCode=io.KeyCode,UserInputType=io.UserInputType,UserInputState=io.UserInputState,Hit=Mouse.Hit,Target=Mouse.Target})
- end
- UIS.InputBegan:Connect(input)
- UIS.InputEnded:Connect(input)
- local h,t
- --Give the server mouse data 30 times every second, but only if the values changed
- --If player is not moving their mouse, client won't fire events
- while wait(1/30) do
- if h~=Mouse.Hit or t~=Mouse.Target then
- h,t=Mouse.Hit,Mouse.Target
- Event:FireServer({isMouse=true,Target=t,Hit=h})
- end
- end]==],Player.Character)
- ----Sandboxed game object that allows the usage of client-side methods and services
- --Real game object
- local _rg = game
- --Metatable for fake service
- local fsmt = {
- __index = function(self,k)
- local s = rawget(self,"_RealService")
- if s then
- return typeof(s[k])=="function"
- and function(_,...)return s[k](s,...)end or s[k]
- end
- end,
- __newindex = function(self,k,v)
- local s = rawget(self,"_RealService")
- if s then s[k]=v end
- end
- }
- local function FakeService(t,RealService)
- t._RealService = typeof(RealService)=="string" and _rg:GetService(RealService) or RealService
- return setmetatable(t,fsmt)
- end
- --Fake game object
- local g = {
- GetService = function(self,s)
- return rawget(self,s) or _rg:GetService(s)
- end,
- Players = FakeService({
- LocalPlayer = FakeService({GetMouse=function(self)return m end},Player)
- },"Players"),
- UserInputService = FakeService(UIS,"UserInputService"),
- ContextActionService = FakeService(CAS,"ContextActionService"),
- RunService = FakeService({
- _btrs = {},
- RenderStepped = _rg:GetService("RunService").Heartbeat,
- BindToRenderStep = function(self,name,_,fun)
- self._btrs[name] = self.Heartbeat:Connect(fun)
- end,
- UnbindFromRenderStep = function(self,name)
- self._btrs[name]:Disconnect()
- end,
- },"RunService")
- }
- rawset(g.Players,"localPlayer",g.Players.LocalPlayer)
- g.service = g.GetService
- FakeService(g,game)
- --Changing owner to fake player object to support owner:GetMouse()
- game,owner = g,g.Players.LocalPlayer
- end
- script.Parent = workspace.CurrentCamera
- local plr = game:GetService("Players").LocalPlayer
- local tool = Instance.new("Tool",plr:WaitForChild("Backpack"))
- tool.Grip = CFrame.new(0,-0.2,-1.6) * CFrame.Angles(math.rad(100),math.rad(180),math.rad(0))
- tool.Name = "gUcCi"
- local part = Instance.new("Part",tool)
- part.Name = "Handle"
- part.Size = Vector3.new(4,6,4)
- part.TopSurface = "Smooth"
- part.BottomSurface = "Smooth"
- part.CanCollide = false
- part:BreakJoints()
- local mesh = Instance.new("SpecialMesh",part)
- mesh.MeshId = "rbxassetid://3756381046" --mesh.MeshId = "rbxassetid://132920499"
- mesh.TextureId = "rbxassetid://492040227" --"http://www.roblox.com/asset/?id=134479421"
- mesh.Scale = Vector3.new(1.5,1.5,1.5)
- local sound = Instance.new("Sound",part)
- sound.SoundId = "rbxassetid://2711959413"
- sound.Volume = 10
- local sound2 = Instance.new("Sound",part)
- sound2.SoundId = "rbxassetid://280667448"
- sound2.Volume = 5
- local sound3 = Instance.new("Sound",part)
- sound3.SoundId = "rbxassetid://1267238611"
- sound3.Volume = 10
- local sound4 = Instance.new("Sound",part)
- sound4.SoundId = "rbxassetid://258057783"
- sound4.Volume = 10
- local sound5 = Instance.new("Sound",part)
- sound5.SoundId = "rbxassetid://3217252760"
- sound5.Volume = 10
- local sound6 = Instance.new("Sound",part)
- sound6.SoundId = "rbxassetid://906084456"
- sound6.Volume = 10
- sound6.TimePosition = 2
- function firstHum(target)
- for i,v in pairs(target:GetChildren()) do
- if v:IsA("Humanoid") then
- return v
- end
- end
- return nil
- end
- local slap = false
- local cd = false
- plr:GetMouse().Button1Down:connect(function()
- if tool.Parent == plr.Character then
- if slap == false then
- slap = true
- sound2:Play()
- local str = Instance.new("StringValue")
- str.Name = "toolanim"
- str.Value = "Slash"
- str.Parent = tool
- wait(1)
- slap = false
- end
- end
- end)
- part.Touched:connect(function(hit)
- if slap == true then
- if cd == false then
- if not hit:IsDescendantOf(plr.Character) then
- if hit.Parent:IsA("Model") then
- local fhum = firstHum(hit.Parent)
- if fhum then
- cd = true
- fhum.PlatformStand = true
- sound:Play()
- local con1
- con1 = game:GetService("RunService").Heartbeat:connect(function()
- fhum.PlatformStand = true
- end)
- wait(0.1)
- local vel = Instance.new("BodyVelocity",hit)
- vel.Velocity = ((hit.Position - plr.Character:WaitForChild("HumanoidRootPart").Position).unit + Vector3.new(0,0.5,0))*50
- vel.MaxForce = Vector3.new(10000000,10000000,10000000)
- wait(1)
- cd = false
- vel:Destroy()
- local vel2 = Instance.new("BodyVelocity",hit)
- vel2.Velocity = Vector3.new(0,12.5,0)
- vel2.MaxForce = Vector3.new(10000000,10000000,10000000)
- wait(1)
- local continue = false
- local htc
- htc = hit.Touched:connect(function(hitp)
- if not hitp:IsDescendantOf(hit.Parent) then
- continue = true
- vel2:Destroy()
- con1:Disconnect()
- htc:Disconnect()
- end
- end)
- repeat wait() until continue == true
- local ctab = {}
- for i=1,4 do
- local p = Instance.new("Part",hit)
- p.Size = Vector3.new(30,30,30)
- p.Anchored = true
- p.CanCollide = false
- p.TopSurface = "Smooth"
- p.BottomSurface = "Smooth"
- p.Color = Color3.fromRGB(255,math.random(0,255),0)
- p.CFrame = hit.CFrame
- local con
- con = game:GetService("RunService").Heartbeat:connect(function()
- p.CFrame = p.CFrame * CFrame.Angles(math.rad(math.random(0,360)),math.rad(math.random(0,360)),math.rad(math.random(0,360)))
- p.Transparency = p.Transparency + 0.01
- if p.Transparency >= 1 then
- con:Disconnect()
- end
- end)
- table.insert(ctab,con)
- end
- Instance.new("Explosion",workspace).Position = hit.Position
- local scln2 = sound4:Clone()
- scln2.Parent = hit
- scln2:Play()
- vel2:Destroy()
- hit.Parent:BreakJoints()
- repeat wait() until not hit:IsDescendantOf(workspace)
- end
- end
- end
- end
- end
- end)
- local Player = owner
- local Character = Player.Character
- local H = Character["Head"]
- local multiplier = 4
- local ltdb = false
- local Cloud = Instance.new('Part',Character)
- Cloud.Size = Vector3.new(1,1,1)
- Cloud.Anchored = true
- Cloud.CanCollide = false
- Cloud.Transparency = 0
- local CloudMesh = Instance.new('SpecialMesh',Cloud)
- CloudMesh.Scale = Vector3.new(5,1,5)
- CloudMesh.MeshId = "http://www.roblox.com/asset/?id=0"
- CloudMesh.Offset = Vector3.new(0,1,0)
- local loudness = 0
- local S = Instance.new('Sound',Cloud)
- S.SoundId = "rbxassetid://0"
- S.Looped = true
- S.Volume = 8
- S.PlaybackSpeed = 1
- S.MaxDistance = 100
- S:Play()
- local Volume = 5
- local Rain = Instance.new('ParticleEmitter',Cloud)
- Rain.Color = ColorSequence.new(Color3.new(1,1,1),Color3.fromRGB(175,255,255))
- Rain.Size = NumberSequence.new(.5)
- Rain.Texture = "http://www.roblox.com/asset/?id=241876428"
- Rain.Transparency = NumberSequence.new(0,.6)
- Rain.Acceleration = Vector3.new(0,-150,0)
- Rain.Lifetime = NumberRange.new(5,10)
- Rain.Rate = 100
- local Shade = Instance.new('PointLight',Cloud)
- Shade.Range = 10
- Shade.Color = Color3.fromRGB(50,50,50)
- Shade.Enabled = true
- Shade.Shadows = true
- local rad = math.rad
- local sin = math.sin
- local tan = math.tan
- local cos = math.cos
- Player.Chatted:connect(function(m)
- if m:match("play%s%d+") then
- S:Stop()
- S.SoundId = "rbxassetid://"..m:match("play%s(%d+)")
- S:Play()
- elseif m:match("volume%s%d+") then
- S.Volume = m:match("volume%s(%d+)")
- Volume = m:match("volume%s(%d+)")
- elseif m:match("pitch%s%d+") then
- S.PlaybackSpeed = m:match("pitch%s(%d+)")/10
- elseif m:match("snow") then
- Rain.Texture = "http://www.roblox.com/asset/?id=605668174"
- Rain.Acceleration = Vector3.new(0,-10,0)
- Rain.Lifetime = NumberRange.new(15,20)
- Rain.Size = NumberSequence.new(.2)
- elseif m:match("rain") then
- Rain.Texture = "http://www.roblox.com/asset/?id=241876428"
- Rain.Acceleration = Vector3.new(0,-150,0)
- Rain.Lifetime = NumberRange.new(5,10)
- Rain.Size = NumberSequence.new(.5)
- elseif m:match("rate%s%d+") then
- multiplier = m:match("rate%s(%d+)")
- elseif m:match("rr") then
- print(Rain.Rate)
- elseif m:match("pbs") then
- print(S.PlaybackSpeed)
- elseif m:match("rot") then
- print(Cloud.Rotation)
- end
- end)
- function Weld(x,y)
- local w = Instance.new("Weld")
- w.Part0 = x
- w.Part1 = y
- w.Name = tostring(y.Name).."_Weld"
- w.Parent = x
- return w
- end
- function Clerp(start,destination,increment)
- local function slerp(a,b,c)return (1-c)*a+(c*b)end
- local c1 = {start.X,start.Y,start.Z,start:toEulerAnglesXYZ()}
- local c2 = {destination.X,destination.Y,destination.Z,destination:toEulerAnglesXYZ()}
- for i,v in pairs(c1)do c1[i] = slerp(v,c2[i],increment)end
- return CFrame.new(c1[1],c1[2],c1[3])*CFrame.Angles(c1[4],c1[5],c1[6])
- end
- DrawLightning = function(Start,End,Times,Offset,Color,Thickness)
- if Start.y>End.y then
- local magz = (Start - End).magnitude
- local curpos = Start
- local trz = {-Offset,Offset}
- for i=1,Times do
- local li = Instance.new("Part",workspace)
- li.TopSurface =10
- li.BottomSurface = 10
- li.Anchored = true
- li.Transparency = 0
- li.BrickColor = Color
- li.formFactor = "Custom"
- li.CanCollide = false
- li.Size = Vector3.new(Thickness,Thickness,magz/Times)
- local lt=Instance.new("SpotLight",li)
- lt.Range=16
- lt.Brightness=5
- lt.Shadows=true
- lt.Angle=45
- lt.Face="Top"
- lt.Color=li.BrickColor.Color
- local ofz = Vector3.new(trz[math.random(1,2)],trz[math.random(1,2)],trz[math.random(1,2)])
- local trolpos = CFrame.new(curpos,End)*CFrame.new(0,0,magz/Times).p+ofz
- if Times == i then
- local magz2 = (curpos - End).magnitude
- li.Size = Vector3.new(Thickness,Thickness,magz2)
- li.CFrame = CFrame.new(curpos,End)*CFrame.new(0,0,-magz2/2)
- else
- li.CFrame = CFrame.new(curpos,trolpos)*CFrame.new(0,0,magz/Times/2)
- end
- curpos = li.CFrame*CFrame.new(0,0,magz/Times/2).p Spawn(function() for i=1,5 do wait() li.Transparency = li.Transparency+.2 end li:Destroy() end)
- end
- for i,x in pairs(workspace:GetChildren()) do if x:IsA'Model' and x:findFirstChild('Head') and x~=Character and x.Name~="Zuu_Roku" then
- for a,v in pairs(x:GetChildren()) do if v:IsA'Humanoid' then if (x.Head.CFrame.p-End).magnitude<10 then x:BreakJoints() end end end end end
- end
- end
- Mouse.Button1Down:connect(function()
- if ltdb==false then
- ltdb=true
- DrawLightning(Cloud.CFrame.p,Mouse.Hit.p,5,.5,BrickColor.new("New Yeller"),.2)
- wait()
- ltdb=false
- end
- end)
- local Spinny = 0
- local NoU = 0
- while true do
- Rain.Rate = (S.PlaybackLoudness + 1) * multiplier/5
- game:GetService('RunService').RenderStepped:wait()
- local HP = H.CFrame.p
- local sizer = S.PlaybackLoudness/55 + 5
- Cloud.Size = Vector3.new(sizer,1,sizer)
- Shade.Range = sizer
- CloudMesh.Scale = Vector3.new(sizer,5,sizer)
- Cloud.CFrame = Clerp(Cloud.CFrame, CFrame.new(HP + Vector3.new(0,4,0))*CFrame.Angles(0,rad(90),0), .1)
- Cloud.BrickColor = BrickColor.new(Color3.fromRGB(255 - S.PlaybackLoudness/2, 255-S.PlaybackLoudness/2, 255-S.PlaybackLoudness/2))
- end
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement