wiremod-svn-archive/wire/lua/weapons/gmod_tool/stools/wire_gate_comparison.lua

219 lines
5.7 KiB
Lua
Raw Normal View History

2007-02-04 01:16:06 +00:00
TOOL.Category = "Wire - Control"
2007-02-04 01:16:06 +00:00
TOOL.Name = "Gate - Comparison"
TOOL.Command = nil
TOOL.ConfigName = ""
if ( CLIENT ) then
language.Add( "Tool_wire_gate_comparison_name", "Comparison Gate Tool (Wire)" )
language.Add( "Tool_wire_gate_comparison_desc", "Spawns a comparison gate for use with the wire system." )
language.Add( "Tool_wire_gate_comparison_0", "Primary: Create/Update Comparison Gate" )
language.Add( "WireGateComparisonTool_action", "Action:" )
2007-02-04 07:34:07 +00:00
language.Add( "WireGateComparisonTool_model", "Model:" )
2007-02-04 01:16:06 +00:00
language.Add( "sboxlimit_wire_gate_comparisons", "You've hit comparison gates limit!" )
language.Add( "undone_wiregatecomparison", "Undone Wire Comparison Gate" )
end
if (SERVER) then
CreateConVar('sbox_maxwire_gate_comparisons', 30)
end
TOOL.ClientConVar[ "action" ] = "<"
2007-02-05 10:52:02 +00:00
TOOL.ClientConVar[ "model" ] = "models/jaanus/wiretool/wiretool_gate.mdl"
2007-02-04 01:16:06 +00:00
2007-02-05 10:52:02 +00:00
if (SERVER) then
ModelPlug_Register("gate")
end
2007-02-04 01:16:06 +00:00
cleanup.Register( "wire_gate_comparisons" )
function TOOL:LeftClick( trace )
if (!trace.HitPos) then return false end
if (trace.Entity:IsPlayer()) then return false end
if ( CLIENT ) then return true end
local ply = self:GetOwner()
// Get client's CVars
local action = self:GetClientInfo( "action" )
2007-02-04 07:34:07 +00:00
local model = self:GetClientInfo( "model" )
2007-02-04 01:16:06 +00:00
if ( trace.Entity:IsValid() && trace.Entity:GetClass() == "gmod_wire_gate" && trace.Entity.pl == ply ) then
trace.Entity:Setup( GateActions[action] )
trace.Entity:GetTable().action = action
return true
end
if ( !self:GetSWEP():CheckLimit( "wire_gate_comparisons" ) ) then return false end
local Ang = trace.HitNormal:Angle()
Ang.pitch = Ang.pitch + 90
2007-02-04 07:34:07 +00:00
local wire_gate_comparison = MakeWireGate( ply, trace.HitPos, Ang, model, action )
2007-02-04 01:16:06 +00:00
local min = wire_gate_comparison:OBBMins()
wire_gate_comparison:SetPos( trace.HitPos - trace.HitNormal * min.z )
local const, nocollide
// Don't weld to world
if ( trace.Entity:IsValid() ) then
const = constraint.Weld( wire_gate_comparison, trace.Entity, 0, trace.PhysicsBone, 0, true, true )
2007-02-04 01:16:06 +00:00
// Don't disable collision if it's not attached to anything
wire_gate_comparison:GetPhysicsObject():EnableCollisions( false )
wire_gate_comparison.nocollide = true
end
undo.Create("WireGateComparison")
undo.AddEntity( wire_gate_comparison )
undo.AddEntity( const )
undo.SetPlayer( ply )
undo.Finish()
ply:AddCleanup( "wire_gate_comparisons", wire_gate_comparison )
return true
end
function TOOL:RightClick( trace )
return self:LeftClick( trace )
end
function TOOL:UpdateGhostWireGateComparison( ent, player )
if ( !ent || !ent:IsValid() ) then return end
local tr = utilx.GetPlayerTrace( player, player:GetCursorAimVector() )
local trace = util.TraceLine( tr )
if (!trace.Hit || trace.Entity:IsPlayer() || trace.Entity:GetClass() == "gmod_wire_gate" ) then
ent:SetNoDraw( true )
return
end
local Ang = trace.HitNormal:Angle()
Ang.pitch = Ang.pitch + 90
local min = ent:OBBMins()
ent:SetPos( trace.HitPos - trace.HitNormal * min.z )
ent:SetAngles( Ang )
ent:SetNoDraw( false )
end
function TOOL:Think()
2007-02-04 07:34:07 +00:00
if (!self.GhostEntity || !self.GhostEntity:IsValid() || self.GhostEntity:GetModel() != self:GetClientInfo( "model" )) then
self:MakeGhostEntity( self:GetClientInfo( "model" ), Vector(0,0,0), Angle(0,0,0) )
2007-02-04 01:16:06 +00:00
end
self:UpdateGhostWireGateComparison( self.GhostEntity, self:GetOwner() )
end
function TOOL.BuildCPanel(panel)
panel:AddControl("Header", { Text = "#Tool_wire_gate_comparison_name", Description = "#Tool_wire_gate_comparison_desc" })
local Actions = {
Label = "#WireGateComparisonTool_action",
MenuButton = "0",
2007-02-12 18:50:46 +00:00
Height = 180,
2007-02-04 01:16:06 +00:00
Options = {}
}
for k,v in pairs(GateActions) do
if(v.group == "Comparison") then
Actions.Options[v.name or "No Name"] = { wire_gate_comparison_action = k }
end
end
panel:AddControl("ListBox", Actions)
2007-02-04 07:34:07 +00:00
ModelPlug_AddToCPanel(panel, "gate", "wire_gate_comparison", "#WireGateComparisonTool_model", nil, "#WireGateComparisonTool_model")
2007-02-04 01:16:06 +00:00
end
GateActions = GateActions or {}
GateActions["="] = {
group = "Comparison",
name = "Equal",
inputs = { "A", "B" },
output = function(gate, A, B)
if (math.abs(A-B) < 0.001) then return 1 end
return 0
end,
label = function(Out, A, B)
return A.." == "..B.." = "..Out
end
}
2007-02-24 10:31:25 +00:00
GateActions["!="] = {
2007-02-04 01:16:06 +00:00
group = "Comparison",
name = "Not Equal",
inputs = { "A", "B" },
output = function(gate, A, B)
if (math.abs(A-B) < 0.001) then return 0 end
return 1
end,
label = function(Out, A, B)
return A.." ~= "..B.." = "..Out
end
}
GateActions["<"] = {
group = "Comparison",
name = "Less Than",
inputs = { "A", "B" },
output = function(gate, A, B)
if (A < B) then return 1 end
return 0
end,
label = function(Out, A, B)
return A.." < "..B.." = "..Out
end
}
GateActions[">"] = {
group = "Comparison",
2007-02-24 10:31:25 +00:00
name = "Greater Then",
2007-02-04 01:16:06 +00:00
inputs = { "A", "B" },
output = function(gate, A, B)
if (A > B) then return 1 end
return 0
end,
label = function(Out, A, B)
return A.." > "..B.." = "..Out
end
}
GateActions["<="] = {
group = "Comparison",
name = "Less or Equal",
inputs = { "A", "B" },
output = function(gate, A, B)
if (A <= B) then return 1 end
return 0
end,
label = function(Out, A, B)
return A.." <= "..B.." = "..Out
end
}
GateActions[">="] = {
group = "Comparison",
name = "Greater or Equal",
inputs = { "A", "B" },
output = function(gate, A, B)
if (A >= B) then return 1 end
return 0
end,
label = function(Out, A, B)
return A.." >= "..B.." = "..Out
end
}