2007-02-04 01:16:06 +00:00
|
|
|
|
2007-02-04 03:03:09 +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
|
2007-03-22 03:27:52 +00:00
|
|
|
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
|
|
|
|
}
|