Added Files
Totally not ready
This commit is contained in:
parent
17fec9c440
commit
204966f929
BIN
Audio/Collapse.ogg
Normal file
BIN
Audio/Collapse.ogg
Normal file
Binary file not shown.
BIN
Audio/Creaky.ogg
Normal file
BIN
Audio/Creaky.ogg
Normal file
Binary file not shown.
BIN
Audio/Deadly Sorrow.ogg
Normal file
BIN
Audio/Deadly Sorrow.ogg
Normal file
Binary file not shown.
BIN
Audio/Don't Die on Me.ogg
Normal file
BIN
Audio/Don't Die on Me.ogg
Normal file
Binary file not shown.
BIN
Audio/Laugh.ogg
Normal file
BIN
Audio/Laugh.ogg
Normal file
Binary file not shown.
BIN
Audio/Lost World - myuu.ogg
Normal file
BIN
Audio/Lost World - myuu.ogg
Normal file
Binary file not shown.
BIN
Audio/The End Is Always Near.ogg
Normal file
BIN
Audio/The End Is Always Near.ogg
Normal file
Binary file not shown.
BIN
Audio/What Could Have Been.ogg
Normal file
BIN
Audio/What Could Have Been.ogg
Normal file
Binary file not shown.
BIN
Audio/Yawn.ogg
Normal file
BIN
Audio/Yawn.ogg
Normal file
Binary file not shown.
BIN
Audio/alarm.ogg
Normal file
BIN
Audio/alarm.ogg
Normal file
Binary file not shown.
BIN
Audio/bed.ogg
Normal file
BIN
Audio/bed.ogg
Normal file
Binary file not shown.
BIN
Audio/boyknife.ogg
Normal file
BIN
Audio/boyknife.ogg
Normal file
Binary file not shown.
BIN
Audio/footsteps.ogg
Normal file
BIN
Audio/footsteps.ogg
Normal file
Binary file not shown.
BIN
Audio/hmm.ogg
Normal file
BIN
Audio/hmm.ogg
Normal file
Binary file not shown.
BIN
Audio/knife.ogg
Normal file
BIN
Audio/knife.ogg
Normal file
Binary file not shown.
BIN
Audio/over.ogg
Normal file
BIN
Audio/over.ogg
Normal file
Binary file not shown.
BIN
Audio/paper.ogg
Normal file
BIN
Audio/paper.ogg
Normal file
Binary file not shown.
BIN
Audio/pots.ogg
Normal file
BIN
Audio/pots.ogg
Normal file
Binary file not shown.
BIN
Audio/select.ogg
Normal file
BIN
Audio/select.ogg
Normal file
Binary file not shown.
BIN
Audio/sigh.ogg
Normal file
BIN
Audio/sigh.ogg
Normal file
Binary file not shown.
BIN
Audio/stairs.ogg
Normal file
BIN
Audio/stairs.ogg
Normal file
Binary file not shown.
BIN
Audio/store.ogg
Normal file
BIN
Audio/store.ogg
Normal file
Binary file not shown.
BIN
Audio/twisted.ogg
Normal file
BIN
Audio/twisted.ogg
Normal file
Binary file not shown.
15
GuiManager/Core/Clickable.int
Normal file
15
GuiManager/Core/Clickable.int
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
function gui:Clickable()
|
||||||
|
local x,y,w,h=love.graphics.getScissor()
|
||||||
|
local mx=love.mouse.getX()
|
||||||
|
local my=love.mouse.getY()
|
||||||
|
if _GuiPro.HasStencel then
|
||||||
|
local obj=_GuiPro.StencelHolder
|
||||||
|
if self:isDescendant(obj) then
|
||||||
|
return math.sqrt((mx-obj.x)^2+(my-obj.y)^2)<=(obj.offset.size.x or 0)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if not(x) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
return not(mx>x+w or mx<x or my>y+h or my<y)
|
||||||
|
end
|
||||||
1667
GuiManager/Core/Colors.int
Normal file
1667
GuiManager/Core/Colors.int
Normal file
File diff suppressed because it is too large
Load Diff
5
GuiManager/Core/DrawThings.int
Normal file
5
GuiManager/Core/DrawThings.int
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
function DrawThings(items)
|
||||||
|
for i=1,#items do
|
||||||
|
items[i]:draw()
|
||||||
|
end
|
||||||
|
end
|
||||||
85
GuiManager/Core/EventDefinitions.int
Normal file
85
GuiManager/Core/EventDefinitions.int
Normal file
@ -0,0 +1,85 @@
|
|||||||
|
function gui:OnClicked(func)
|
||||||
|
table.insert(self.funcs,func)
|
||||||
|
end
|
||||||
|
function gui:OnReleased(func)
|
||||||
|
table.insert(self.funcs2,func)
|
||||||
|
end
|
||||||
|
function gui:OnEnter(func)
|
||||||
|
table.insert(self.funcs3,func)
|
||||||
|
end
|
||||||
|
function gui:OnExit(func)
|
||||||
|
table.insert(self.funcs4,func)
|
||||||
|
end
|
||||||
|
function gui:OnUpdate(func)
|
||||||
|
table.insert(self.funcs5,func)
|
||||||
|
end
|
||||||
|
function gui:OnDragStart(func)
|
||||||
|
table.insert(self.func8,func)
|
||||||
|
end
|
||||||
|
function gui:OnDragging(func)
|
||||||
|
table.insert(self.func6,func)
|
||||||
|
end
|
||||||
|
function gui:OnDragEnd(func)
|
||||||
|
table.insert(self.func7,func)
|
||||||
|
end
|
||||||
|
function gui:WhileHovering(func)
|
||||||
|
table.insert(self.func9,func)
|
||||||
|
end
|
||||||
|
function gui:OnMouseMoved(func)
|
||||||
|
table.insert(self.func10,func)
|
||||||
|
end
|
||||||
|
function gui:getChildren()
|
||||||
|
return self.Children
|
||||||
|
end
|
||||||
|
function gui:LClicked()
|
||||||
|
return self.lclicked
|
||||||
|
end
|
||||||
|
function gui:RClicked()
|
||||||
|
return self.rclicked
|
||||||
|
end
|
||||||
|
function gui:MClicked()
|
||||||
|
return self.mclicked
|
||||||
|
end
|
||||||
|
function gui:Clicked()
|
||||||
|
return (self.lclicked or self.rclicked)
|
||||||
|
end
|
||||||
|
function gui:Hovering()
|
||||||
|
return self.hovering
|
||||||
|
end
|
||||||
|
function gui:FreeConnections()
|
||||||
|
self.funcs={function(b,self) if b=="l" then self.LRE=true end end,function(b,self) if b=="r" then self.RRE=true end end,function(b,self) if b=="m" then self.MRE=true end end}
|
||||||
|
self.funcs2={function(b,self) if b=="l" then self.LRE=false end end,function(b,self) if b=="r" then self.RRE=false end end,function(b,self) if b=="m" then self.MRE=false end end}
|
||||||
|
self.funcs3={function(self) self.HE=true end}
|
||||||
|
self.funcs4={function(self) self.HE=false end}
|
||||||
|
self.funcs5={function(self) self.x=(self.Parent.width*self.scale.pos.x)+self.offset.pos.x+self.Parent.x self.y=(self.Parent.height*self.scale.pos.y)+self.offset.pos.y+self.Parent.y self.width=(self.Parent.width*self.scale.size.x)+self.offset.size.x self.height=(self.Parent.height*self.scale.size.y)+self.offset.size.y end}
|
||||||
|
end
|
||||||
|
function gui:LClick()
|
||||||
|
for i=1,#self.funcs do
|
||||||
|
self.funcs[i]("l",self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function gui:RClick()
|
||||||
|
for i=1,#self.funcs do
|
||||||
|
self.funcs[i]("r",self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function gui:MClick()
|
||||||
|
for i=1,#self.funcs do
|
||||||
|
self.funcs[i]("m",self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function gui:LRelease()
|
||||||
|
for i=1,#self.funcs2 do
|
||||||
|
self.funcs2[i]("l",self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function gui:RRelease()
|
||||||
|
for i=1,#self.funcs2 do
|
||||||
|
self.funcs2[i]("r",self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function gui:MRelease()
|
||||||
|
for i=1,#self.funcs2 do
|
||||||
|
self.funcs2[i]("m",self)
|
||||||
|
end
|
||||||
|
end
|
||||||
46
GuiManager/Core/UpdateThings.int
Normal file
46
GuiManager/Core/UpdateThings.int
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
function UpdateThings(items)
|
||||||
|
for i=#items,1,-1 do
|
||||||
|
if items[i]:LClicked() then
|
||||||
|
for g=1,#items[i].funcs do
|
||||||
|
items[i].funcs[g]("l",items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
elseif items[i]:RClicked() then
|
||||||
|
for g=1,#items[i].funcs do
|
||||||
|
items[i].funcs[g]("r",items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
elseif items[i]:MClicked() then
|
||||||
|
for g=1,#items[i].funcs do
|
||||||
|
items[i].funcs[g]("m",items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if not(items[i]:LClicked()) and items[i].LRE then
|
||||||
|
for g=1,#items[i].funcs2 do
|
||||||
|
items[i].funcs2[g]("l",items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
elseif not(items[i]:RClicked()) and items[i].RRE then
|
||||||
|
for g=1,#items[i].funcs2 do
|
||||||
|
items[i].funcs2[g]("r",items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
elseif not(items[i]:MClicked()) and items[i].MRE then
|
||||||
|
for g=1,#items[i].funcs2 do
|
||||||
|
items[i].funcs2[g]("m",items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if items[i]:Hovering() and items[i].HE==false then
|
||||||
|
for g=1,#items[i].funcs3 do
|
||||||
|
items[i].funcs3[g](items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
elseif not(items[i]:Hovering()) and items[i].HE==true then
|
||||||
|
for g=1,#items[i].funcs4 do
|
||||||
|
items[i].funcs4[g](items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
elseif items[i]:Hovering() then
|
||||||
|
for g=1,#items[i].func9 do
|
||||||
|
items[i].func9[g](items[i],love.mouse.getX()-items[i].x,love.mouse.getY()-items[i].y)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
for g=1,#items[i].funcs5 do
|
||||||
|
items[i].funcs5[g](items[i])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
25
GuiManager/Core/_GetAllChildren.int
Normal file
25
GuiManager/Core/_GetAllChildren.int
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
function GetAllChildren(Object)
|
||||||
|
local Stuff = {}
|
||||||
|
function Seek(Items)
|
||||||
|
for i=1,#Items do
|
||||||
|
if Items[i].Visible==true then
|
||||||
|
table.insert(Stuff,Items[i])
|
||||||
|
local NItems = Items[i]:getChildren()
|
||||||
|
if NItems ~= nil then
|
||||||
|
Seek(NItems)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local Objs = Object:getChildren()
|
||||||
|
for i=1,#Objs do
|
||||||
|
if Objs[i].Visible==true then
|
||||||
|
table.insert(Stuff,Objs[i])
|
||||||
|
local Items = Objs[i]:getChildren()
|
||||||
|
if Items ~= nil then
|
||||||
|
Seek(Items)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return Stuff
|
||||||
|
end
|
||||||
21
GuiManager/Core/_GetAllChildren2.int
Normal file
21
GuiManager/Core/_GetAllChildren2.int
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
function GetAllChildren2(Object)
|
||||||
|
local Stuff = {}
|
||||||
|
function Seek(Items)
|
||||||
|
for i=1,#Items do
|
||||||
|
table.insert(Stuff,Items[i])
|
||||||
|
local NItems = Items[i]:getChildren()
|
||||||
|
if NItems ~= nil then
|
||||||
|
Seek(NItems)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local Objs = Object:getChildren()
|
||||||
|
for i=1,#Objs do
|
||||||
|
table.insert(Stuff,Objs[i])
|
||||||
|
local Items = Objs[i]:getChildren()
|
||||||
|
if Items ~= nil then
|
||||||
|
Seek(Items)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return Stuff
|
||||||
|
end
|
||||||
14
GuiManager/Core/eventable.int
Normal file
14
GuiManager/Core/eventable.int
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
function gui:eventable()
|
||||||
|
if self.important then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
if _GuiPro.Hierarchy then
|
||||||
|
if _GuiPro.TopHovered~=nil then
|
||||||
|
return self:isDescendant(_GuiPro.TopHovered) or _GuiPro.TopHovered==self
|
||||||
|
else
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
else
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
3
GuiManager/Core/full.int
Normal file
3
GuiManager/Core/full.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:full()
|
||||||
|
self:SetDualDim(nil,nil,nil,nil,nil,nil,1,1)
|
||||||
|
end
|
||||||
237
GuiManager/Core/newBase.int
Normal file
237
GuiManager/Core/newBase.int
Normal file
@ -0,0 +1,237 @@
|
|||||||
|
function gui.enableAutoWindowScaling(b)
|
||||||
|
_GuiPro.DPI_ENABLED=b or true
|
||||||
|
_defaultfont=love.graphics.newFont(12*love.window.getPixelScale())
|
||||||
|
end
|
||||||
|
function filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
if type(name)~="string" then
|
||||||
|
sh=sw
|
||||||
|
sw=sy
|
||||||
|
sy=sx
|
||||||
|
sx=h
|
||||||
|
h=w
|
||||||
|
w=y
|
||||||
|
y=x
|
||||||
|
x=name
|
||||||
|
end
|
||||||
|
return x,y,w,h,sx,sy,sw,sh
|
||||||
|
end
|
||||||
|
function gui:newBase(tp,name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
_GuiPro.count=_GuiPro.count+1
|
||||||
|
local c = {}
|
||||||
|
setmetatable(c, gui)
|
||||||
|
if self==gui then
|
||||||
|
c.Parent=_GuiPro
|
||||||
|
else
|
||||||
|
c.Parent=self
|
||||||
|
end
|
||||||
|
c.segments=nil
|
||||||
|
c.ry=nil
|
||||||
|
c.rx=nil
|
||||||
|
c.DPI=1
|
||||||
|
if _GuiPro.DPI_ENABLED then
|
||||||
|
c.DPI=love.window.getPixelScale()
|
||||||
|
x, y, w, h=c.DPI*x,c.DPI*y,c.DPI*w,c.DPI*h
|
||||||
|
end
|
||||||
|
c.centerFontY=true
|
||||||
|
c.FormFactor="rectangle"
|
||||||
|
c.Type=tp
|
||||||
|
c.Active=true
|
||||||
|
c.form="rectangle"
|
||||||
|
c.Draggable=false
|
||||||
|
c.Name=name or "Gui"..tp
|
||||||
|
c:SetName(name)
|
||||||
|
c.BorderSize=1
|
||||||
|
c.BorderColor={0,0,0}
|
||||||
|
c.VIS=true
|
||||||
|
c.Visible=true
|
||||||
|
c.oV=true
|
||||||
|
c.Children={}
|
||||||
|
c.hovering=false
|
||||||
|
c.rclicked=false
|
||||||
|
c.lclicked=false
|
||||||
|
c.mclicked=false
|
||||||
|
c.clicked=false
|
||||||
|
c.Visibility=1
|
||||||
|
c.ClipDescendants=false
|
||||||
|
c.TextWrap=true
|
||||||
|
c.scale={}
|
||||||
|
c.scale.size={}
|
||||||
|
c.scale.size.x=sw or 0
|
||||||
|
c.scale.size.y=sh or 0
|
||||||
|
c.offset={}
|
||||||
|
c.offset.size={}
|
||||||
|
c.offset.size.x=w or 0
|
||||||
|
c.offset.size.y=h or 0
|
||||||
|
c.scale.pos={}
|
||||||
|
c.scale.pos.x=sx or 0
|
||||||
|
c.scale.pos.y=sy or 0
|
||||||
|
c.offset.pos={}
|
||||||
|
c.offset.pos.x=x or 0
|
||||||
|
c.offset.pos.y=y or 0
|
||||||
|
c.width = 0
|
||||||
|
c.height = 0
|
||||||
|
c.LRE=false
|
||||||
|
c.RRE=false
|
||||||
|
c.MRE=false
|
||||||
|
c.Color = {255, 255, 255}
|
||||||
|
function c:setRoundness(rx,ry,segments)
|
||||||
|
self.segments=segments
|
||||||
|
self.ry=ry
|
||||||
|
self.rx=rx
|
||||||
|
end
|
||||||
|
function c.stfunc()
|
||||||
|
love.graphics.rectangle("fill", c.x, c.y, c.width, c.height,c.rx,c.ry,c.segments)
|
||||||
|
end
|
||||||
|
function c:hasRoundness()
|
||||||
|
return (self.ry or self.rx)
|
||||||
|
end
|
||||||
|
c.funcs={function(b,self)
|
||||||
|
if b=="l" then
|
||||||
|
self.LRE=true
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
function(b,self)
|
||||||
|
if b=="r" then
|
||||||
|
self.RRE=true
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
function(b,self)
|
||||||
|
if b=="m" then
|
||||||
|
self.MRE=true
|
||||||
|
end
|
||||||
|
end}
|
||||||
|
c.funcs2={function(b,self)
|
||||||
|
if b=="l" then
|
||||||
|
self.LRE=false
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
function(b,self)
|
||||||
|
if b=="r" then
|
||||||
|
self.RRE=false
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
function(b,self)
|
||||||
|
if b=="m" then
|
||||||
|
self.MRE=false
|
||||||
|
end
|
||||||
|
end}
|
||||||
|
c.HE=false
|
||||||
|
c.funcs3={function(self)
|
||||||
|
self.HE=true
|
||||||
|
end}
|
||||||
|
c.funcs4={function(self)
|
||||||
|
self.HE=false
|
||||||
|
end}
|
||||||
|
c.funcs5={}
|
||||||
|
c.tid={}
|
||||||
|
c.touchcount=0
|
||||||
|
c.x=(c.Parent.width*c.scale.pos.x)+c.offset.pos.x+c.Parent.x
|
||||||
|
c.y=(c.Parent.height*c.scale.pos.y)+c.offset.pos.y+c.Parent.y
|
||||||
|
c.width=(c.Parent.width*c.scale.size.x)+c.offset.size.x
|
||||||
|
c.height=(c.Parent.height*c.scale.size.y)+c.offset.size.y
|
||||||
|
c.func6={}
|
||||||
|
c.func7={function() _GuiPro.DragItem={} end}
|
||||||
|
c.func8={function(self) _GuiPro.DragItem=self end}
|
||||||
|
c.func9={}
|
||||||
|
c.func10={}
|
||||||
|
function c:ImageRule()
|
||||||
|
if self.Image then
|
||||||
|
local sx=self.width/self.ImageWidth
|
||||||
|
local sy=self.height/self.ImageHeigth
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.ImageVisibility*255)
|
||||||
|
if self.width~=self.ImageWidth and self.height~=self.ImageHeigth then
|
||||||
|
love.graphics.draw(self.Image,self.x,self.y,math.rad(self.rotation),sx,sy)
|
||||||
|
else
|
||||||
|
love.graphics.draw(self.Image,self.Quad,self.x,self.y,math.rad(self.rotation),sx,sy)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function c:VideoRule()
|
||||||
|
if self.Video then
|
||||||
|
local sx=self.width/self.VideoWidth
|
||||||
|
local sy=self.height/self.VideoHeigth
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.VideoVisibility*255)
|
||||||
|
if self.width~=self.VideoWidth and self.height~=self.VideoHeigth then
|
||||||
|
love.graphics.draw(self.Video,self.x,self.y,math.rad(self.rotation),sx,sy)
|
||||||
|
else
|
||||||
|
love.graphics.draw(self.Video,self.Quad,self.x,self.y,math.rad(self.rotation),sx,sy)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function c:repeatImage(b,b2)
|
||||||
|
if b then
|
||||||
|
self.Image:setWrap(b,b2 or "repeat")
|
||||||
|
function self:ImageRule()
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.ImageVisibility*255)
|
||||||
|
love.graphics.draw(self.Image,self.Quad,self.x,self.y,math.rad(self.rotation))
|
||||||
|
end
|
||||||
|
else
|
||||||
|
sx=self.width/self.ImageWidth
|
||||||
|
sy=self.height/self.ImageHeigth
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.ImageVisibility*255)
|
||||||
|
love.graphics.draw(self.Image,self.Quad,self.x,self.y,math.rad(self.rotation),sx,sy)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function c:Mutate(t)
|
||||||
|
for i,v in pairs(t) do
|
||||||
|
_GuiPro.self=self
|
||||||
|
if type(i)=="number" then
|
||||||
|
loadstring("_GuiPro.self:"..v)()
|
||||||
|
else
|
||||||
|
self[i]=v
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return self
|
||||||
|
end
|
||||||
|
c:WhileHovering(function(self)
|
||||||
|
self.omx=self.nmx
|
||||||
|
self.omy=self.nmy
|
||||||
|
self.nmx=love.mouse.getX()
|
||||||
|
self.nmy=love.mouse.getY()
|
||||||
|
if self.omx~=self.nmx or self.omy~=self.nmy then
|
||||||
|
for i=1,#self.func10 do
|
||||||
|
if self and self.nmx and self.nmy and self.omx and self.omy then
|
||||||
|
self.func10[i](self,self.nmx,self.nmy,self.omx,self.omy)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if self.WasBeingDragged==true and love.mouse.isDown(self.dragbut or "m")==false and self.Type~="TextImageButtonFrameDrag" then
|
||||||
|
for i=1,#self.func7 do
|
||||||
|
self.func7[i](self,(love.mouse.getX())-self.width/2,(love.mouse.getY())-self.height/2)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if _GuiPro.hasDrag==false and love.mouse.isDown(self.dragbut or "m") then
|
||||||
|
for i=1,#self.func8 do
|
||||||
|
self.func8[i](self,(love.mouse.getX())-self.width/2,(love.mouse.getY())-self.height/2)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if self.IsBeingDragged==true then
|
||||||
|
_GuiPro.hasDrag=true
|
||||||
|
self.WasBeingDragged=true
|
||||||
|
elseif self.WasBeingDragged==true and self.IsBeingDragged==false then
|
||||||
|
self.WasBeingDragged=false
|
||||||
|
_GuiPro.hasDrag=false
|
||||||
|
end
|
||||||
|
if self.Draggable==true and love.mouse.isDown(self.dragbut or "m") and _GuiPro.hasDrag==false then
|
||||||
|
for i=1,#self.func6 do
|
||||||
|
self.func6[i](self,(love.mouse.getX())-self.width/2,(love.mouse.getY())-self.height/2)
|
||||||
|
end
|
||||||
|
_GuiPro.hasDrag=true
|
||||||
|
if self.FormFactor:lower()=="circle" or self.FormFactor:lower()=="c" or self.FormFactor:lower()=="cir" then
|
||||||
|
self.IsBeingDragged=true
|
||||||
|
x=(love.mouse.getX()-self.x)
|
||||||
|
y=(love.mouse.getY()-self.y)
|
||||||
|
self:Move(x,y)
|
||||||
|
elseif self.FormFactor:lower()=="rectangle" or self.FormFactor:lower()=="r" or self.FormFactor:lower()=="rect" then
|
||||||
|
self.IsBeingDragged=true
|
||||||
|
x=(love.mouse.getX()-self.x)-self.width/2
|
||||||
|
y=(love.mouse.getY()-self.y)-self.height/2
|
||||||
|
self:Move(x,y)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
self.IsBeingDragged=false
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
table.insert(c.Parent.Children,c)
|
||||||
|
return c
|
||||||
|
end
|
||||||
7
GuiManager/Core/patches.int
Normal file
7
GuiManager/Core/patches.int
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
_GuiPro.mousedownfunc=love.mouse.isDown
|
||||||
|
function love.mouse.isDown(b)
|
||||||
|
if not(b) then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
return _GuiPro.mousedownfunc(({["l"]=1,["r"]=2,["m"]=3})[b] or b)
|
||||||
|
end
|
||||||
204
GuiManager/Core/touchManager.int
Normal file
204
GuiManager/Core/touchManager.int
Normal file
@ -0,0 +1,204 @@
|
|||||||
|
--[[WORKING ON
|
||||||
|
doubleTap - UnFinished!
|
||||||
|
touchRendering - Broken
|
||||||
|
]]
|
||||||
|
function gui:TClickable(mx,my)
|
||||||
|
local x,y,w,h=love.graphics.getScissor()
|
||||||
|
if _GuiPro.HasStencel then
|
||||||
|
local obj=_GuiPro.StencelHolder
|
||||||
|
if self:isDescendant(obj) then
|
||||||
|
return math.sqrt((mx-obj.x)^2+(my-obj.y)^2)<=(obj.offset.size.x or 0)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if not(x) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
return not(mx>x+w or mx<x or my>y+h or my<y)
|
||||||
|
end
|
||||||
|
function gui:touchable(t)
|
||||||
|
local touches = love.touch.getTouches()
|
||||||
|
local x,y=0,0
|
||||||
|
for i, id in ipairs(touches) do
|
||||||
|
if self.id==id then
|
||||||
|
x, y = love.touch.getPosition(id)
|
||||||
|
return (x > self.x and x < self.x+self.width and y > self.y and y < self.y+self.height and self:TClickable(x,y) and self:eventable())
|
||||||
|
end
|
||||||
|
end
|
||||||
|
self.id=-1
|
||||||
|
end
|
||||||
|
multi:newTask(function() -- A bit of post-loading haha
|
||||||
|
gui.touchpressed=multi:newConnection()
|
||||||
|
gui.touchreleased=multi:newConnection()
|
||||||
|
gui.touchmoved=multi:newConnection()
|
||||||
|
love.touchpressed=Library.convert(love.touchpressed or function() end)
|
||||||
|
love.touchreleased=Library.convert(love.touchreleased or function() end)
|
||||||
|
love.touchmoved=Library.convert(love.touchmoved or function() end)
|
||||||
|
love.touchpressed:inject(function(id, x, y, dx, dy, pressure) gui.touchpressed:Fire(id, x, y, dx, dy, pressure) return {id, x, y, dx, dy, pressure} end,1)
|
||||||
|
love.touchreleased:inject(function(id, x, y, dx, dy, pressure) gui.touchreleased:Fire(id, x, y, dx, dy, pressure) return {id, x, y, dx, dy, pressure} end,1)
|
||||||
|
love.touchmoved:inject(function(id, x, y, dx, dy, pressure) gui.touchmoved:Fire(id, x, y, dx, dy, pressure) return {id, x, y, dx, dy, pressure} end,1)
|
||||||
|
_GuiPro.TouchReady=true
|
||||||
|
_GuiPro.TouchRegister={}
|
||||||
|
gui.touchpressed:connect(function(id, x, y, dx, dy, pressure)
|
||||||
|
for i,v in pairs(_GuiPro.TouchRegister) do
|
||||||
|
if #v.tid==0 then
|
||||||
|
if (x > v.x and x < v.x+v.width and y > v.y and y < v.y+v.height and v:TClickable(x,y) and v:eventable()) then
|
||||||
|
v:addTID(id)
|
||||||
|
v.touchcount=1
|
||||||
|
for i=1,#v.ToFuncP do
|
||||||
|
v.ToFuncP[i](v,id, x-v.x, y-v.y, dx, dy or 0, pressure or 1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
elseif not(v:hasTID(id)) then
|
||||||
|
if (x > v.x and x < v.x+v.width and y > v.y and y < v.y+v.height and v:TClickable(x,y) and v:eventable()) then
|
||||||
|
v:addTID(id)
|
||||||
|
v.touchcount=v.touchcount+1
|
||||||
|
for i=1,#v.ToFuncP do
|
||||||
|
v.ToFuncP[i](v,id, x-v.x, y-v.y, dx, dy or 0, pressure or 1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
gui.touchreleased:connect(function(id, x, y, dx, dy, pressure)
|
||||||
|
for i,v in pairs(_GuiPro.TouchRegister) do
|
||||||
|
if v:hasTID(id) then
|
||||||
|
v:removeTID(id)
|
||||||
|
for i=1,#v.ToFuncR do
|
||||||
|
v.ToFuncR[i](v,id, x-v.x, y-v.y, dx, dy or 0, pressure or 1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
gui.touchmoved:connect(function(id, x, y, dx, dy, pressure)
|
||||||
|
for i,v in pairs(_GuiPro.TouchRegister) do
|
||||||
|
if v:hasTID(id) and (x > v.x and x < v.x+v.width and y > v.y and y < v.y+v.height and v:TClickable(x,y) and v:eventable()) then
|
||||||
|
for i=1,#v.ToFuncM do
|
||||||
|
v.ToFuncM[i](v,id, x-v.x, y-v.y, dx, dy or 0, pressure or 1)
|
||||||
|
end
|
||||||
|
elseif v:hasTID(id) and not((x > v.x and x < v.x+v.width and y > v.y and y < v.y+v.height and v:TClickable(x,y) and v:eventable())) then
|
||||||
|
v:removeTID(id)
|
||||||
|
for i=1,#v.ToFuncR do
|
||||||
|
v.ToFuncR[i](v,id, x-v.x, y-v.y, dx, dy or 0, pressure or 1)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
end)
|
||||||
|
-- now that that is done lets set up some more post loading checks
|
||||||
|
_GuiPro.int=multi:newProcess()
|
||||||
|
_GuiPro.int:Start()
|
||||||
|
_GuiPro.int:setJobSpeed(.001)
|
||||||
|
_GuiPro.EXACT=0
|
||||||
|
_GuiPro.LAX=.01
|
||||||
|
_GuiPro.LAZY=.05
|
||||||
|
-- now lets define the reg function
|
||||||
|
function gui.Compare(a,b,v,tp)
|
||||||
|
if tp==">" then
|
||||||
|
if (a+v>b or a-v>b) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
elseif tp=="<" then
|
||||||
|
if (a+v<b or a-v<b) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
elseif tp=="<=" then
|
||||||
|
if (a+v<=b or a-v<=b) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
elseif tp==">=" then
|
||||||
|
if (a+v>=b or a-v>=b) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
elseif tp=="==" then -- this one is gonna be tricky
|
||||||
|
if (a>=b-v and a<=b+v) or (b>=a-v and b<=a+v) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
function gui:regesterTouch()
|
||||||
|
local obj=self
|
||||||
|
obj.ToFuncP={}
|
||||||
|
obj.ToFuncM={}
|
||||||
|
obj.ToFuncR={}
|
||||||
|
obj.To2Func={}
|
||||||
|
obj.ToDTFunc={}
|
||||||
|
obj.touchRendering =_GuiPro.EXACT -- exact(0), lax(), #
|
||||||
|
function obj:removeTID(id)
|
||||||
|
for i=1,#self.tid do
|
||||||
|
if self.tid[i]==id then
|
||||||
|
table.remove(self.tid,i)
|
||||||
|
self.touchcount=self.touchcount-1
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function obj:hasTID(id)
|
||||||
|
for i=1,#self.tid do
|
||||||
|
if self.tid[i]==id then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
obj.txl1=0
|
||||||
|
obj.tyl1=0
|
||||||
|
obj.txl2=0
|
||||||
|
obj.tyl2=0
|
||||||
|
obj.LS=0
|
||||||
|
obj:OnUpdate(function(self)
|
||||||
|
if self.touchcount==2 then
|
||||||
|
local x1,y1=love.touch.getPosition( self.tid[1] )
|
||||||
|
local x2,y2=love.touch.getPosition( self.tid[2] )
|
||||||
|
local CS=math.sqrt((x2-x1)^2+(y2-y1)^2)
|
||||||
|
if gui.Compare(CS,self.LS,self.touchRendering,">") then
|
||||||
|
for i=1,#self.To2Func do
|
||||||
|
self.To2Func[i](self,CS,x1-self.x,y1-self.y,x2-self.x,y2-self.y)
|
||||||
|
end
|
||||||
|
elseif gui.Compare(CS,self.LS,self.touchRendering,"<") then
|
||||||
|
for i=1,#self.To2Func do
|
||||||
|
self.To2Func[i](self,-CS,x1-self.x,y1-self.y,x2-self.x,y2-self.y)
|
||||||
|
end
|
||||||
|
elseif gui.Compare(CS,self.LS,self.touchRendering,"==") then
|
||||||
|
for i=1,#self.To2Func do
|
||||||
|
self.To2Func[i](self,0,x1-self.x,y1-self.y,x2-self.x,y2-self.y)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- if self.txl1~=x1 or self.txl2~=x2 or self.tyl1~=y1 or self.tyl2~=y2 then
|
||||||
|
-- for i=1,#self.To2Func do
|
||||||
|
-- self.To2Func[i](self,0,x1-self.x,y1-self.y,x2-self.x,y2-self.y)
|
||||||
|
-- end
|
||||||
|
-- end
|
||||||
|
self.LS=CS
|
||||||
|
self.txl1=x1
|
||||||
|
self.txl2=x2
|
||||||
|
self.tyl1=y1
|
||||||
|
self.tyl2=y2
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
function obj:OnDoubleTap(func)
|
||||||
|
table.insert(self.ToDTFunc,func)
|
||||||
|
end
|
||||||
|
function obj:On2TouchMoved(func)
|
||||||
|
table.insert(self.To2Func,func)
|
||||||
|
end
|
||||||
|
function obj:addTID(id)
|
||||||
|
table.insert(self.tid,id)
|
||||||
|
end
|
||||||
|
function obj:OnTouchPressed(func)
|
||||||
|
table.insert(self.ToFuncP,func) -- event for touches
|
||||||
|
end
|
||||||
|
function obj:OnTouchReleased(func) -- event for touches
|
||||||
|
table.insert(self.ToFuncR,func)
|
||||||
|
end
|
||||||
|
function obj:OnTouchMoved(func) -- event for touches
|
||||||
|
table.insert(self.ToFuncM,func)
|
||||||
|
end
|
||||||
|
if _GuiPro.TouchReady then -- my sneaky test
|
||||||
|
print("Registred: "..tostring(obj))
|
||||||
|
table.insert(_GuiPro.TouchRegister,obj)
|
||||||
|
else
|
||||||
|
print("Attempting to register: "..tostring(obj))
|
||||||
|
_GuiPro.int:newJob(function() table.insert(_GuiPro.TouchRegister,obj) end) -- a sneaky way to ensure that your object gets registered eventually, even if you call the method before the touch patch was activated.
|
||||||
|
end
|
||||||
|
end
|
||||||
4
GuiManager/Drawing/AddDrawRuleB.int
Normal file
4
GuiManager/Drawing/AddDrawRuleB.int
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
function gui:AddDrawRuleB(rule)
|
||||||
|
if not(self.DrawRulesB) then self.DrawRulesB={} end
|
||||||
|
table.insert(self.DrawRulesB,rule)
|
||||||
|
end
|
||||||
4
GuiManager/Drawing/AddDrawRuleE.int
Normal file
4
GuiManager/Drawing/AddDrawRuleE.int
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
function gui:AddDrawRuleE(rule)
|
||||||
|
if not(self.DrawRulesE) then self.DrawRulesE={} end
|
||||||
|
table.insert(self.DrawRulesE,rule)
|
||||||
|
end
|
||||||
12
GuiManager/Drawing/draw.int
Normal file
12
GuiManager/Drawing/draw.int
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
function gui:draw()
|
||||||
|
if _GuiPro.rotate~=0 then
|
||||||
|
love.graphics.rotate(math.rad(_GuiPro.rotate))
|
||||||
|
end
|
||||||
|
if self.FormFactor:lower()=="rectangle" then
|
||||||
|
self:drawR()
|
||||||
|
elseif self.FormFactor:lower()=="circle" then
|
||||||
|
self:drawC()
|
||||||
|
else
|
||||||
|
error("Unsupported FormFactor: "..self.FormFactor.."!")
|
||||||
|
end
|
||||||
|
end
|
||||||
89
GuiManager/Drawing/drawC.int
Normal file
89
GuiManager/Drawing/drawC.int
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
function gui:drawC()
|
||||||
|
if love.mouse.isDown("l")==false and love.mouse.isDown("m")==false and love.mouse.isDown("r")==false then
|
||||||
|
_GuiPro.DragItem={}
|
||||||
|
_GuiPro.hasDrag=false
|
||||||
|
end
|
||||||
|
if self.Visible==true and self.VIS==true then
|
||||||
|
local b=true
|
||||||
|
for i,v in pairs(_GuiPro.Clips) do
|
||||||
|
if self:isDescendant(v)==true then
|
||||||
|
b=false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if b then
|
||||||
|
love.graphics.setStencilTest( )
|
||||||
|
_GuiPro.HasStencel=false
|
||||||
|
_GuiPro.StencelHolder=nil
|
||||||
|
end
|
||||||
|
local x,y,r,s=(self.offset.pos.x or 0)+self.Parent.x,(self.offset.pos.y or 0)+self.Parent.y,self.offset.size.x or 0,self.offset.size.y or 360
|
||||||
|
if self.CC then
|
||||||
|
x,y=x+r,y+r
|
||||||
|
end
|
||||||
|
self.x,self.y=x,y
|
||||||
|
_GuiPro.circleStencilFunction = function()
|
||||||
|
love.graphics.circle("fill",x,y,r,s)
|
||||||
|
end
|
||||||
|
if math.sqrt((love.mouse.getX()-x)^2+(love.mouse.getY()-y)^2)<=r and self:eventable() and self:Clickable() and self.Active==true then
|
||||||
|
self.hovering=true
|
||||||
|
if love.mouse.isDown("l") and _GuiPro.hasDrag==false then
|
||||||
|
if string.find(self.Type, "Button") then
|
||||||
|
love.graphics.setColor(self.Color[1]-10, self.Color[2]-10, self.Color[3]-10,self.Visibility*254)
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
end
|
||||||
|
self.lclicked=true
|
||||||
|
elseif love.mouse.isDown("r") and _GuiPro.hasDrag==false then
|
||||||
|
if string.find(self.Type, "Button") then
|
||||||
|
love.graphics.setColor(self.Color[1]-10, self.Color[2]-10, self.Color[3]-10,self.Visibility*254)
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
end
|
||||||
|
self.rclicked=true
|
||||||
|
elseif love.mouse.isDown("m") and _GuiPro.hasDrag==false then
|
||||||
|
if string.find(self.Type, "Button") then
|
||||||
|
love.graphics.setColor(self.Color[1]-10, self.Color[2]-10, self.Color[3]-10,self.Visibility*254)
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
end
|
||||||
|
self.mclicked=true
|
||||||
|
else
|
||||||
|
if string.find(self.Type, "Button") and _GuiPro.hasDrag==false then
|
||||||
|
love.graphics.setColor(self.Color[1]-5, self.Color[2]-5, self.Color[3]-5,self.Visibility*254)
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
end
|
||||||
|
self.rclicked=false
|
||||||
|
self.lclicked=false
|
||||||
|
self.mclicked=false
|
||||||
|
end
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
self.hovering=false
|
||||||
|
self.rclicked=false
|
||||||
|
self.lclicked=false
|
||||||
|
self.mclicked=false
|
||||||
|
end
|
||||||
|
if self.ClipDescendants==true then
|
||||||
|
_GuiPro.Clips[tostring(self)]=self
|
||||||
|
_GuiPro.HasStencel=true
|
||||||
|
_GuiPro.StencelHolder=self
|
||||||
|
love.graphics.stencil(_GuiPro.circleStencilFunction)
|
||||||
|
love.graphics.setStencilTest("notequal",0)
|
||||||
|
end
|
||||||
|
love.graphics.circle("fill",x,y,r,s)
|
||||||
|
love.graphics.setColor(self.BorderColor[1], self.BorderColor[2], self.BorderColor[3],self.Visibility*254)
|
||||||
|
for b=0,self.BorderSize-1 do
|
||||||
|
love.graphics.circle("line",x,y,r+b,s)
|
||||||
|
end
|
||||||
|
if string.find(self.Type, "Text") then
|
||||||
|
if self.text~=nil then
|
||||||
|
if self.AutoScaleText then
|
||||||
|
self.FontSize=math.floor(self.height/1.45833)
|
||||||
|
end
|
||||||
|
love.graphics.setColor(self.TextColor[1],self.TextColor[2],self.TextColor[3],self.TextVisibility*254)
|
||||||
|
love.graphics.setFont(self.Font)
|
||||||
|
love.graphics.printf(self.text, x-(r/2)+(self.XTween), y-(r/2)+self.Tween, r, self.TextFormat)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
118
GuiManager/Drawing/drawR.int
Normal file
118
GuiManager/Drawing/drawR.int
Normal file
@ -0,0 +1,118 @@
|
|||||||
|
function gui:drawR()
|
||||||
|
if love.mouse.isDown("l")==false and love.mouse.isDown("m")==false and love.mouse.isDown("r")==false then
|
||||||
|
_GuiPro.DragItem={}
|
||||||
|
_GuiPro.hasDrag=false
|
||||||
|
end
|
||||||
|
if self.Visible==true and self.VIS==true then
|
||||||
|
local b=true
|
||||||
|
for i,v in pairs(_GuiPro.Clips) do
|
||||||
|
if self:isDescendant(v)==true then
|
||||||
|
b=false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if b==true then
|
||||||
|
love.graphics.setStencilTest()
|
||||||
|
love.graphics.setScissor()
|
||||||
|
end
|
||||||
|
self.x=(self.Parent.width*self.scale.pos.x)+self.offset.pos.x+self.Parent.x
|
||||||
|
self.y=(self.Parent.height*self.scale.pos.y)+self.offset.pos.y+self.Parent.y
|
||||||
|
self.width=(self.Parent.width*self.scale.size.x)+self.offset.size.x
|
||||||
|
self.height=(self.Parent.height*self.scale.size.y)+self.offset.size.y
|
||||||
|
if self.DrawRulesB then
|
||||||
|
for dr=1,#self.DrawRulesB do
|
||||||
|
self.DrawRulesB[dr](self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if (love.mouse.getX() > self.x and love.mouse.getX() < self.x+self.width and love.mouse.getY() > self.y and love.mouse.getY() < self.y+self.height and self:Clickable() and self:eventable()) or self:touchable("r") and self.Active==true then
|
||||||
|
self.hovering=true
|
||||||
|
if love.mouse.isDown("l") or self:touchable("r") and _GuiPro.hasDrag==false then
|
||||||
|
if string.find(self.Type, "Button") then
|
||||||
|
love.graphics.setColor(self.Color[1]-10, self.Color[2]-10, self.Color[3]-10,self.Visibility*254)
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
end
|
||||||
|
self.lclicked=true
|
||||||
|
elseif love.mouse.isDown("r") or self:touchable("r") and _GuiPro.hasDrag==false then
|
||||||
|
if string.find(self.Type, "Button") then
|
||||||
|
love.graphics.setColor(self.Color[1]-10, self.Color[2]-10, self.Color[3]-10,self.Visibility*254)
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
end
|
||||||
|
self.rclicked=true
|
||||||
|
elseif love.mouse.isDown("m") or self:touchable("r") and _GuiPro.hasDrag==false then
|
||||||
|
if string.find(self.Type, "Button") then
|
||||||
|
love.graphics.setColor(self.Color[1]-10, self.Color[2]-10, self.Color[3]-10,self.Visibility*254)
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
end
|
||||||
|
self.mclicked=true
|
||||||
|
else
|
||||||
|
if string.find(self.Type, "Button") or self:touchable("r") and _GuiPro.hasDrag==false then
|
||||||
|
love.graphics.setColor(self.Color[1]-5, self.Color[2]-5, self.Color[3]-5,self.Visibility*254)
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
end
|
||||||
|
self.rclicked=false
|
||||||
|
self.lclicked=false
|
||||||
|
self.mclicked=false
|
||||||
|
end
|
||||||
|
else
|
||||||
|
love.graphics.setColor(self.Color[1],self.Color[2],self.Color[3],self.Visibility*254)
|
||||||
|
self.hovering=false
|
||||||
|
self.rclicked=false
|
||||||
|
self.lclicked=false
|
||||||
|
self.mclicked=false
|
||||||
|
end
|
||||||
|
if self.ClipDescendants==true then
|
||||||
|
_GuiPro.Clips[tostring(self)]=self
|
||||||
|
love.graphics.setScissor(self.x, self.y, self.width, self.height)
|
||||||
|
end
|
||||||
|
if self:hasRoundness() then
|
||||||
|
love.graphics.stencil(self.stfunc, "replace", 1)
|
||||||
|
love.graphics.setStencilTest("greater", 0)
|
||||||
|
end
|
||||||
|
love.graphics.rectangle("fill", self.x, self.y, self.width, self.height,(self.rx or 1)*self.DPI,(self.ry or 1)*self.DPI,(self.segments or 1)*self.DPI)
|
||||||
|
if string.find(self.Type, "Image") then
|
||||||
|
self:ImageRule()
|
||||||
|
end
|
||||||
|
if self.Type=="Video" then
|
||||||
|
self:VideoRule()
|
||||||
|
end
|
||||||
|
if self:hasRoundness() then
|
||||||
|
love.graphics.setStencilTest()
|
||||||
|
end
|
||||||
|
love.graphics.setColor(self.BorderColor[1], self.BorderColor[2], self.BorderColor[3],self.Visibility*254)
|
||||||
|
for b=0,self.BorderSize-1 do
|
||||||
|
love.graphics.rectangle("line", self.x-(b/2), self.y-(b/2), self.width+b, self.height+b,(self.rx or 1)*self.DPI,(self.ry or 1)*self.DPI,(self.segments or 1)*self.DPI)
|
||||||
|
end
|
||||||
|
if string.find(self.Type, "Text") then
|
||||||
|
if self.text~=nil then
|
||||||
|
if self.AutoScaleText then
|
||||||
|
self.FontSize=math.floor(self.height/1.45833)
|
||||||
|
end
|
||||||
|
love.graphics.setColor(self.TextColor[1],self.TextColor[2],self.TextColor[3],self.TextVisibility*254)
|
||||||
|
if self.Font==_defaultfont then
|
||||||
|
love.graphics.setFont(self.Font)
|
||||||
|
love.graphics.printf(self.text, self.x+2+(self.XTween*self.DPI)+((self.marginL or 0)*self.DPI or self.XTween*self.DPI), self.y+(self.FontHeight/2)+self.Tween*self.DPI, self.width+(0 or (self.marginR or 0)*self.DPI), self.TextFormat)
|
||||||
|
else
|
||||||
|
if type(self.Font)=="string" then
|
||||||
|
self.Font=love.graphics.newFont(self.Font,self.FontSize)
|
||||||
|
self.FontHeight=self.Font:getHeight()
|
||||||
|
else
|
||||||
|
love.graphics.setFont(self.Font)
|
||||||
|
end
|
||||||
|
if type(self.FontSize)=="string" then
|
||||||
|
self.FontSize=tonumber(self.FontSize)
|
||||||
|
love.graphics.setNewFont(self.FontSize)
|
||||||
|
end
|
||||||
|
love.graphics.printf(self.text, self.x+2+((self.marginL or 0)*self.DPI or self.XTween*self.DPI), self.y+math.floor((self.FontHeight-self.FontSize)/2)+self.Tween*self.DPI, self.width+(0 or (self.marginR or 0)*self.DPI), self.TextFormat)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if self.DrawRulesE then
|
||||||
|
for dr=1,#self.DrawRulesE do
|
||||||
|
self.DrawRulesE[dr](self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
37
GuiManager/Frame/newDropFrame.int
Normal file
37
GuiManager/Frame/newDropFrame.int
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
function gui:newDropFrame(name,x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("DropFrame",name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
c.WasBeingDragged=false
|
||||||
|
c.IsBeingDragged=false
|
||||||
|
c.Draggable=false
|
||||||
|
c.funcD={}
|
||||||
|
function c:GetDroppedItems()
|
||||||
|
local t=self:getChildren()
|
||||||
|
local tab={}
|
||||||
|
for i=1,#t do
|
||||||
|
if t[i].Type=="TextImageButtonFrameDrag" then
|
||||||
|
table.insert(tab,t[i])
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return tab
|
||||||
|
end
|
||||||
|
function c:OnDropped(func)
|
||||||
|
table.insert(self.funcD,func)
|
||||||
|
end
|
||||||
|
c:OnUpdate(function(self)
|
||||||
|
if _GuiPro.DragItem then
|
||||||
|
if _GuiPro.DragItem.Type=="TextImageButtonFrameDrag" and love.mouse.isDown(_GuiPro.DragItem.dragbut or "m")==false and self:IsHovering() then
|
||||||
|
local t=_GuiPro.DragItem
|
||||||
|
_GuiPro.DragItem={}
|
||||||
|
for i=1,#t.funcD do
|
||||||
|
t.funcD[i](self,t)
|
||||||
|
end
|
||||||
|
for i=1,#self.funcD do
|
||||||
|
self.funcD[i](self,t)
|
||||||
|
end
|
||||||
|
_GuiPro.hasDrag=false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
return c
|
||||||
|
end
|
||||||
8
GuiManager/Frame/newFrame.int
Normal file
8
GuiManager/Frame/newFrame.int
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
function gui:newFrame(name,x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("Frame",name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
c.WasBeingDragged=false
|
||||||
|
c.IsBeingDragged=false
|
||||||
|
c.Draggable=false
|
||||||
|
return c
|
||||||
|
end
|
||||||
4
GuiManager/Frame/newFullFrame.int
Normal file
4
GuiManager/Frame/newFullFrame.int
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
function gui:newFullFrame(name)
|
||||||
|
name=name or ""
|
||||||
|
return self:newFrame(name,0,0,0,0,0,0,1,1)
|
||||||
|
end
|
||||||
59
GuiManager/Frame/newTabFrame.int
Normal file
59
GuiManager/Frame/newTabFrame.int
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
function gui:newTabFrame(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=gui:newFrame(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
c.tabheight=20
|
||||||
|
c.Holder=c:newFrame("Holder",0,c.tabheight,0,0,0,0,1,1)
|
||||||
|
c.TabHolder=c:newFrame("TabHolder",0,0,0,c.tabheight,0,0,1)
|
||||||
|
function c:setTabHeight(n)
|
||||||
|
self.tabheight=n
|
||||||
|
self.Holder:SetDualDim(0,-self.tabheight,0,0,0,0,1,1)
|
||||||
|
end
|
||||||
|
function c:addTab(name,colorT,colorH)
|
||||||
|
if colorT and not(colorH) then
|
||||||
|
colorH=colorT
|
||||||
|
end
|
||||||
|
local tab=self.TabHolder:newTextButton(name,name,0,0,0,0,0,0,0,1)
|
||||||
|
tab.Tween=-3
|
||||||
|
if colorT then
|
||||||
|
tab.Color=colorT
|
||||||
|
end
|
||||||
|
local holder=self.Holder:newFrame(name,0,0,0,0,0,0,1,1)
|
||||||
|
if colorH then
|
||||||
|
holder.Color=colorH
|
||||||
|
end
|
||||||
|
tab.frame=holder
|
||||||
|
tab:OnReleased(function(b,self)
|
||||||
|
if b=="l" then
|
||||||
|
local tt=self.Parent:getChildren()
|
||||||
|
local th=self.Parent.Parent.Holder:getChildren()
|
||||||
|
for i=1,#th do
|
||||||
|
th[i].Visible=false
|
||||||
|
end
|
||||||
|
for i=1,#tt do
|
||||||
|
tt[i].frame.Visible=false
|
||||||
|
tt[i].BorderSize=1
|
||||||
|
end
|
||||||
|
self.BorderSize=0
|
||||||
|
self.frame.Visible=true
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
local tt=self.TabHolder:getChildren()
|
||||||
|
for i=1,#tt do
|
||||||
|
tt[i].frame.Visible=false
|
||||||
|
tt[i].BorderSize=1
|
||||||
|
end
|
||||||
|
tab.frame.Visible=true
|
||||||
|
tab.BorderSize=0
|
||||||
|
return tab,holder
|
||||||
|
end
|
||||||
|
c:OnUpdate(function(self)
|
||||||
|
local th=self.TabHolder:getChildren()
|
||||||
|
local l=self.width/#th
|
||||||
|
for i=1,#th do
|
||||||
|
th[i]:SetDualDim(l*(i-1),0,l)
|
||||||
|
end
|
||||||
|
if #th==0 then
|
||||||
|
self:Destroy()
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
return c
|
||||||
|
end
|
||||||
0
GuiManager/Frame/newratioFrame.int
Normal file
0
GuiManager/Frame/newratioFrame.int
Normal file
13
GuiManager/Image-Animation/SetImage.int
Normal file
13
GuiManager/Image-Animation/SetImage.int
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
function gui:SetImage(i)
|
||||||
|
if type(i)=="string" then
|
||||||
|
self.Image=love.graphics.newImage(i)
|
||||||
|
else
|
||||||
|
self.Image=i
|
||||||
|
end
|
||||||
|
if self.Image~=nil then
|
||||||
|
self.ImageHeigth=self.Image:getHeight()
|
||||||
|
self.ImageWidth=self.Image:getWidth()
|
||||||
|
self.Quad=love.graphics.newQuad(0,0,self.width,self.height,self.ImageWidth,self.ImageHeigth)
|
||||||
|
end
|
||||||
|
return self.ImageWidth,self.ImageHeigth
|
||||||
|
end
|
||||||
5
GuiManager/Image-Animation/UpdateImage.int
Normal file
5
GuiManager/Image-Animation/UpdateImage.int
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
function gui:UpdateImage()
|
||||||
|
self.ImageHeigth=self.Image:getHeight()
|
||||||
|
self.ImageWidth=self.Image:getWidth()
|
||||||
|
self.Quad=love.graphics.newQuad(0,0,self.width,self.height,self.ImageWidth,self.ImageHeigth)
|
||||||
|
end
|
||||||
20
GuiManager/Image-Animation/getTile.int
Normal file
20
GuiManager/Image-Animation/getTile.int
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
function gui:getTile(i,x,y,w,h)-- returns imagedata
|
||||||
|
if type(i)=="string" then
|
||||||
|
i=love.graphics.newImage(i)
|
||||||
|
elseif type(i)=="userdata" then
|
||||||
|
-- do nothing
|
||||||
|
elseif string.find(self.Type,"Image",1,true) then
|
||||||
|
local i,x,y,w,h=self.Image,i,x,y,w
|
||||||
|
else
|
||||||
|
error("getTile invalid args!!! Usage: ImageElement:getTile(x,y,w,h) or gui:getTile(imagedata,x,y,w,h)")
|
||||||
|
end
|
||||||
|
local iw,ih=i:getDimensions()
|
||||||
|
local id,_id=i:getData(),love.image.newImageData(w,h)
|
||||||
|
for _x=x,w+x-1 do
|
||||||
|
for _y=y,h+y-1 do
|
||||||
|
--
|
||||||
|
_id:setPixel(_x-x,_y-y,id:getPixel(_x,_y))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return love.graphics.newImage(_id)
|
||||||
|
end
|
||||||
57
GuiManager/Image-Animation/newAnim.int
Normal file
57
GuiManager/Image-Animation/newAnim.int
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
function gui:newAnim(file,delay, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local x,y,w,h,sx,sy,sw,sh=filter(file, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("ImageAnimation",file, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
c.Visibility=0
|
||||||
|
c.ImageVisibility=1
|
||||||
|
c.delay=delay or .05
|
||||||
|
c.files={}
|
||||||
|
c.AnimStart={}
|
||||||
|
c.AnimEnd={}
|
||||||
|
local _files=alphanumsort(love.filesystem.getDirectoryItems(file))
|
||||||
|
for i=1,#_files do
|
||||||
|
if string.sub(_files[i],-1,-1)~="b" then
|
||||||
|
table.insert(c.files,love.graphics.newImage(file.."/".._files[i]))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
c.step=multi:newTStep(1,#c.files,1,c.delay)
|
||||||
|
c.step.parent=c
|
||||||
|
c.rotation=0
|
||||||
|
c.step:OnStart(function(step)
|
||||||
|
for i=1,#step.parent.AnimStart do
|
||||||
|
step.parent.AnimStart[i](step.parent)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
c.step:OnStep(function(pos,step)
|
||||||
|
step.parent:SetImage(step.parent.files[pos])
|
||||||
|
end)
|
||||||
|
c.step:OnEnd(function(step)
|
||||||
|
for i=1,#step.parent.AnimEnd do
|
||||||
|
step.parent.AnimEnd[i](step.parent)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
function c:OnAnimStart(func)
|
||||||
|
table.insert(self.AnimStart,func)
|
||||||
|
end
|
||||||
|
function c:OnAnimEnd(func)
|
||||||
|
table.insert(self.AnimEnd,func)
|
||||||
|
end
|
||||||
|
function c:Pause()
|
||||||
|
self.step:Pause()
|
||||||
|
end
|
||||||
|
function c:Resume()
|
||||||
|
self.step:Resume()
|
||||||
|
end
|
||||||
|
function c:Reset()
|
||||||
|
self.step.pos=1
|
||||||
|
end
|
||||||
|
function c:getFrames()
|
||||||
|
return #self.files
|
||||||
|
end
|
||||||
|
function c:getFrame()
|
||||||
|
return self.step.pos
|
||||||
|
end
|
||||||
|
function c:setFrame(n)
|
||||||
|
return self:SetImage(self.files[n])
|
||||||
|
end
|
||||||
|
return c
|
||||||
|
end
|
||||||
52
GuiManager/Image-Animation/newAnimFromData.int
Normal file
52
GuiManager/Image-Animation/newAnimFromData.int
Normal file
@ -0,0 +1,52 @@
|
|||||||
|
function gui:newAnimFromData(data,delay, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("ImageAnimation","FromFile", x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
c.Visibility=0
|
||||||
|
c.ImageVisibility=1
|
||||||
|
c.delay=delay or .05
|
||||||
|
c.files=data
|
||||||
|
c.AnimStart={}
|
||||||
|
c.AnimEnd={}
|
||||||
|
c:SetImage(c.files[1])
|
||||||
|
c.step=multi:newTStep(1,#c.files,1,c.delay)
|
||||||
|
c.step.parent=c
|
||||||
|
c.rotation=0
|
||||||
|
c.step:OnStart(function(step)
|
||||||
|
for i=1,#step.parent.AnimStart do
|
||||||
|
step.parent.AnimStart[i](step.parent)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
c.step:OnStep(function(pos,step)
|
||||||
|
step.parent:SetImage(step.parent.files[pos])
|
||||||
|
end)
|
||||||
|
c.step:OnEnd(function(step)
|
||||||
|
for i=1,#step.parent.AnimEnd do
|
||||||
|
step.parent.AnimEnd[i](step.parent)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
function c:OnAnimStart(func)
|
||||||
|
table.insert(self.AnimStart,func)
|
||||||
|
end
|
||||||
|
function c:OnAnimEnd(func)
|
||||||
|
table.insert(self.AnimEnd,func)
|
||||||
|
end
|
||||||
|
function c:Pause()
|
||||||
|
self.step:Pause()
|
||||||
|
end
|
||||||
|
function c:Resume()
|
||||||
|
self.step:Resume()
|
||||||
|
end
|
||||||
|
function c:Reset()
|
||||||
|
self.step.pos=1
|
||||||
|
end
|
||||||
|
function c:getFrames()
|
||||||
|
return #self.files
|
||||||
|
end
|
||||||
|
function c:getFrame()
|
||||||
|
return self.step.pos
|
||||||
|
end
|
||||||
|
function c:setFrame(n)
|
||||||
|
return self:SetImage(self.files[n])
|
||||||
|
end
|
||||||
|
return c
|
||||||
|
end
|
||||||
59
GuiManager/Image-Animation/newAnimFromTiles.int
Normal file
59
GuiManager/Image-Animation/newAnimFromTiles.int
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
function gui:newAnimFromTiles(file,xd,yd,delay, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(file, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("ImageAnimation",file, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local im=love.graphics.newImage(file)
|
||||||
|
local _x,_y=im:getDimensions()
|
||||||
|
c.Visibility=0
|
||||||
|
c.ImageVisibility=1
|
||||||
|
c.delay=delay or .05
|
||||||
|
c.files={}
|
||||||
|
c.AnimStart={}
|
||||||
|
c.AnimEnd={}
|
||||||
|
for i=0,_y/yd-1 do
|
||||||
|
for j=0,_x/xd-1 do
|
||||||
|
table.insert(c.files,gui:getTile(im,j*xd,i*yd,xd,yd))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
c:SetImage(c.files[1])
|
||||||
|
c.step=multi:newTStep(1,#c.files,1,c.delay)
|
||||||
|
c.step.parent=c
|
||||||
|
c.rotation=0
|
||||||
|
c.step:OnStart(function(step)
|
||||||
|
for i=1,#step.parent.AnimStart do
|
||||||
|
step.parent.AnimStart[i](step.parent)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
c.step:OnStep(function(pos,step)
|
||||||
|
step.parent:SetImage(step.parent.files[pos])
|
||||||
|
end)
|
||||||
|
c.step:OnEnd(function(step)
|
||||||
|
for i=1,#step.parent.AnimEnd do
|
||||||
|
step.parent.AnimEnd[i](step.parent)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
function c:OnAnimStart(func)
|
||||||
|
table.insert(self.AnimStart,func)
|
||||||
|
end
|
||||||
|
function c:OnAnimEnd(func)
|
||||||
|
table.insert(self.AnimEnd,func)
|
||||||
|
end
|
||||||
|
function c:Pause()
|
||||||
|
self.step:Pause()
|
||||||
|
end
|
||||||
|
function c:Resume()
|
||||||
|
self.step:Resume()
|
||||||
|
end
|
||||||
|
function c:Reset()
|
||||||
|
self.step.pos=1
|
||||||
|
end
|
||||||
|
function c:getFrames()
|
||||||
|
return #self.files
|
||||||
|
end
|
||||||
|
function c:getFrame()
|
||||||
|
return self.step.pos
|
||||||
|
end
|
||||||
|
function c:setFrame(n)
|
||||||
|
return self:SetImage(self.files[n])
|
||||||
|
end
|
||||||
|
return c
|
||||||
|
end
|
||||||
3
GuiManager/Image-Animation/newFullImageLabel.int
Normal file
3
GuiManager/Image-Animation/newFullImageLabel.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:newFullImageLabel(i,name)
|
||||||
|
return self:newImageLabel(i,name,0,0,0,0,0,0,1,1)
|
||||||
|
end
|
||||||
25
GuiManager/Image-Animation/newImageButton.int
Normal file
25
GuiManager/Image-Animation/newImageButton.int
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
function gui:newImageButton(i,name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("ImageButton",name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
if type(i)=="string" then
|
||||||
|
c.Image=love.graphics.newImage(i)
|
||||||
|
else
|
||||||
|
c.Image=i
|
||||||
|
end
|
||||||
|
c.Visibility=0
|
||||||
|
c.ImageVisibility=1
|
||||||
|
c.rotation=0
|
||||||
|
if c.Image~=nil then
|
||||||
|
c.ImageHeigth=c.Image:getHeight()
|
||||||
|
c.ImageHeight=c.Image:getHeight()
|
||||||
|
c.ImageWidth=c.Image:getWidth()
|
||||||
|
c.Quad=love.graphics.newQuad(0,0,w,h,c.ImageWidth,c.ImageHeigth)
|
||||||
|
end
|
||||||
|
c:OnEnter(function()
|
||||||
|
love.mouse.setCursor(_GuiPro.CursorH)
|
||||||
|
end)
|
||||||
|
c:OnExit(function()
|
||||||
|
love.mouse.setCursor(_GuiPro.CursorN)
|
||||||
|
end)
|
||||||
|
return c
|
||||||
|
end
|
||||||
18
GuiManager/Image-Animation/newImageLabel.int
Normal file
18
GuiManager/Image-Animation/newImageLabel.int
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
function gui:newImageLabel(i,name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("ImageLabel",name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
if type(i)=="string" then
|
||||||
|
c.Image=love.graphics.newImage(i)
|
||||||
|
else
|
||||||
|
c.Image=i
|
||||||
|
end
|
||||||
|
c.Visibility=0
|
||||||
|
c.ImageVisibility=1
|
||||||
|
c.rotation=0
|
||||||
|
if c.Image~=nil then
|
||||||
|
c.ImageHeigth=c.Image:getHeight()
|
||||||
|
c.ImageWidth=c.Image:getWidth()
|
||||||
|
c.Quad=love.graphics.newQuad(0,0,w,h,c.ImageWidth,c.ImageHeigth)
|
||||||
|
end
|
||||||
|
return c
|
||||||
|
end
|
||||||
62
GuiManager/Image-Animation/newVideo.int
Normal file
62
GuiManager/Image-Animation/newVideo.int
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
function gui:newVideo(name,i,x,y,w,h,sx,sy,sw,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("Video",name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
if type(i)=="string" then
|
||||||
|
c.Video=love.graphics.newVideo(i)
|
||||||
|
else
|
||||||
|
c.Video=i
|
||||||
|
end
|
||||||
|
c.Visibility=0
|
||||||
|
c.VideoVisibility=1
|
||||||
|
c.rotation=0
|
||||||
|
if c.Video~=nil then
|
||||||
|
c.VideoHeigth=c.Video:getHeight()
|
||||||
|
c.VideoWidth=c.Video:getWidth()
|
||||||
|
c.Quad=love.graphics.newQuad(0,0,w,h,c.VideoWidth,c.VideoHeigth)
|
||||||
|
end
|
||||||
|
c.funcV={}
|
||||||
|
function c:Play()
|
||||||
|
self.handStart=true
|
||||||
|
self.Video:play()
|
||||||
|
end
|
||||||
|
function c:Pause()
|
||||||
|
self.Video:pause()
|
||||||
|
end
|
||||||
|
c.Resume=c.Play
|
||||||
|
function c:Stop()
|
||||||
|
self.handStart=false
|
||||||
|
self:Pause()
|
||||||
|
self:Rewind()
|
||||||
|
for i=1,# self.funcV do
|
||||||
|
self.funcV[i](self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function c:OnVideoStopped(func)
|
||||||
|
table.insert(self.funcV,func)
|
||||||
|
end
|
||||||
|
function c:Rewind()
|
||||||
|
self.Video:rewind()
|
||||||
|
end
|
||||||
|
function c:Restart()
|
||||||
|
self:Rewind()
|
||||||
|
self:Play()
|
||||||
|
end
|
||||||
|
function c:Seek(o)
|
||||||
|
self.Video:seek(o)
|
||||||
|
end
|
||||||
|
function c:Tell()
|
||||||
|
self.Video:tell()
|
||||||
|
end
|
||||||
|
function c:SetFilter(min, mag, anisotropy)
|
||||||
|
self.Video:setFilter(min, mag, anisotropy)
|
||||||
|
end
|
||||||
|
function c:IsPlaying()
|
||||||
|
return self.Video:isPlaying()
|
||||||
|
end
|
||||||
|
c:OnUpdate(function(self)
|
||||||
|
if self.Video:isPlaying()==false and self.handStart == true then
|
||||||
|
self:Stop()
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
return c
|
||||||
|
end
|
||||||
51
GuiManager/Item/newDragItem.int
Normal file
51
GuiManager/Item/newDragItem.int
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
function gui:newDragItem(t,i,name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("TextImageButtonFrameDrag",name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
c.WasBeingDragged=false
|
||||||
|
c.IsBeingDragged=false
|
||||||
|
c.Draggable=true
|
||||||
|
c.funcD={}
|
||||||
|
if type(i)=="string" then
|
||||||
|
c.Image=love.graphics.newImage(i)
|
||||||
|
c.ImageVisibility=1
|
||||||
|
c.ImageHeigth=c.Image:getHeight()
|
||||||
|
c.ImageWidth=c.Image:getWidth()
|
||||||
|
c.Quad=love.graphics.newQuad(0,0,w,h,c.ImageWidth,c.ImageHeigth)
|
||||||
|
elseif type(i)=="image" then
|
||||||
|
c.Image=i
|
||||||
|
c.ImageVisibility=1
|
||||||
|
c.ImageHeigth=c.Image:getHeight()
|
||||||
|
c.ImageWidth=c.Image:getWidth()
|
||||||
|
c.Quad=love.graphics.newQuad(0,0,w,h,c.ImageWidth,c.ImageHeigth)
|
||||||
|
end
|
||||||
|
c:OnDragStart(function(self,x,y)
|
||||||
|
if _GuiPro.hasDrag==false then
|
||||||
|
self:setParent(_GuiPro)
|
||||||
|
self:SetDualDim(x,y)
|
||||||
|
self:TopStack()
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
c.rotation=0
|
||||||
|
c.Tween=0
|
||||||
|
c.XTween=0
|
||||||
|
c.text = t
|
||||||
|
c.AutoScaleText=false
|
||||||
|
c.FontHeight=_defaultfont:getHeight()
|
||||||
|
c.Font=_defaultfont
|
||||||
|
c.FontSize=15
|
||||||
|
c.TextFormat="center"
|
||||||
|
c.TextVisibility=1
|
||||||
|
c.TextColor = {0, 0, 0}
|
||||||
|
function c:OnDropped(func)
|
||||||
|
table.insert(self.funcD,func)
|
||||||
|
end
|
||||||
|
c:OnUpdate(function(self)
|
||||||
|
if love.mouse.isDown("m" or self.dragbut)==false and self==_GuiPro.DragItem and self.hovering==false then
|
||||||
|
_GuiPro.DragItem={}
|
||||||
|
for i=1,#self.func7 do
|
||||||
|
self.func7[i](self,(love.mouse.getX())-self.width/2,(love.mouse.getY())-self.height/2)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
return c
|
||||||
|
end
|
||||||
28
GuiManager/Item/newItem.int
Normal file
28
GuiManager/Item/newItem.int
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
function gui:newItem(t,i,name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("TextImageButtonFrame",name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
if type(i)=="string" then
|
||||||
|
c.Image=love.graphics.newImage(i)
|
||||||
|
else
|
||||||
|
c.Image=i
|
||||||
|
end
|
||||||
|
c.rotation=0
|
||||||
|
c.ImageVisibility=1
|
||||||
|
c.Draggable=false
|
||||||
|
if c.Image~=nil then
|
||||||
|
c.ImageHeigth=c.Image:getHeight()
|
||||||
|
c.ImageWidth=c.Image:getWidth()
|
||||||
|
c.Quad=love.graphics.newQuad(0,0,w,h,c.ImageWidth,c.ImageHeigth)
|
||||||
|
end
|
||||||
|
c.Tween=0
|
||||||
|
c.XTween=0
|
||||||
|
c.text = t
|
||||||
|
c.AutoScaleText=false
|
||||||
|
c.FontHeight=_defaultfont:getHeight()
|
||||||
|
c.Font=_defaultfont
|
||||||
|
c.FontSize=15
|
||||||
|
c.TextFormat="center"
|
||||||
|
c.TextVisibility=1 -- 0=invisible,1=solid (self.TextVisibility*254+1)
|
||||||
|
c.TextColor = {0, 0, 0}
|
||||||
|
return c
|
||||||
|
end
|
||||||
45
GuiManager/Misc/AdvTextBox.int
Normal file
45
GuiManager/Misc/AdvTextBox.int
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
function gui:AdvTextBox(txt,x,y,w,h,sx,sy,sw,sh)
|
||||||
|
name="AdvTextBox"
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("AdvTextBoxFrame",name, x, y, w, 30, sx ,sy ,sw ,sh)
|
||||||
|
c.Draggable=true
|
||||||
|
c.dragbut="r"
|
||||||
|
c.BorderSize=0
|
||||||
|
c:ApplyGradient{Color.Blue,Color.sexy_purple}
|
||||||
|
c:newTextLabel(txt,"Holder",0,0,0,h-30,0,1,1,0).Color=Color.sexy_purple
|
||||||
|
c.funcO={}
|
||||||
|
c.funcX={}
|
||||||
|
c:OnDragStart(function(self)
|
||||||
|
self:TopStack()
|
||||||
|
end)
|
||||||
|
--local temp = c:newTextButton("X","Close",-25,5,20,20,1)
|
||||||
|
--temp.Tween=-5
|
||||||
|
--temp.XTween=-2
|
||||||
|
--temp:OnReleased(function(b,self) for i=1,#self.Parent.funcX do self.Parent.funcX[i](self.Parent) end end)
|
||||||
|
--temp.Color=Color.Red
|
||||||
|
c.tLink=c:newTextBox("puttext","TextBox",5,h-95,-40,30,0,1,1,1)
|
||||||
|
c.tLink.Color=Color.light_gray
|
||||||
|
c.tLink.ClearOnFocus=true
|
||||||
|
c.tLink:OnFocus(function(self) self.ClearOnFocus=false end)
|
||||||
|
local temp=c:newTextButton("OK","Ok",-35,h-65,30,30,1,1)
|
||||||
|
temp:OnReleased(function(b,self) for i=1,#self.Parent.funcO do self.Parent.funcO[i](self.Parent,self.Parent.tLink.text) end end)
|
||||||
|
temp.Color=Color.Green
|
||||||
|
temp.XTween=-2
|
||||||
|
local temp=c:newTextButton("X","Cancel",-35,h-95,30,30,1,1)
|
||||||
|
temp:OnReleased(function(b,self) for i=1,#self.Parent.funcX do self.Parent.funcX[i](self.Parent,self.Parent.tLink.text) end end)
|
||||||
|
temp.Color=Color.Red
|
||||||
|
temp.XTween=-2
|
||||||
|
function c:Close()
|
||||||
|
self.Visible=false
|
||||||
|
end
|
||||||
|
function c:Open()
|
||||||
|
self.Visible=true
|
||||||
|
end
|
||||||
|
function c:OnOk(func)
|
||||||
|
table.insert(self.funcO,func)
|
||||||
|
end
|
||||||
|
function c:OnX(func)
|
||||||
|
table.insert(self.funcX,func)
|
||||||
|
end
|
||||||
|
return c
|
||||||
|
end
|
||||||
36
GuiManager/Misc/ApplyGradient.int
Normal file
36
GuiManager/Misc/ApplyGradient.int
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
function _GuiPro.gradient(colors)
|
||||||
|
local direction = colors.direction or "horizontal"
|
||||||
|
colors.direction=nil
|
||||||
|
trans = colors.trans or 255
|
||||||
|
trans=math.floor(trans)
|
||||||
|
if direction == "horizontal" then
|
||||||
|
direction = true
|
||||||
|
elseif direction == "vertical" then
|
||||||
|
direction = false
|
||||||
|
else
|
||||||
|
error("Invalid direction '" .. tostring(direction) "' for gradient. Horizontal or vertical expected.")
|
||||||
|
end
|
||||||
|
local result = love.image.newImageData(direction and 1 or #colors, direction and #colors or 1)
|
||||||
|
for __i, color in ipairs(colors) do
|
||||||
|
local x, y
|
||||||
|
if direction then
|
||||||
|
x, y = 0, __i - 1
|
||||||
|
else
|
||||||
|
x, y = __i - 1, 0
|
||||||
|
end
|
||||||
|
result:setPixel(x, y, color[1], color[2], color[3], trans)
|
||||||
|
end
|
||||||
|
result = love.graphics.newImage(result)
|
||||||
|
result:setFilter('linear', 'linear')
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
function _GuiPro.drawinrect(img, x, y, w, h, r, ox, oy, kx, ky)
|
||||||
|
love.graphics.draw(img, x, y, r, w / img:getWidth(), h / img:getHeight(), ox, oy, kx, ky)
|
||||||
|
end
|
||||||
|
function gui:ApplyGradient(rules)
|
||||||
|
self.Image=nil
|
||||||
|
self.Type=self.Type.."w/GradImage"
|
||||||
|
self.rotation=0
|
||||||
|
self.ImageVisibility=rules.visibility or 1
|
||||||
|
self:SetImage(_GuiPro.gradient(rules))
|
||||||
|
end
|
||||||
10
GuiManager/Misc/BottomStack.int
Normal file
10
GuiManager/Misc/BottomStack.int
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
function gui:BottomStack()
|
||||||
|
childs=self.Parent:getChildren()
|
||||||
|
for i=1,#childs do
|
||||||
|
if childs[i]==self then
|
||||||
|
table.remove(self.Parent.Children,i)
|
||||||
|
table.insert(self.Parent.Children,1,self)
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
4
GuiManager/Misc/Center.int
Normal file
4
GuiManager/Misc/Center.int
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
function gui:Center()
|
||||||
|
local x,y=self:getFullSize()
|
||||||
|
self:SetDualDim(-math.floor(x/2),-math.floor(y/2),nil,nil,.5,.5)
|
||||||
|
end
|
||||||
9
GuiManager/Misc/Destroy.int
Normal file
9
GuiManager/Misc/Destroy.int
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
function gui:Destroy()
|
||||||
|
check=self.Parent:getChildren()
|
||||||
|
local cc=0
|
||||||
|
for cc=1,#check do
|
||||||
|
if check[cc]==self then
|
||||||
|
table.remove(self.Parent.Children,cc)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
25
GuiManager/Misc/GetAllChildren.int
Normal file
25
GuiManager/Misc/GetAllChildren.int
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
function gui:GetAllChildren()
|
||||||
|
local Stuff = {}
|
||||||
|
function Seek(Items)
|
||||||
|
for i=1,#Items do
|
||||||
|
if Items[i].Visible==true then
|
||||||
|
table.insert(Stuff,Items[i])
|
||||||
|
local NItems = Items[i]:getChildren()
|
||||||
|
if NItems ~= nil then
|
||||||
|
Seek(NItems)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local Objs = self:getChildren()
|
||||||
|
for i=1,#Objs do
|
||||||
|
if Objs[i].Visible==true then
|
||||||
|
table.insert(Stuff,Objs[i])
|
||||||
|
local Items = Objs[i]:getChildren()
|
||||||
|
if Items ~= nil then
|
||||||
|
Seek(Items)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return Stuff
|
||||||
|
end
|
||||||
3
GuiManager/Misc/GetChild.int
Normal file
3
GuiManager/Misc/GetChild.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:GetChild(name)
|
||||||
|
return self.Children[name] or self
|
||||||
|
end
|
||||||
3
GuiManager/Misc/InGrid.int
Normal file
3
GuiManager/Misc/InGrid.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function InGrid(i,x,y,s)
|
||||||
|
return math.floor((i-1)/x)*s,(i-1)*s-(math.floor((i-1)/y)*(s*x))
|
||||||
|
end
|
||||||
5
GuiManager/Misc/InGridX.int
Normal file
5
GuiManager/Misc/InGridX.int
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
function InGridX(i,w,h,xs,ys)
|
||||||
|
local xc,yc=math.floor(w/xs),math.floor(h/ys)
|
||||||
|
local xi,yi=(i-1)%xc,math.floor((i-1)/xc)
|
||||||
|
return xi*xs,yi*ys
|
||||||
|
end
|
||||||
5
GuiManager/Misc/InGridY.int
Normal file
5
GuiManager/Misc/InGridY.int
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
function InGridY(i,w,h,xs,ys)
|
||||||
|
local xc,yc=math.floor(w/xs),math.floor(h/ys)
|
||||||
|
local xi,yi=math.floor((i-1)/yc),(i-1)%yc
|
||||||
|
return xi*xs,yi*ys
|
||||||
|
end
|
||||||
3
GuiManager/Misc/IsHovering.int
Normal file
3
GuiManager/Misc/IsHovering.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:IsHovering()
|
||||||
|
return (love.mouse.getX() > self.x and love.mouse.getX() < self.x+self.width and love.mouse.getY() > self.y and love.mouse.getY() < self.y+self.height)
|
||||||
|
end
|
||||||
4
GuiManager/Misc/Move.int
Normal file
4
GuiManager/Misc/Move.int
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
function gui:Move(x,y)
|
||||||
|
self.offset.pos.x=self.offset.pos.x+x
|
||||||
|
self.offset.pos.y=self.offset.pos.y+y
|
||||||
|
end
|
||||||
46
GuiManager/Misc/SetDualDim.int
Normal file
46
GuiManager/Misc/SetDualDim.int
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
function gui:SetDualDim(x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
if _GuiPro.DPI_ENABLED then
|
||||||
|
if x then
|
||||||
|
x=self.DPI*x
|
||||||
|
end
|
||||||
|
if y then
|
||||||
|
y=self.DPI*y
|
||||||
|
end
|
||||||
|
if w then
|
||||||
|
w=self.DPI*w
|
||||||
|
end
|
||||||
|
if h then
|
||||||
|
h=self.DPI*h
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if sx then
|
||||||
|
self.scale.pos.x=sx
|
||||||
|
end
|
||||||
|
if sy then
|
||||||
|
self.scale.pos.y=sy
|
||||||
|
end
|
||||||
|
if x then
|
||||||
|
self.offset.pos.x=x
|
||||||
|
end
|
||||||
|
if y then
|
||||||
|
self.offset.pos.y=y
|
||||||
|
end
|
||||||
|
if sw then
|
||||||
|
self.scale.size.x=sw
|
||||||
|
end
|
||||||
|
if sh then
|
||||||
|
self.scale.size.y=sh
|
||||||
|
end
|
||||||
|
if w then
|
||||||
|
self.offset.size.x=w
|
||||||
|
end
|
||||||
|
if h then
|
||||||
|
self.offset.size.y=h
|
||||||
|
end
|
||||||
|
if self.Image then
|
||||||
|
self:SetImage(self.Image)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function gui:setDualDim(...)
|
||||||
|
self:SetDualDim(...)
|
||||||
|
end
|
||||||
5
GuiManager/Misc/SetHand.int
Normal file
5
GuiManager/Misc/SetHand.int
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
_GuiPro.CursorN=love.mouse.getSystemCursor("arrow")
|
||||||
|
_GuiPro.CursorH=love.mouse.getSystemCursor("hand")
|
||||||
|
function gui:SetHand(img,x,y)
|
||||||
|
_GuiPro.CursorN=love.mouse.newCursor(img,x,y)
|
||||||
|
end
|
||||||
3
GuiManager/Misc/SetHover.int
Normal file
3
GuiManager/Misc/SetHover.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:SetHover(img,x,y)
|
||||||
|
_GuiPro.CursorH=love.mouse.newCursor(img,x,y)
|
||||||
|
end
|
||||||
4
GuiManager/Misc/SetName.int
Normal file
4
GuiManager/Misc/SetName.int
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
function gui:SetName(name)
|
||||||
|
self.Parent.Children[name]=self
|
||||||
|
self.Name=name
|
||||||
|
end
|
||||||
10
GuiManager/Misc/TopStack.int
Normal file
10
GuiManager/Misc/TopStack.int
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
function gui:TopStack()
|
||||||
|
childs=self.Parent:getChildren()
|
||||||
|
for i=1,#childs do
|
||||||
|
if childs[i]==self then
|
||||||
|
table.remove(self.Parent.Children,i)
|
||||||
|
table.insert(self.Parent.Children,self)
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
3
GuiManager/Misc/addDominance.int
Normal file
3
GuiManager/Misc/addDominance.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:addDominance()
|
||||||
|
_GuiPro.TopHovered=self
|
||||||
|
end
|
||||||
6
GuiManager/Misc/addHotKey.int
Normal file
6
GuiManager/Misc/addHotKey.int
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
function gui:addHotKey(key)
|
||||||
|
local temp=self:newFrame(0,0,0,0)
|
||||||
|
temp.Visible=false
|
||||||
|
temp:setHotKey(key)
|
||||||
|
return temp
|
||||||
|
end
|
||||||
7
GuiManager/Misc/alphanumsort.int
Normal file
7
GuiManager/Misc/alphanumsort.int
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
function alphanumsort(o)
|
||||||
|
local function padnum(d) local dec, n = string.match(d, "(%.?)0*(.+)")
|
||||||
|
return #dec > 0 and ("%.12f"):format(d) or ("%s%03d%s"):format(dec, #n, n)
|
||||||
|
end
|
||||||
|
table.sort(o, function(a,b) return tostring(a):gsub("%.?%d+",padnum)..("%3d"):format(#b)< tostring(b):gsub("%.?%d+",padnum)..("%3d"):format(#a) end)
|
||||||
|
return o
|
||||||
|
end
|
||||||
3
GuiManager/Misc/anchorRight.int
Normal file
3
GuiManager/Misc/anchorRight.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:anchorRight(n)
|
||||||
|
self:SetDualDim(-(self.width+n),nil,nil,nil,1)
|
||||||
|
end
|
||||||
3
GuiManager/Misc/centerX.int
Normal file
3
GuiManager/Misc/centerX.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:centerX()
|
||||||
|
self:SetDualDim(-(self.width/2),nil,nil,nil,.5)
|
||||||
|
end
|
||||||
3
GuiManager/Misc/centerY.int
Normal file
3
GuiManager/Misc/centerY.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:centerY()
|
||||||
|
self:SetDualDim(nil,-(self.height/2),nil,nil,nil,.5)
|
||||||
|
end
|
||||||
3
GuiManager/Misc/disrespectHierarchy.int
Normal file
3
GuiManager/Misc/disrespectHierarchy.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:disrespectHierarchy()
|
||||||
|
_GuiPro.Hierarchy=false
|
||||||
|
end
|
||||||
3
GuiManager/Misc/getChildren.int
Normal file
3
GuiManager/Misc/getChildren.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:getChildren()
|
||||||
|
return self.Children
|
||||||
|
end
|
||||||
3
GuiManager/Misc/getColor.int
Normal file
3
GuiManager/Misc/getColor.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:getColor(cindex)
|
||||||
|
return Color[cindex]
|
||||||
|
end
|
||||||
12
GuiManager/Misc/getFullSize.int
Normal file
12
GuiManager/Misc/getFullSize.int
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
function gui:getFullSize()
|
||||||
|
local maxx,maxy=-math.huge,-math.huge
|
||||||
|
local temp = self:GetAllChildren()
|
||||||
|
for i=1,#temp do
|
||||||
|
if temp[i].width>maxx then
|
||||||
|
maxx=temp[i].width+temp[i].offset.pos.x
|
||||||
|
elseif temp[i].height>maxy then
|
||||||
|
maxy=temp[i].height+temp[i].offset.pos.y
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return maxx,maxy
|
||||||
|
end
|
||||||
5
GuiManager/Misc/getHighest.int
Normal file
5
GuiManager/Misc/getHighest.int
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
function gui:getHighest()
|
||||||
|
if self.Children[#self.Children]~=nil then
|
||||||
|
return self.Children[#self.Children]
|
||||||
|
end
|
||||||
|
end
|
||||||
5
GuiManager/Misc/getLowest.int
Normal file
5
GuiManager/Misc/getLowest.int
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
function gui:getLowest()
|
||||||
|
if self.Children[1]~=nil then
|
||||||
|
return self.Children[1]
|
||||||
|
end
|
||||||
|
end
|
||||||
9
GuiManager/Misc/isDescendant.int
Normal file
9
GuiManager/Misc/isDescendant.int
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
function gui:isDescendant(obj)
|
||||||
|
local things=obj:GetAllChildren()
|
||||||
|
for i=1,#things do
|
||||||
|
if things[i]==self then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
3
GuiManager/Misc/isHighest.int
Normal file
3
GuiManager/Misc/isHighest.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:isHighest()
|
||||||
|
return (self==self.Parent:getHighest())
|
||||||
|
end
|
||||||
3
GuiManager/Misc/isLowest.int
Normal file
3
GuiManager/Misc/isLowest.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:isLowest()
|
||||||
|
return (self==self.Parent:getLowest())
|
||||||
|
end
|
||||||
6
GuiManager/Misc/massMutate.int
Normal file
6
GuiManager/Misc/massMutate.int
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
function gui.massMutate(t,...)
|
||||||
|
local mut={...}
|
||||||
|
for i=1,#mut do
|
||||||
|
mut[i]:Mutate(t)
|
||||||
|
end
|
||||||
|
end
|
||||||
41
GuiManager/Misc/newCheckBox.int
Normal file
41
GuiManager/Misc/newCheckBox.int
Normal file
@ -0,0 +1,41 @@
|
|||||||
|
if love.filesystem.exists("CheckBoxes.png") then
|
||||||
|
_GuiPro.UC=gui:getTile("CheckBoxes.png",0,0,16,16)
|
||||||
|
_GuiPro.C=gui:getTile("CheckBoxes.png",16,0,16,16)
|
||||||
|
_GuiPro.UCH=gui:getTile("CheckBoxes.png",0,16,16,16)
|
||||||
|
_GuiPro.CH=gui:getTile("CheckBoxes.png",16,16,16,16)
|
||||||
|
end
|
||||||
|
function gui:newCheckBox(name,x,y)
|
||||||
|
if not(_GuiPro.UC) then error("CheckBoxes.png not found! Cannot currently use checkbox without the data") end
|
||||||
|
if type(name)~="String" then
|
||||||
|
x,y,name=name,x,"CheckBox"
|
||||||
|
end
|
||||||
|
local c=self:newImageLabel(_GuiPro.UC,name, x, y, 16,16)
|
||||||
|
c.Visibility=0
|
||||||
|
c.check=false
|
||||||
|
c:OnEnter(function(self)
|
||||||
|
if self.check then
|
||||||
|
self:SetImage(_GuiPro.CH)
|
||||||
|
else
|
||||||
|
self:SetImage(_GuiPro.UCH)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
function c:isChecked()
|
||||||
|
return self.check
|
||||||
|
end
|
||||||
|
c:OnExit(function(self)
|
||||||
|
if self.check then
|
||||||
|
self:SetImage(_GuiPro.C)
|
||||||
|
else
|
||||||
|
self:SetImage(_GuiPro.UC)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
c:OnReleased(function(b,self)
|
||||||
|
self.check=not(self.check)
|
||||||
|
if self.check then
|
||||||
|
self:SetImage(_GuiPro.CH)
|
||||||
|
else
|
||||||
|
self:SetImage(_GuiPro.UCH)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
return c
|
||||||
|
end
|
||||||
36
GuiManager/Misc/newMessageBox.int
Normal file
36
GuiManager/Misc/newMessageBox.int
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
function gui:newMessageBox(txt,x,y,w,h,sx,sy,sw,sh)
|
||||||
|
name="MessageBox"
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("MessageBoxFrame",name, x, y, w, 30, sx ,sy ,sw ,sh)
|
||||||
|
c.Draggable=true
|
||||||
|
c.dragbut="r"
|
||||||
|
c:ApplyGradient{Color.Blue,Color.sexy_purple}
|
||||||
|
c.BorderSize=0
|
||||||
|
c:newTextLabel(txt,"Holder",0,0,0,h-30,0,1,1,0).Color=Color.sexy_purple
|
||||||
|
c.funcO={}
|
||||||
|
c.funcX={}
|
||||||
|
c:OnDragStart(function(self)
|
||||||
|
self:TopStack()
|
||||||
|
end)
|
||||||
|
local temp = c:newTextButton("X","Close",-25,5,20,20,1)
|
||||||
|
temp.Tween=-5
|
||||||
|
temp.XTween=-2
|
||||||
|
temp:OnReleased(function(b,self) for i=1,#self.Parent.funcX do self.Parent.funcX[i](self.Parent) end end)
|
||||||
|
temp.Color=Color.Red
|
||||||
|
local temp=c:newTextButton("OK","Ok",0,h-65,0,30,.25,1,.5)
|
||||||
|
temp:OnReleased(function(b,self) for i=1,#self.Parent.funcO do self.Parent.funcO[i](self.Parent) end end)
|
||||||
|
temp.Color=Color.Green
|
||||||
|
function c:Close()
|
||||||
|
self.Visible=false
|
||||||
|
end
|
||||||
|
function c:Open()
|
||||||
|
self.Visible=true
|
||||||
|
end
|
||||||
|
function c:OnOk(func)
|
||||||
|
table.insert(self.funcO,func)
|
||||||
|
end
|
||||||
|
function c:OnX(func)
|
||||||
|
table.insert(self.funcX,func)
|
||||||
|
end
|
||||||
|
return c
|
||||||
|
end
|
||||||
49
GuiManager/Misc/newPart.int
Normal file
49
GuiManager/Misc/newPart.int
Normal file
@ -0,0 +1,49 @@
|
|||||||
|
function gui:newPart(x, y,w ,h , sx ,sy ,sw ,sh)
|
||||||
|
local c = {}
|
||||||
|
setmetatable(c, gui)
|
||||||
|
if self==gui then
|
||||||
|
c.Parent=_GuiPro
|
||||||
|
else
|
||||||
|
c.Parent=self
|
||||||
|
end
|
||||||
|
c.funcs={}
|
||||||
|
c.funcs2={}
|
||||||
|
c.funcs3={}
|
||||||
|
c.funcs4={}
|
||||||
|
c.funcs5={}
|
||||||
|
c.func6={}
|
||||||
|
c.func7={}
|
||||||
|
c.func8={}
|
||||||
|
c.func9={}
|
||||||
|
c.func10={}
|
||||||
|
c.form="rectangle"
|
||||||
|
c.Color = {255, 255, 255}
|
||||||
|
c.scale={}
|
||||||
|
c.scale.size={}
|
||||||
|
c.scale.size.x=sw or 0
|
||||||
|
c.scale.size.y=sh or 0
|
||||||
|
c.offset={}
|
||||||
|
c.offset.size={}
|
||||||
|
c.offset.size.x=w or 0
|
||||||
|
c.offset.size.y=h or 0
|
||||||
|
c.scale.pos={}
|
||||||
|
c.scale.pos.x=sx or 0
|
||||||
|
c.scale.pos.y=sy or 0
|
||||||
|
c.offset.pos={}
|
||||||
|
c.offset.pos.x=x or 0
|
||||||
|
c.offset.pos.y=y or 0
|
||||||
|
c.VIS=true
|
||||||
|
c.Visible=true
|
||||||
|
c.Visibility=1
|
||||||
|
c.BorderColor={0,0,0}
|
||||||
|
c.BorderSize=0
|
||||||
|
c.Type="Part"
|
||||||
|
c.Name="GuiPart"
|
||||||
|
_GuiPro.count=_GuiPro.count+1
|
||||||
|
c.x=(c.Parent.width*c.scale.pos.x)+c.offset.pos.x+c.Parent.x
|
||||||
|
c.y=(c.Parent.height*c.scale.pos.y)+c.offset.pos.y+c.Parent.y
|
||||||
|
c.width=(c.Parent.width*c.scale.size.x)+c.offset.size.x
|
||||||
|
c.height=(c.Parent.height*c.scale.size.y)+c.offset.size.y
|
||||||
|
table.insert(c.Parent.Children,c)
|
||||||
|
return c
|
||||||
|
end
|
||||||
45
GuiManager/Misc/newProgressBar.int
Normal file
45
GuiManager/Misc/newProgressBar.int
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
function gui:newProgressBar(txt,x,y,w,h,sx,sy,sw,sh)
|
||||||
|
name="newProgressBar"
|
||||||
|
x,y,w,h,sx,sy,sw,sh=filter(name, x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local c=self:newBase("newProgressBarFrame",name, x, y, w, 30, sx ,sy ,sw ,sh)
|
||||||
|
c.Draggable=true
|
||||||
|
c.dragbut="r"
|
||||||
|
c.BorderSize=0
|
||||||
|
c:ApplyGradient{Color.Blue,Color.sexy_purple}
|
||||||
|
c:newTextLabel(txt,"Holder",0,0,0,h-30,0,1,1,0).Color=Color.sexy_purple
|
||||||
|
c.funcO={}
|
||||||
|
c.funcX={}
|
||||||
|
c:OnDragStart(function(self)
|
||||||
|
self:TopStack()
|
||||||
|
end)
|
||||||
|
local temp = c:newTextButton("X","Close",-25,5,20,20,1)
|
||||||
|
temp.Tween=-5
|
||||||
|
temp.XTween=-2
|
||||||
|
temp:OnReleased(function(b,self) for i=1,#self.Parent.funcX do self.Parent.funcX[i](self.Parent) end end)
|
||||||
|
temp.Color=Color.Red
|
||||||
|
c.BarBG=c:newTextButton("",5,h-65,-10,30,0,1,1)
|
||||||
|
c.BarBG:ApplyGradient{Color.Red,Color.light_red}
|
||||||
|
c.Bar=c.BarBG:newTextLabel("",0,0,0,0,0,0,0,1)
|
||||||
|
c.Bar:ApplyGradient{Color.Green,Color.light_green}
|
||||||
|
c.BarDisp=c.BarBG:newTextLabel("0%","0%",0,0,0,0,0,0,1,1)
|
||||||
|
c.BarDisp.Visibility=0
|
||||||
|
c.BarDisp.Link=c.Bar
|
||||||
|
c.BarDisp:OnUpdate(function(self)
|
||||||
|
self.text=self.Link.scale.size.x*100 .."%"
|
||||||
|
end)
|
||||||
|
c.Func1={}
|
||||||
|
function c:On100(func)
|
||||||
|
table.insert(self.Func1,func)
|
||||||
|
end
|
||||||
|
c:OnUpdate(function(self)
|
||||||
|
if self.Bar.scale.size.x*100>=100 then
|
||||||
|
for P=1,#self.Func1 do
|
||||||
|
self.Func1[P](self)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
function c:SetPercentage(n)
|
||||||
|
self.Bar:SetDualDim(0,0,0,0,0,0,n/100,1)
|
||||||
|
end
|
||||||
|
return c
|
||||||
|
end
|
||||||
42
GuiManager/Misc/newScrollBar.int
Normal file
42
GuiManager/Misc/newScrollBar.int
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
function gui:newScrollBar(color1,color2)
|
||||||
|
local scrollbar=self:newFrame(-20,0,20,0,1,0,0,1)
|
||||||
|
scrollbar.funcS={}
|
||||||
|
scrollbar.Color=color1 or Color.saddle_brown
|
||||||
|
scrollbar:OnClicked(function(b,self,x,y)
|
||||||
|
love.mouse.setX(self.x+10)
|
||||||
|
if y>=10 and y<=self.height-10 then
|
||||||
|
self.mover:SetDualDim(0,y-10)
|
||||||
|
end
|
||||||
|
if y<10 then
|
||||||
|
love.mouse.setY(10+self.y)
|
||||||
|
end
|
||||||
|
if y>self.height-10 then
|
||||||
|
love.mouse.setY((self.height-10)+self.y)
|
||||||
|
end
|
||||||
|
for i=1,#self.funcS do
|
||||||
|
self.funcS[i](self,self:getPosition())
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
scrollbar:OnEnter(function(self)
|
||||||
|
self:addDominance()
|
||||||
|
end)
|
||||||
|
scrollbar:OnExit(function(self)
|
||||||
|
self:removeDominance()
|
||||||
|
end)
|
||||||
|
scrollbar.mover=scrollbar:newTextButton("","",0,0,20,20)
|
||||||
|
scrollbar.mover.Color=color2 or Color.light_brown
|
||||||
|
function scrollbar:getPosition()
|
||||||
|
return ((self.mover.offset.pos.y)/(self.height-20))*100
|
||||||
|
end
|
||||||
|
function scrollbar:setPosition(n)
|
||||||
|
print((self.height-20),n)
|
||||||
|
self.mover.offset.pos.y=((self.height-20)/(100/n))
|
||||||
|
for i=1,#self.funcS do
|
||||||
|
self.funcS[i](self,self:getPosition())
|
||||||
|
end
|
||||||
|
end
|
||||||
|
function scrollbar:OnScroll(func)
|
||||||
|
table.insert(self.funcS,func)
|
||||||
|
end
|
||||||
|
return scrollbar
|
||||||
|
end
|
||||||
98
GuiManager/Misc/newScrollMenu.int
Normal file
98
GuiManager/Misc/newScrollMenu.int
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
function gui:newScrollMenu(title,tabN,onloop,x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local Main = self:newFrame(x, y, w, h, sx ,sy ,sw ,sh)
|
||||||
|
local Title=Main:newTextButton(title,"Title",0,0,0,20,0,0,1)
|
||||||
|
Title.Tween=-4
|
||||||
|
Title.FontSize=12
|
||||||
|
Title:OnReleased(function(b,self)
|
||||||
|
self.Parent.Tick=not(self.Parent.Tick)
|
||||||
|
end)
|
||||||
|
local scroll=Main:newTextButton("","Scroll",-20,20,20,-20,1,0,0,1)
|
||||||
|
scroll:OnClicked(function(b,self,x,y)
|
||||||
|
self.Parent.Mover:SetDualDim(0,y-10,20,20)
|
||||||
|
if self.Parent.Mover.offset.pos.y<0 then
|
||||||
|
self.Parent.Mover:SetDualDim(0,0,20,20)
|
||||||
|
end
|
||||||
|
if self.Parent.Mover.offset.pos.y>self.Parent.height-40 then
|
||||||
|
self.Parent.Mover:SetDualDim(0,self.Parent.height-40,20,20)
|
||||||
|
end
|
||||||
|
local temp = #self.Parent.TList
|
||||||
|
self.Parent.pos=(math.floor((temp*self.Parent.Mover.offset.pos.y)/self.height))+1
|
||||||
|
end)
|
||||||
|
Main:OnUpdate(function(self)
|
||||||
|
if self.Tick==false then
|
||||||
|
self.Visibility=0
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
scroll:OnUpdate(function(self)
|
||||||
|
self.Visible=self.Parent.Tick
|
||||||
|
end)
|
||||||
|
local Mover=scroll:newTextLabel("",0,0,20,20)
|
||||||
|
Main.Mover=Mover
|
||||||
|
Main.TList=tabN
|
||||||
|
Main.pos=1
|
||||||
|
Main.Tick=true
|
||||||
|
function Main:Update(title,tabN,onloop)
|
||||||
|
ch=self:getChildren()
|
||||||
|
for i=#ch,1,-1 do
|
||||||
|
ch[i]:Destroy()
|
||||||
|
end
|
||||||
|
Title=Main:newTextButton(title,"Title",0,0,0,20,0,0,1)
|
||||||
|
Title.Tween=-4
|
||||||
|
Title.FontSize=12
|
||||||
|
Title:OnReleased(function(b,self)
|
||||||
|
self.Parent.Tick=not(self.Parent.Tick)
|
||||||
|
end)
|
||||||
|
scroll=Main:newTextButton("","Scroll",-20,20,20,-20,1,0,0,1)
|
||||||
|
scroll:OnClicked(function(b,self,x,y)
|
||||||
|
self.Parent.Mover:SetDualDim(0,y-10,20,20)
|
||||||
|
if self.Parent.Mover.offset.pos.y<0 then
|
||||||
|
self.Parent.Mover:SetDualDim(0,0,20,20)
|
||||||
|
end
|
||||||
|
if self.Parent.Mover.offset.pos.y>self.Parent.height-40 then
|
||||||
|
self.Parent.Mover:SetDualDim(0,self.Parent.height-40,20,20)
|
||||||
|
end
|
||||||
|
local temp = #self.Parent.TList
|
||||||
|
self.Parent.pos=(math.floor((temp*self.Parent.Mover.offset.pos.y)/self.height))+1
|
||||||
|
end)
|
||||||
|
local Mover=scroll:newTextLabel("",0,0,20,20)
|
||||||
|
Main.Mover=Mover
|
||||||
|
Main.TList=tabN
|
||||||
|
Main.pos=1
|
||||||
|
Main.Tick=true
|
||||||
|
scroll:OnUpdate(function(self)
|
||||||
|
self.Visible=self.Parent.Tick
|
||||||
|
end)
|
||||||
|
for i=1,math.floor(Main.height/20)-1 do
|
||||||
|
local temp=Main:newTextButton("","Item"..i,0,i*20,-20,20,0,0,1)
|
||||||
|
temp.FontSize=10
|
||||||
|
temp.Tween=-4
|
||||||
|
temp.pos=i
|
||||||
|
temp:OnUpdate(function(self)
|
||||||
|
self.text=self.Parent.TList[(self.Parent.pos+self.pos)-1]
|
||||||
|
self.Visible=self.Parent.Tick
|
||||||
|
end)
|
||||||
|
if onloop then
|
||||||
|
onloop(temp,i)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
io.write(tostring(Main.height).."\n")
|
||||||
|
for i=1,math.floor(Main.height/20)-1 do
|
||||||
|
local temp=Main:newTextButton("Item"..i,0,i*20,-20,20,0,0,1)
|
||||||
|
temp.FontSize=10
|
||||||
|
temp.Tween=-4
|
||||||
|
temp.pos=i
|
||||||
|
temp:OnUpdate(function(self)
|
||||||
|
if self.Parent.TList[(self.Parent.pos+self.pos)-1]~=nil then
|
||||||
|
self.text=self.Parent.TList[(self.Parent.pos+self.pos)-1]
|
||||||
|
else
|
||||||
|
self.text=""
|
||||||
|
end
|
||||||
|
self.Visible=self.Parent.Tick
|
||||||
|
end)
|
||||||
|
if onloop then
|
||||||
|
onloop(temp,i)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return Main
|
||||||
|
end
|
||||||
6
GuiManager/Misc/removeAllChildren.int
Normal file
6
GuiManager/Misc/removeAllChildren.int
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
function gui:destroyAllChildren()
|
||||||
|
local c=self.Children
|
||||||
|
for i=1,#c do
|
||||||
|
c[i]:Destroy()
|
||||||
|
end
|
||||||
|
end
|
||||||
3
GuiManager/Misc/removeDominance.int
Normal file
3
GuiManager/Misc/removeDominance.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:removeDominance()
|
||||||
|
_GuiPro.TopHovered=nil
|
||||||
|
end
|
||||||
3
GuiManager/Misc/respectHierarchy.int
Normal file
3
GuiManager/Misc/respectHierarchy.int
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
function gui:respectHierarchy()
|
||||||
|
_GuiPro.Hierarchy=true
|
||||||
|
end
|
||||||
4
GuiManager/Misc/round.int
Normal file
4
GuiManager/Misc/round.int
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
function gui.round(num, idp)
|
||||||
|
local mult = 10^(idp or 0)
|
||||||
|
return math.floor(num * mult + 0.5) / mult
|
||||||
|
end
|
||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user