UltimateZoneBuilder/Source/Plugins/BuilderModes/ErrorChecks/ResultMissingTexture.cs
2017-01-15 00:35:40 +02:00

137 lines
4.1 KiB
C#
Executable file

#region ================== Copyright (c) 2007 Pascal vd Heiden
/*
* Copyright (c) 2007 Pascal vd Heiden, www.codeimp.com
* This program is released under GNU General Public License
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
*/
#endregion
#region ================== Namespaces
using System;
using CodeImp.DoomBuilder.Map;
using CodeImp.DoomBuilder.Rendering;
#endregion
namespace CodeImp.DoomBuilder.BuilderModes
{
public class ResultMissingTexture : ErrorResult
{
#region ================== Variables
private readonly Sidedef side;
private readonly SidedefPart part;
private static string imagename = "-"; //mxd
#endregion
#region ================== Properties
public override int Buttons { get { return 2; } }
public override string Button1Text { get { return "Add Default Texture"; } }
public override string Button2Text { get { return "Browse Texture..."; } } //mxd
#endregion
#region ================== Constructor / Destructor
// Constructor
public ResultMissingTexture(Sidedef sd, SidedefPart part)
{
// Initialize
this.side = sd;
this.part = part;
this.viewobjects.Add(sd);
this.hidden = sd.IgnoredErrorChecks.Contains(this.GetType()); //mxd
imagename = "-"; //mxd
this.description = "This sidedef is missing a texture where it is required and could cause a 'Hall Of Mirrors' visual problem in the map.";
}
#endregion
#region ================== Methods
// This sets if this result is displayed in ErrorCheckForm (mxd)
internal override void Hide(bool hide)
{
hidden = hide;
Type t = this.GetType();
if(hide) side.IgnoredErrorChecks.Add(t);
else if(side.IgnoredErrorChecks.Contains(t)) side.IgnoredErrorChecks.Remove(t);
}
// This must return the string that is displayed in the listbox
public override string ToString()
{
string sidestr = side.IsFront ? "front" : "back";
switch(part)
{
case SidedefPart.Upper:
return "Linedef " + side.Line.Index + " has missing upper texture (" + sidestr + " side)";
case SidedefPart.Middle:
return "Linedef " + side.Line.Index + " has missing middle texture (" + sidestr + " side)";
case SidedefPart.Lower:
return "Linedef " + side.Line.Index + " has missing lower texture (" + sidestr + " side)";
default:
return "ERROR";
}
}
// Rendering
public override void PlotSelection(IRenderer2D renderer)
{
renderer.PlotLinedef(side.Line, General.Colors.Selection);
renderer.PlotVertex(side.Line.Start, ColorCollection.VERTICES);
renderer.PlotVertex(side.Line.End, ColorCollection.VERTICES);
}
// Fix by setting default texture
public override bool Button1Click(bool batchMode)
{
if(!batchMode) General.Map.UndoRedo.CreateUndo("Missing texture correction");
General.Settings.FindDefaultDrawSettings();
switch(part)
{
case SidedefPart.Upper: side.SetTextureHigh(General.Map.Options.DefaultTopTexture); break;
case SidedefPart.Middle: side.SetTextureMid(General.Map.Options.DefaultWallTexture); break;
case SidedefPart.Lower: side.SetTextureLow(General.Map.Options.DefaultBottomTexture); break;
}
General.Map.Map.Update();
return true;
}
//mxd. Fix by picking a texture
public override bool Button2Click(bool batchMode)
{
if(!batchMode) General.Map.UndoRedo.CreateUndo("Missing texture correction");
if(imagename == "-") imagename = General.Interface.BrowseTexture(General.Interface, imagename);
if(imagename == "-") return false;
switch(part)
{
case SidedefPart.Upper: side.SetTextureHigh(imagename); break;
case SidedefPart.Middle: side.SetTextureMid(imagename); break;
case SidedefPart.Lower: side.SetTextureLow(imagename); break;
}
General.Map.Map.Update();
return true;
}
#endregion
}
}