mirror of
https://git.do.srb2.org/STJr/UltimateZoneBuilder.git
synced 2025-01-19 06:51:09 +00:00
Doom/Hexen map formats: texture offsets of walls can now be edited properly in GZDoom Visual mode.
This commit is contained in:
parent
c0c36eabbc
commit
082bb87c3c
9 changed files with 64 additions and 131 deletions
|
@ -273,8 +273,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
mode.Renderer.ShowSelection = false;
|
||||
mode.Renderer.ShowHighlight = false;
|
||||
UpdateDragUV();
|
||||
} else {
|
||||
General.ShowErrorMessage(BaseVisualMode.TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -488,7 +486,9 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
// Texture offset change
|
||||
public virtual void OnChangeTextureOffset(int horizontal, int vertical)
|
||||
{
|
||||
if((General.Map.UndoRedo.NextUndo == null) || (General.Map.UndoRedo.NextUndo.TicketID != undoticket))
|
||||
//mxd
|
||||
if (General.Map.UDMF) {
|
||||
if ((General.Map.UndoRedo.NextUndo == null) || (General.Map.UndoRedo.NextUndo.TicketID != undoticket))
|
||||
undoticket = mode.CreateUndo("Change texture offsets");
|
||||
|
||||
// Apply offsets
|
||||
|
@ -499,6 +499,9 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
// Update sector geometry
|
||||
Sector.UpdateSectorGeometry(false);
|
||||
Sector.Rebuild();
|
||||
} else {
|
||||
General.ShowErrorMessage("Floor/ceiling texture offsets cannot be changed in this map format!", MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
#endregion
|
||||
|
|
|
@ -869,7 +869,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
float deltaz = General.Map.VisualCamera.AngleZ - dragstartanglez;
|
||||
if((Math.Abs(deltaxy) + Math.Abs(deltaz)) > DRAG_ANGLE_TOLERANCE)
|
||||
{
|
||||
if(General.Map.UDMF) { //mxd
|
||||
mode.PreAction(UndoGroup.TextureOffsetChange);
|
||||
mode.CreateUndo("Change texture offsets");
|
||||
|
||||
|
@ -878,9 +877,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
mode.Renderer.ShowSelection = false;
|
||||
mode.Renderer.ShowHighlight = false;
|
||||
UpdateDragUV();
|
||||
} else {
|
||||
General.ShowErrorMessage(BaseVisualMode.TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -957,10 +953,18 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
if((General.Map.UndoRedo.NextUndo == null) || (General.Map.UndoRedo.NextUndo.TicketID != undoticket))
|
||||
undoticket = mode.CreateUndo("Change texture offsets");
|
||||
|
||||
// Apply offsets
|
||||
//mxd
|
||||
if (General.Map.UDMF) {
|
||||
// Apply UDMF offsets
|
||||
MoveTextureOffset(new Point(-horizontal, -vertical));
|
||||
|
||||
mode.SetActionResult("Changed texture offsets by " + -horizontal + ", " + -vertical + ".");
|
||||
Point p = GetTextureOffset();
|
||||
mode.SetActionResult("Changed texture offsets to " + p.X + ", " + p.Y + ".");
|
||||
} else {
|
||||
// Apply classic offsets
|
||||
Sidedef.OffsetX -= horizontal;
|
||||
Sidedef.OffsetY -= vertical;
|
||||
mode.SetActionResult("Changed texture offsets to " + Sidedef.OffsetX + ", " + Sidedef.OffsetY + ".");
|
||||
}
|
||||
|
||||
// Update sidedef geometry
|
||||
VisualSidedefParts parts = Sector.GetSidedefParts(Sidedef);
|
||||
|
|
|
@ -50,9 +50,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
public class BaseVisualMode : VisualMode
|
||||
{
|
||||
#region ================== Constants
|
||||
//mxd
|
||||
public const string TEXTURE_OFFSET_CHANGE_ERROR = "Texture offsets cannot be changed in this mode if the map is not in UDMF format.\nPlease use Visual mode to change them.";
|
||||
|
||||
// Object picking
|
||||
private const float PICK_INTERVAL = 80.0f;
|
||||
private const float PICK_RANGE = 0.98f;
|
||||
|
@ -1431,105 +1428,73 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
[BeginAction("movetextureleft", Library = "BuilderModes")]
|
||||
public void MoveTextureLeft1()
|
||||
{
|
||||
if(General.Map.UDMF) {
|
||||
PreAction(UndoGroup.TextureOffsetChange);
|
||||
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, true);
|
||||
foreach(IVisualEventReceiver i in objs) i.OnChangeTextureOffset(-1, 0);
|
||||
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(-1, 0);
|
||||
PostAction();
|
||||
} else {
|
||||
General.ShowErrorMessage(TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
[BeginAction("movetextureright", Library = "BuilderModes")]
|
||||
public void MoveTextureRight1()
|
||||
{
|
||||
if(General.Map.UDMF) {
|
||||
PreAction(UndoGroup.TextureOffsetChange);
|
||||
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, true);
|
||||
foreach(IVisualEventReceiver i in objs) i.OnChangeTextureOffset(1, 0);
|
||||
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(1, 0);
|
||||
PostAction();
|
||||
} else {
|
||||
General.ShowErrorMessage(TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
[BeginAction("movetextureup", Library = "BuilderModes")]
|
||||
public void MoveTextureUp1()
|
||||
{
|
||||
if(General.Map.UDMF) {
|
||||
PreAction(UndoGroup.TextureOffsetChange);
|
||||
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, true);
|
||||
foreach(IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, -1);
|
||||
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, -1);
|
||||
PostAction();
|
||||
} else {
|
||||
General.ShowErrorMessage(TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
[BeginAction("movetexturedown", Library = "BuilderModes")]
|
||||
public void MoveTextureDown1()
|
||||
{
|
||||
if(General.Map.UDMF) {
|
||||
PreAction(UndoGroup.TextureOffsetChange);
|
||||
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, true);
|
||||
foreach(IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, 1);
|
||||
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, 1);
|
||||
PostAction();
|
||||
} else {
|
||||
General.ShowErrorMessage(TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
[BeginAction("movetextureleft8", Library = "BuilderModes")]
|
||||
public void MoveTextureLeft8()
|
||||
{
|
||||
if(General.Map.UDMF) {
|
||||
PreAction(UndoGroup.TextureOffsetChange);
|
||||
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, true);
|
||||
foreach(IVisualEventReceiver i in objs) i.OnChangeTextureOffset(-8, 0);
|
||||
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(-8, 0);
|
||||
PostAction();
|
||||
} else {
|
||||
General.ShowErrorMessage(TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
[BeginAction("movetextureright8", Library = "BuilderModes")]
|
||||
public void MoveTextureRight8()
|
||||
{
|
||||
if(General.Map.UDMF) {
|
||||
PreAction(UndoGroup.TextureOffsetChange);
|
||||
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, true);
|
||||
foreach(IVisualEventReceiver i in objs) i.OnChangeTextureOffset(8, 0);
|
||||
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(8, 0);
|
||||
PostAction();
|
||||
} else {
|
||||
General.ShowErrorMessage(TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
[BeginAction("movetextureup8", Library = "BuilderModes")]
|
||||
public void MoveTextureUp8()
|
||||
{
|
||||
if(General.Map.UDMF) {
|
||||
PreAction(UndoGroup.TextureOffsetChange);
|
||||
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, true);
|
||||
foreach(IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, -8);
|
||||
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, -8);
|
||||
PostAction();
|
||||
} else {
|
||||
General.ShowErrorMessage(TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
[BeginAction("movetexturedown8", Library = "BuilderModes")]
|
||||
public void MoveTextureDown8()
|
||||
{
|
||||
if(General.Map.UDMF) {
|
||||
PreAction(UndoGroup.TextureOffsetChange);
|
||||
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, true);
|
||||
foreach(IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, 8);
|
||||
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, 8);
|
||||
PostAction();
|
||||
} else {
|
||||
General.ShowErrorMessage(TEXTURE_OFFSET_CHANGE_ERROR, MessageBoxButtons.OK);
|
||||
}
|
||||
}
|
||||
|
||||
[BeginAction("textureselect", Library = "BuilderModes")]
|
||||
|
|
|
@ -175,13 +175,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
s.Fields["xpanningfloor"] = new UniValue(UniversalType.Float, oldx + (float)xy.X);
|
||||
s.Fields["ypanningfloor"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y);
|
||||
s.UpdateNeeded = true;
|
||||
|
||||
/*Sector.Sector.Fields.BeforeFieldsChange();
|
||||
float oldx = Sector.Sector.Fields.GetValue("xpanningfloor", 0.0f);
|
||||
float oldy = Sector.Sector.Fields.GetValue("ypanningfloor", 0.0f);
|
||||
Sector.Sector.Fields["xpanningfloor"] = new UniValue(UniversalType.Float, oldx + (float)xy.X);
|
||||
Sector.Sector.Fields["ypanningfloor"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y);
|
||||
Sector.Sector.UpdateNeeded = true;*/
|
||||
}
|
||||
|
||||
// Paste texture
|
||||
|
|
|
@ -240,10 +240,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
float scaley = Sidedef.Fields.GetValue("scaley_bottom", 1.0f);
|
||||
Sidedef.Fields["offsetx_bottom"] = new UniValue(UniversalType.Float, getRoundedTextureOffset(oldx, (float)xy.X, scalex)); //mxd
|
||||
Sidedef.Fields["offsety_bottom"] = new UniValue(UniversalType.Float, getRoundedTextureOffset(oldy, (float)xy.Y, scaley)); //mxd
|
||||
//Sidedef.Fields["offsetx_bottom"] = new UniValue(UniversalType.Float, oldx + getRoundedTextureOffset((float)xy.X, scalex)); //mxd
|
||||
//Sidedef.Fields["offsety_bottom"] = new UniValue(UniversalType.Float, oldy + getRoundedTextureOffset((float)xy.Y, scaley)); //mxd
|
||||
//Sidedef.Fields["offsetx_bottom"] = new UniValue(UniversalType.Float, oldx + (float)xy.X * scalex);
|
||||
//Sidedef.Fields["offsety_bottom"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y * scaley);
|
||||
}
|
||||
|
||||
protected override Point GetTextureOffset()
|
||||
|
|
|
@ -76,9 +76,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
Sidedef sourceside = extrafloor.Linedef.Front;
|
||||
this.extrafloor = extrafloor;
|
||||
|
||||
//int lightvalue = Sidedef.Fields.GetValue("light", 0);
|
||||
//bool lightabsolute = Sidedef.Fields.GetValue("lightabsolute", false);
|
||||
|
||||
//mxd. lightfog flag support
|
||||
bool lightabsolute = Sidedef.Fields.GetValue("lightabsolute", false);
|
||||
bool ignoreUDMFLight = (!Sidedef.Fields.GetValue("lightfog", false) || !lightabsolute) && Sector.Sector.Fields.ContainsKey("fadecolor");
|
||||
|
@ -197,7 +194,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
// Determine initial color
|
||||
int lightlevel = lightabsolute ? lightvalue : sd.Ceiling.brightnessbelow + lightvalue;
|
||||
//mxd. This calculates light with doom-style wall shading
|
||||
//PixelColor wallbrightness = PixelColor.FromInt(mode.CalculateBrightness(lightlevel));
|
||||
PixelColor wallbrightness = PixelColor.FromInt(mode.CalculateBrightness(lightlevel, Sidedef));
|
||||
PixelColor wallcolor = PixelColor.Modulate(sd.Ceiling.colorbelow, wallbrightness);
|
||||
poly.color = wallcolor.WithAlpha(255).ToInt();
|
||||
|
|
|
@ -78,9 +78,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
{
|
||||
Vector2D vl, vr;
|
||||
|
||||
//int lightvalue = Sidedef.Fields.GetValue("light", 0);
|
||||
//bool lightabsolute = Sidedef.Fields.GetValue("lightabsolute", false);
|
||||
|
||||
//mxd. lightfog flag support
|
||||
bool lightabsolute = Sidedef.Fields.GetValue("lightabsolute", false);
|
||||
bool ignoreUDMFLight = (!Sidedef.Fields.GetValue("lightfog", false) || !lightabsolute) && Sector.Sector.Fields.ContainsKey("fadecolor");
|
||||
|
@ -194,7 +191,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
// Determine initial color
|
||||
int lightlevel = lightabsolute ? lightvalue : sd.Ceiling.brightnessbelow + lightvalue;
|
||||
//mxd
|
||||
//PixelColor wallbrightness = PixelColor.FromInt(mode.CalculateBrightness(lightlevel));
|
||||
PixelColor wallbrightness = PixelColor.FromInt(mode.CalculateBrightness(lightlevel, Sidedef));
|
||||
PixelColor wallcolor = PixelColor.Modulate(sd.Ceiling.colorbelow, wallbrightness);
|
||||
poly.color = wallcolor.WithAlpha(255).ToInt();
|
||||
|
@ -317,10 +313,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
float scaley = Sidedef.Fields.GetValue("scaley_mid", 1.0f);
|
||||
Sidedef.Fields["offsetx_mid"] = new UniValue(UniversalType.Float, getRoundedTextureOffset(oldx, (float)xy.X, scalex)); //mxd
|
||||
Sidedef.Fields["offsety_mid"] = new UniValue(UniversalType.Float, getRoundedTextureOffset(oldy, (float)xy.Y, scaley)); //mxd
|
||||
//Sidedef.Fields["offsetx_mid"] = new UniValue(UniversalType.Float, oldx + getRoundedTextureOffset((float)xy.X, scalex)); //mxd
|
||||
//Sidedef.Fields["offsety_mid"] = new UniValue(UniversalType.Float, oldy + getRoundedTextureOffset((float)xy.Y, scaley)); //mxd
|
||||
//Sidedef.Fields["offsetx_mid"] = new UniValue(UniversalType.Float, oldx + (float)xy.X * scalex);
|
||||
//Sidedef.Fields["offsety_mid"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y * scaley);
|
||||
}
|
||||
|
||||
protected override Point GetTextureOffset()
|
||||
|
|
|
@ -71,9 +71,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
{
|
||||
Vector2D vl, vr;
|
||||
|
||||
//int lightvalue = Sidedef.Fields.GetValue("light", 0);
|
||||
//bool lightabsolute = Sidedef.Fields.GetValue("lightabsolute", false);
|
||||
|
||||
//mxd. lightfog flag support
|
||||
bool lightabsolute = Sidedef.Fields.GetValue("lightabsolute", false);
|
||||
bool ignoreUDMFLight = (!Sidedef.Fields.GetValue("lightfog", false) || !lightabsolute) && Sector.Sector.Fields.ContainsKey("fadecolor");
|
||||
|
@ -189,7 +186,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
// Determine initial color
|
||||
int lightlevel = lightabsolute ? lightvalue : sd.Ceiling.brightnessbelow + lightvalue;
|
||||
//mxd
|
||||
//PixelColor wallbrightness = PixelColor.FromInt(mode.CalculateBrightness(lightlevel));
|
||||
PixelColor wallbrightness = PixelColor.FromInt(mode.CalculateBrightness(lightlevel, Sidedef));
|
||||
PixelColor wallcolor = PixelColor.Modulate(sd.Ceiling.colorbelow, wallbrightness);
|
||||
poly.color = wallcolor.WithAlpha(255).ToInt();
|
||||
|
@ -245,10 +241,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
float scaley = Sidedef.Fields.GetValue("scaley_mid", 1.0f);
|
||||
Sidedef.Fields["offsetx_mid"] = new UniValue(UniversalType.Float, getRoundedTextureOffset(oldx, (float)xy.X, scalex)); //mxd
|
||||
Sidedef.Fields["offsety_mid"] = new UniValue(UniversalType.Float, getRoundedTextureOffset(oldy, (float)xy.Y, scaley)); //mxd
|
||||
//Sidedef.Fields["offsetx_mid"] = new UniValue(UniversalType.Float, oldx + getRoundedTextureOffset((float)xy.X, scalex)); //mxd
|
||||
//Sidedef.Fields["offsety_mid"] = new UniValue(UniversalType.Float, oldy + getRoundedTextureOffset((float)xy.Y, scaley)); //mxd
|
||||
//Sidedef.Fields["offsetx_mid"] = new UniValue(UniversalType.Float, oldx + (float)xy.X * scalex);
|
||||
//Sidedef.Fields["offsety_mid"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y * scaley);
|
||||
}
|
||||
|
||||
protected override Point GetTextureOffset()
|
||||
|
|
|
@ -72,9 +72,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
{
|
||||
Vector2D vl, vr;
|
||||
|
||||
//int lightvalue = Sidedef.Fields.GetValue("light", 0);
|
||||
//bool lightabsolute = Sidedef.Fields.GetValue("lightabsolute", false);
|
||||
|
||||
//mxd. lightfog flag support
|
||||
bool lightabsolute = Sidedef.Fields.GetValue("lightabsolute", false);
|
||||
bool ignoreUDMFLight = (!Sidedef.Fields.GetValue("lightfog", false) || !lightabsolute) && Sector.Sector.Fields.ContainsKey("fadecolor");
|
||||
|
@ -179,7 +176,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
// Determine initial color
|
||||
int lightlevel = lightabsolute ? lightvalue : sd.Ceiling.brightnessbelow + lightvalue;
|
||||
//mxd
|
||||
//PixelColor wallbrightness = PixelColor.FromInt(mode.CalculateBrightness(lightlevel));
|
||||
PixelColor wallbrightness = PixelColor.FromInt(mode.CalculateBrightness(lightlevel, Sidedef));
|
||||
PixelColor wallcolor = PixelColor.Modulate(sd.Ceiling.colorbelow, wallbrightness);
|
||||
poly.color = wallcolor.WithAlpha(255).ToInt();
|
||||
|
@ -244,10 +240,6 @@ namespace CodeImp.DoomBuilder.GZDoomEditing
|
|||
float scaley = Sidedef.Fields.GetValue("scaley_top", 1.0f);
|
||||
Sidedef.Fields["offsetx_top"] = new UniValue(UniversalType.Float, getRoundedTextureOffset(oldx, (float)xy.X, scalex)); //mxd
|
||||
Sidedef.Fields["offsety_top"] = new UniValue(UniversalType.Float, getRoundedTextureOffset(oldy, (float)xy.Y, scaley)); //mxd
|
||||
//Sidedef.Fields["offsetx_top"] = new UniValue(UniversalType.Float, oldx + getRoundedTextureOffset((float)xy.X, scalex)); //mxd
|
||||
//Sidedef.Fields["offsety_top"] = new UniValue(UniversalType.Float, oldy + getRoundedTextureOffset((float)xy.Y, scaley)); //mxd
|
||||
//Sidedef.Fields["offsetx_top"] = new UniValue(UniversalType.Float, oldx + (float)xy.X * scalex);
|
||||
//Sidedef.Fields["offsety_top"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y * scaley);
|
||||
}
|
||||
|
||||
protected override Point GetTextureOffset()
|
||||
|
|
Loading…
Reference in a new issue