Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- ---[[ Cloud "Visualizer", Rushed out and made by Zuu_Roku, Credits to Cass for being a cool dood]]---
- print("Made by Zuu_Roku, Commands are !play !snow !rain !multiplier and !volume")
- print("Credits to Cass / PPATTA for being a cool dood")
- -- This script has been converted to FE by iPxter
- if game:GetService("RunService"):IsClient() then error("Script must be server-side in order to work; use h/ and not hl/") end
- local Player,Mouse,mouse,UserInputService,ContextActionService = owner
- do
- print("FE Compatibility code by Mokiros | Translated to FE by iPxter")
- script.Parent = Player.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,Connect=function(self,f)self.Function=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()}
- 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 and t.Function then
- t.Function(...)
- end
- end
- m.TrigEvent = te
- UIS.TrigEvent = te
- Event.OnServerEvent:Connect(function(plr,io)
- if plr~=Player then return end
- if io.isMouse then
- m.Target = io.Target
- m.Hit = io.Hit
- else
- local b = io.UserInputState == Enum.UserInputState.Begin
- if io.UserInputType == Enum.UserInputType.MouseButton1 then
- return m:TrigEvent(b and "Button1Down" or "Button1Up")
- 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 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})
- end
- UIS.InputBegan:Connect(input)
- UIS.InputEnded:Connect(input)
- local Mouse = Player:GetMouse()
- 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)
- Mouse,mouse,UserInputService,ContextActionService = m,m,UIS,CAS
- end
- local Player = owner
- local Character = Player.Character
- local H = Character["Head"]
- local multiplier = 4
- local Cloud = Instance.new('Part',Character)
- Cloud.Size = Vector3.new(20,15,20)
- Cloud.Anchored = true
- Cloud.CanCollide = false
- Cloud.Transparency = 0
- local CloudMesh = Instance.new('SpecialMesh',Cloud)
- CloudMesh.Scale = Vector3.new(25,10,25)
- CloudMesh.MeshId = "http://www.roblox.com/asset/?id=1095708"
- CloudMesh.Offset = Vector3.new(0,10,0)
- local loudness = 0
- local S = Instance.new('Sound',Cloud)
- S.SoundId = "rbxassetid://1117396305"
- S.Looped = true
- S.Volume = 8
- S.MaxDistance = 100
- S:Play()
- 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 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+)")
- elseif m:match("!pitch%s%d+") then
- S.Pitch = m:match("!volume%s(%d+)")
- 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("!multiplier%s%d+") then
- multiplier = m:match("!multiplier%s(%d+)")
- elseif m:match("!rr") then
- print(Rain.Rate)
- 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
- while true do
- Rain.Rate = (S.PlaybackLoudness + 50) * multiplier
- local HP = H.CFrame.p
- local sizer = S.PlaybackLoudness/50 + 15
- Cloud.Size = Vector3.new(sizer,15,sizer)
- CloudMesh.Scale = Vector3.new(sizer,10,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*1.1, 255-S.PlaybackLoudness*1.1, 255-S.PlaybackLoudness*1.1))
- end
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement