Visual Mode: added "Toggle Slope" action.

Visual Mode, UDMF: "Auto Align Textures" actions now work on slopes.
Visual Mode, UDMF: Floor/ceiling texture rotation is now taken into account when moving texture offsets with arrow keys.
Visual Mode, UDMF: Fixed a bug in floor/ceiling texture dragging by mouse.
This commit is contained in:
MaxED 2013-04-26 12:32:51 +00:00
parent 23efaee1ee
commit c3c7490231
13 changed files with 433 additions and 78 deletions

View file

@ -190,7 +190,8 @@ namespace CodeImp.DoomBuilder.BuilderModes
// toolStripMenuItem2 // toolStripMenuItem2
// //
this.toolStripMenuItem2.Name = "toolStripMenuItem2"; this.toolStripMenuItem2.Name = "toolStripMenuItem2";
this.toolStripMenuItem2.Size = new System.Drawing.Size(146, 6); this.toolStripMenuItem2.Size = new System.Drawing.Size(149, 6);
this.toolStripMenuItem2.Visible = false;
// //
// thingsmenu // thingsmenu
// //

View file

@ -844,6 +844,18 @@ pasteproperties
allowscroll = true; allowscroll = true;
} }
//mxd
toggleslope
{
title = "Toggle Slope";
category = "visual";
description = "Toggles Slope for selected surfaces. Select or highlight upper/lower walls to add a slope. Select or highlight floors or ceilings to remove slope.";
allowkeys = true;
allowmouse = true;
allowscroll = true;
default = 262227; //Alt-S
}
placevisualstart placevisualstart
{ {
title = "Place Visual Mode Camera"; title = "Place Visual Mode Camera";

View file

@ -125,15 +125,16 @@ namespace CodeImp.DoomBuilder.BuilderModes
//mxd. Modify offsets based on surface and camera angles //mxd. Modify offsets based on surface and camera angles
if (General.Map.UDMF) { if (General.Map.UDMF) {
float angle = 0; float angle = 0;
if(GeometryType == VisualGeometryType.CEILING && level.sector.Fields.ContainsKey("rotationceiling"))
angle = Angle2D.DegToRad((float)level.sector.Fields["rotationceiling"].Value);// * (float)Math.PI / 180f; if(GeometryType == VisualGeometryType.CEILING)
else if(GeometryType == VisualGeometryType.FLOOR && level.sector.Fields.ContainsKey("rotationfloor")) angle = Angle2D.DegToRad(level.sector.Fields.GetValue("rotationceiling", 0f));
angle = Angle2D.DegToRad((float)level.sector.Fields["rotationfloor"].Value);// *(float)Math.PI / 180f; else
angle = Angle2D.DegToRad(level.sector.Fields.GetValue("rotationfloor", 0f));
Vector2D v = new Vector2D(offsetx, offsety).GetRotated(angle); Vector2D v = new Vector2D(offsetx, offsety).GetRotated(angle);
Point p = getTranslatedTextureOffset(new Point((int)Math.Round(v.x), (int)Math.Round(v.y)));
offsetx = p.X; offsetx = (int)Math.Round(v.x);
offsety = p.Y; offsety = (int)Math.Round(v.y);
} }
// Apply offsets // Apply offsets
@ -151,27 +152,6 @@ namespace CodeImp.DoomBuilder.BuilderModes
return level.sector; return level.sector;
} }
//mxd. Modify texture offsets based on camera angle (so "movetextureleft" action always moves texture more or less "left" etc.)
protected Point getTranslatedTextureOffset(Point p) {
Point tp = new Point();
int camAngle = (int)Angle2D.RadToDeg(General.Map.VisualCamera.AngleXY);// * 180f / (float)Math.PI);
if (camAngle > 315 || camAngle < 46) {
tp = p;
} else if (camAngle > 225) {
tp.Y = p.X;
tp.X = -p.Y;
} else if (camAngle > 135) {
tp.X = -p.X;
tp.Y = -p.Y;
}else{
tp.Y = -p.X;
tp.X = p.Y;
}
return tp;
}
//mxd //mxd
protected void onTextureChanged() { protected void onTextureChanged() {
if(level.sector == this.Sector.Sector) { if(level.sector == this.Sector.Sector) {
@ -206,7 +186,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
// Unused // Unused
public virtual void OnEditBegin() { } public virtual void OnEditBegin() { }
public virtual void OnTextureAlign(bool alignx, bool aligny) { } //public virtual void OnTextureAlign(bool alignx, bool aligny) { }
public virtual void OnToggleUpperUnpegged() { } public virtual void OnToggleUpperUnpegged() { }
public virtual void OnToggleLowerUnpegged() { } public virtual void OnToggleLowerUnpegged() { }
public virtual void OnResetTextureOffset() { } public virtual void OnResetTextureOffset() { }
@ -388,6 +368,41 @@ namespace CodeImp.DoomBuilder.BuilderModes
} }
} }
//mxd. Auto-align texture offsets
public virtual void OnTextureAlign(bool alignx, bool aligny) {
if(!General.Map.UDMF) return;
//create undo
string rest = string.Empty;
if(alignx && aligny) rest = "(X and Y)";
else if(alignx) rest = "(X)";
else rest = "(Y)";
mode.CreateUndo("Auto-align textures " + rest);
mode.SetActionResult("Auto-aligned textures " + rest + ".");
//get selection
List<VisualGeometry> selection = mode.GetSelectedSurfaces();
//align textures on slopes
foreach(VisualGeometry vg in selection) {
if(vg.GeometryType == VisualGeometryType.FLOOR || vg.GeometryType == VisualGeometryType.CEILING) {
if(vg.GeometryType == VisualGeometryType.FLOOR)
((VisualFloor)vg).AlignTexture(alignx, aligny);
else
((VisualCeiling)vg).AlignTexture(alignx, aligny);
vg.Sector.Sector.UpdateNeeded = true;
vg.Sector.Sector.UpdateCache();
}
}
// Map is changed
General.Map.Map.Update();
General.Map.IsChanged = true;
General.Interface.RefreshInfo();
}
// Copy properties // Copy properties
public virtual void OnCopyProperties() public virtual void OnCopyProperties()
{ {
@ -506,24 +521,49 @@ namespace CodeImp.DoomBuilder.BuilderModes
} }
// Texture offset change // Texture offset change
public virtual void OnChangeTextureOffset(int horizontal, int vertical) public virtual void OnChangeTextureOffset(int horizontal, int vertical, bool doSurfaceAngleCorrection)
{ {
//mxd //mxd
if (General.Map.UDMF) { if (!General.Map.UDMF) {
General.ShowErrorMessage("Floor/ceiling texture offsets cannot be changed in this map format!", MessageBoxButtons.OK);
return;
}
if((General.Map.UndoRedo.NextUndo == null) || (General.Map.UndoRedo.NextUndo.TicketID != undoticket)) if((General.Map.UndoRedo.NextUndo == null) || (General.Map.UndoRedo.NextUndo.TicketID != undoticket))
undoticket = mode.CreateUndo("Change texture offsets"); undoticket = mode.CreateUndo("Change texture offsets");
//mxd
if(doSurfaceAngleCorrection) {
Point p = new Point(horizontal, vertical);
float angle = Angle2D.RadToDeg(General.Map.VisualCamera.AngleXY);
if(GeometryType == VisualGeometryType.CEILING) {
angle += level.sector.Fields.GetValue("rotationceiling", 0f);
} else
angle += level.sector.Fields.GetValue("rotationfloor", 0f);
angle = General.ClampAngle(angle);
if(angle > 315 || angle < 46) {
} else if(angle > 225) {
vertical = p.X;
horizontal = -p.Y;
} else if(angle > 135) {
horizontal = -p.X;
vertical = -p.Y;
} else {
vertical = -p.X;
horizontal = p.Y;
}
}
// Apply offsets // Apply offsets
MoveTextureOffset(new Point(-horizontal, -vertical)); MoveTextureOffset(new Point(-horizontal, -vertical));
mode.SetActionResult("Changed texture offsets by " + (-horizontal) + ", " + (-vertical) + ".");
mode.SetActionResult("Changed texture offsets by " + -horizontal + ", " + -vertical + ".");
// Update sector geometry // Update sector geometry
Sector.UpdateSectorGeometry(false); Sector.UpdateSectorGeometry(false);
Sector.Rebuild(); Sector.Rebuild();
} else {
General.ShowErrorMessage("Floor/ceiling texture offsets cannot be changed in this map format!", MessageBoxButtons.OK);
}
} }
#endregion #endregion

View file

@ -756,11 +756,17 @@ namespace CodeImp.DoomBuilder.BuilderModes
} }
} }
// Auto-align texture X offsets // Auto-align texture offsets
public virtual void OnTextureAlign(bool alignx, bool aligny) public virtual void OnTextureAlign(bool alignx, bool aligny)
{ {
mode.CreateUndo("Auto-align textures"); //mxd
mode.SetActionResult("Auto-aligned textures."); string rest = string.Empty;
if(alignx && aligny) rest = "(X and Y)";
else if(alignx) rest = "(X)";
else rest = "(Y)";
mode.CreateUndo("Auto-align textures " + rest);
mode.SetActionResult("Auto-aligned textures " + rest + ".");
// Make sure the texture is loaded (we need the texture size) // Make sure the texture is loaded (we need the texture size)
if(!base.Texture.IsImageLoaded) base.Texture.LoadImage(); if(!base.Texture.IsImageLoaded) base.Texture.LoadImage();
@ -1068,7 +1074,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
} }
// Texture offset change // Texture offset change
public virtual void OnChangeTextureOffset(int horizontal, int vertical) public virtual void OnChangeTextureOffset(int horizontal, int vertical, bool doSurfaceAngleCorrection)
{ {
if((General.Map.UndoRedo.NextUndo == null) || (General.Map.UndoRedo.NextUndo.TicketID != undoticket)) if((General.Map.UndoRedo.NextUndo == null) || (General.Map.UndoRedo.NextUndo.TicketID != undoticket))
undoticket = mode.CreateUndo("Change texture offsets"); undoticket = mode.CreateUndo("Change texture offsets");

View file

@ -1229,7 +1229,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
if(!donesides.ContainsKey((i as BaseVisualGeometrySidedef).Sidedef)) if(!donesides.ContainsKey((i as BaseVisualGeometrySidedef).Sidedef))
{ {
i.OnChangeTextureOffset(dx, dy); i.OnChangeTextureOffset(dx, dy, false);
donesides.Add((i as BaseVisualGeometrySidedef).Sidedef, 0); donesides.Add((i as BaseVisualGeometrySidedef).Sidedef, 0);
} }
} }
@ -1247,7 +1247,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
if(!donesectors.ContainsKey((i as BaseVisualGeometrySector).Sector.Sector)) if(!donesectors.ContainsKey((i as BaseVisualGeometrySector).Sector.Sector))
{ {
i.OnChangeTextureOffset(dx, dy); i.OnChangeTextureOffset(dx, dy, false);
donesectors.Add((i as BaseVisualGeometrySector).Sector.Sector, 0); donesectors.Add((i as BaseVisualGeometrySector).Sector.Sector, 0);
} }
} }
@ -2015,7 +2015,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
PreAction(UndoGroup.TextureOffsetChange); PreAction(UndoGroup.TextureOffsetChange);
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false); List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false);
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(-1, 0); foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(-1, 0, true);
PostAction(); PostAction();
} }
@ -2024,7 +2024,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
PreAction(UndoGroup.TextureOffsetChange); PreAction(UndoGroup.TextureOffsetChange);
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false); List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false);
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(1, 0); foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(1, 0, true);
PostAction(); PostAction();
} }
@ -2033,7 +2033,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
PreAction(UndoGroup.TextureOffsetChange); PreAction(UndoGroup.TextureOffsetChange);
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false); List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false);
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, -1); foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, -1, true);
PostAction(); PostAction();
} }
@ -2042,7 +2042,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
PreAction(UndoGroup.TextureOffsetChange); PreAction(UndoGroup.TextureOffsetChange);
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false); List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false);
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, 1); foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, 1, true);
PostAction(); PostAction();
} }
@ -2051,7 +2051,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
PreAction(UndoGroup.TextureOffsetChange); PreAction(UndoGroup.TextureOffsetChange);
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false); List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false);
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(-8, 0); foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(-8, 0, true);
PostAction(); PostAction();
} }
@ -2060,7 +2060,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
PreAction(UndoGroup.TextureOffsetChange); PreAction(UndoGroup.TextureOffsetChange);
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false); List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false);
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(8, 0); foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(8, 0, true);
PostAction(); PostAction();
} }
@ -2069,7 +2069,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
PreAction(UndoGroup.TextureOffsetChange); PreAction(UndoGroup.TextureOffsetChange);
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false); List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false);
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, -8); foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, -8, true);
PostAction(); PostAction();
} }
@ -2078,7 +2078,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
PreAction(UndoGroup.TextureOffsetChange); PreAction(UndoGroup.TextureOffsetChange);
List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false); List<IVisualEventReceiver> objs = GetSelectedObjects(true, true, false, false);
foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, 8); foreach (IVisualEventReceiver i in objs) i.OnChangeTextureOffset(0, 8, true);
PostAction(); PostAction();
} }
@ -2475,6 +2475,129 @@ namespace CodeImp.DoomBuilder.BuilderModes
ShowTargetInfo(); ShowTargetInfo();
} }
//mxd
[BeginAction("toggleslope")]
public void ToggleSlope() {
List<VisualGeometry> selection = GetSelectedSurfaces();
if(selection.Count == 0) {
General.Interface.DisplayStatus(StatusType.Warning, "Toggle Slope action requires selected surfaces!");
return;
}
bool update = false;
List<BaseVisualSector> toUpdate = new List<BaseVisualSector>();
General.Map.UndoRedo.CreateUndo("Toggle Slope");
//check selection
foreach(VisualGeometry vg in selection) {
update = false;
//assign/remove action
if(vg.GeometryType == VisualGeometryType.WALL_BOTTOM) {
if(vg.Sidedef.Line.Action == 0 || (vg.Sidedef.Line.Action == 181 && vg.Sidedef.Line.Args[0] == 0)) {
//check if the sector already has floor slopes
foreach(Sidedef side in vg.Sidedef.Sector.Sidedefs) {
if(side == vg.Sidedef || side.Line.Action != 181)
continue;
int arg = (side == side.Line.Front ? 1 : 2);
if(side.Line.Args[0] == arg) {
//if only floor is affected, remove action
if(side.Line.Args[1] == 0)
side.Line.Action = 0;
else //clear floor alignment
side.Line.Args[0] = 0;
}
}
//set action
vg.Sidedef.Line.Action = 181;
vg.Sidedef.Line.Args[0] = (vg.Sidedef == vg.Sidedef.Line.Front ? 1 : 2);
update = true;
}
} else if(vg.GeometryType == VisualGeometryType.WALL_UPPER) {
if(vg.Sidedef.Line.Action == 0 || (vg.Sidedef.Line.Action == 181 && vg.Sidedef.Line.Args[1] == 0)) {
//check if the sector already has ceiling slopes
foreach(Sidedef side in vg.Sidedef.Sector.Sidedefs) {
if(side == vg.Sidedef || side.Line.Action != 181)
continue;
int arg = (side == side.Line.Front ? 1 : 2);
if(side.Line.Args[1] == arg) {
//if only ceiling is affected, remove action
if(side.Line.Args[0] == 0)
side.Line.Action = 0;
else //clear ceiling alignment
side.Line.Args[1] = 0;
}
}
//set action
vg.Sidedef.Line.Action = 181;
vg.Sidedef.Line.Args[1] = (vg.Sidedef == vg.Sidedef.Line.Front ? 1 : 2);
update = true;
}
} else if(vg.GeometryType == VisualGeometryType.CEILING) {
//check if the sector has ceiling slopes
foreach(Sidedef side in vg.Sector.Sector.Sidedefs) {
if(side.Line.Action != 181)
continue;
int arg = (side == side.Line.Front ? 1 : 2);
if(side.Line.Args[1] == arg) {
//if only ceiling is affected, remove action
if(side.Line.Args[0] == 0)
side.Line.Action = 0;
else //clear ceiling alignment
side.Line.Args[1] = 0;
update = true;
}
}
} else if(vg.GeometryType == VisualGeometryType.FLOOR) {
//check if the sector has floor slopes
foreach(Sidedef side in vg.Sector.Sector.Sidedefs) {
if(side.Line.Action != 181)
continue;
int arg = (side == side.Line.Front ? 1 : 2);
if(side.Line.Args[0] == arg) {
//if only floor is affected, remove action
if(side.Line.Args[1] == 0)
side.Line.Action = 0;
else //clear floor alignment
side.Line.Args[0] = 0;
update = true;
}
}
}
//add to update list
if(update)
toUpdate.Add(vg.Sector as BaseVisualSector);
}
//update changed geometry
if(toUpdate.Count > 0) {
RebuildElementData();
foreach(BaseVisualSector vs in toUpdate)
vs.UpdateSectorGeometry(true);
UpdateChangedObjects();
ClearSelection();
ShowTargetInfo();
}
General.Interface.DisplayStatus(StatusType.Action, "Toggled Slope for " + toUpdate.Count + (toUpdate.Count == 1 ? " surface." : " surfaces."));
}
#endregion #endregion
#region ================== Texture Alignment #region ================== Texture Alignment

View file

@ -438,7 +438,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
public virtual void OnEditBegin() { } public virtual void OnEditBegin() { }
public virtual void OnMouseMove(MouseEventArgs e) { } public virtual void OnMouseMove(MouseEventArgs e) { }
public virtual void OnChangeTargetBrightness(bool up) { } public virtual void OnChangeTargetBrightness(bool up) { }
public virtual void OnChangeTextureOffset(int horizontal, int vertical) { } public virtual void OnChangeTextureOffset(int horizontal, int vertical, bool doSurfaceAngleCorrection) { }
public virtual void OnSelectTexture() { } public virtual void OnSelectTexture() { }
public virtual void OnCopyTexture() { } public virtual void OnCopyTexture() { }
public virtual void OnPasteTexture() { } public virtual void OnPasteTexture() { }

View file

@ -204,7 +204,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
public virtual void OnEditBegin() { } public virtual void OnEditBegin() { }
public virtual void OnMouseMove(MouseEventArgs e) { } public virtual void OnMouseMove(MouseEventArgs e) { }
public virtual void OnChangeTargetBrightness(bool up) { } public virtual void OnChangeTargetBrightness(bool up) { }
public virtual void OnChangeTextureOffset(int horizontal, int vertical) { } public virtual void OnChangeTextureOffset(int horizontal, int vertical, bool doSurfaceAngleCorrection) { }
public virtual void OnSelectTexture() { } public virtual void OnSelectTexture() { }
public virtual void OnCopyTexture() { } public virtual void OnCopyTexture() { }
public virtual void OnPasteTexture() { } public virtual void OnPasteTexture() { }

View file

@ -32,7 +32,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
void OnMouseMove(MouseEventArgs e); void OnMouseMove(MouseEventArgs e);
void OnChangeTargetHeight(int amount); void OnChangeTargetHeight(int amount);
void OnChangeTargetBrightness(bool up); void OnChangeTargetBrightness(bool up);
void OnChangeTextureOffset(int horizontal, int vertical); void OnChangeTextureOffset(int horizontal, int vertical, bool doSurfaceAngleCorrection);
void OnResetTextureOffset(); void OnResetTextureOffset();
void OnSelectTexture(); void OnSelectTexture();
void OnCopyTexture(); void OnCopyTexture();

View file

@ -57,7 +57,7 @@ namespace CodeImp.DoomBuilder.BuilderModes
{ {
} }
public void OnChangeTextureOffset(int horizontal, int vertical) public void OnChangeTextureOffset(int horizontal, int vertical, bool doSurfaceAngleCorrection)
{ {
} }

View file

@ -179,7 +179,6 @@ namespace CodeImp.DoomBuilder.BuilderModes
s.Fields.BeforeFieldsChange(); s.Fields.BeforeFieldsChange();
float oldx = s.Fields.GetValue("xpanningceiling", 0.0f); float oldx = s.Fields.GetValue("xpanningceiling", 0.0f);
float oldy = s.Fields.GetValue("ypanningceiling", 0.0f); float oldy = s.Fields.GetValue("ypanningceiling", 0.0f);
xy = getTranslatedTextureOffset(xy);
s.Fields["xpanningceiling"] = new UniValue(UniversalType.Float, oldx + (float)xy.X); s.Fields["xpanningceiling"] = new UniValue(UniversalType.Float, oldx + (float)xy.X);
s.Fields["ypanningceiling"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y); s.Fields["ypanningceiling"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y);
s.UpdateNeeded = true; s.UpdateNeeded = true;
@ -377,6 +376,96 @@ namespace CodeImp.DoomBuilder.BuilderModes
} }
} }
//mxd
public void AlignTexture(bool alignx, bool aligny) {
if(!General.Map.UDMF) return;
float slopeAngle = level.plane.Normal.GetAngleZ() - Angle2D.PIHALF;
if(slopeAngle == 0) return; //it's a horizontal plane
//find slope source linedef
Linedef slopeSource = null;
bool isFront = false;
foreach(Sidedef side in Sector.Sector.Sidedefs) {
if(side.Line.Action == 181) {
if(side.Line.Args[1] == 1 && side.Line.Front != null && side.Line.Front == side) {
slopeSource = side.Line;
isFront = true;
break;
} else if(side.Line.Args[1] == 2 && side.Line.Back != null && side.Line.Back == side) {
slopeSource = side.Line;
break;
}
}
}
if(slopeSource == null) return;
Sector.Sector.Fields.BeforeFieldsChange();
//match rotation
float sourceAngle = (float)Math.Round(General.ClampAngle(isFront ? -Angle2D.RadToDeg(slopeSource.Angle) + 90 : -Angle2D.RadToDeg(slopeSource.Angle) - 90), 1);
if((isFront && slopeSource.Front.Sector.CeilHeight < slopeSource.Back.Sector.CeilHeight) ||
(!isFront && slopeSource.Front.Sector.CeilHeight > slopeSource.Back.Sector.CeilHeight)) {
sourceAngle = General.ClampAngle(sourceAngle + 180);
}
if(sourceAngle != 0) {
if(!Sector.Sector.Fields.ContainsKey("rotationceiling"))
Sector.Sector.Fields.Add("rotationceiling", new UniValue(UniversalType.Float, sourceAngle));
else
Sector.Sector.Fields["rotationceiling"].Value = sourceAngle;
} else if(Sector.Sector.Fields.ContainsKey("rotationceiling")) {
Sector.Sector.Fields.Remove("rotationceiling");
}
//update scaleY
float scaleX = Sector.Sector.Fields.GetValue("xscaleceiling", 1.0f);
float scaleY = (float)Math.Round(scaleX * (1 / (float)Math.Cos(slopeAngle)), 2);
if(aligny) {
if(Sector.Sector.Fields.ContainsKey("yscaleceiling"))
Sector.Sector.Fields["yscaleceiling"].Value = scaleY;
else
Sector.Sector.Fields.Add("yscaleceiling", new UniValue(UniversalType.Float, scaleY));
}
//update texture offsets
Vector2D offset;
if((isFront && slopeSource.Front.Sector.CeilHeight > slopeSource.Back.Sector.CeilHeight) ||
(!isFront && slopeSource.Front.Sector.CeilHeight < slopeSource.Back.Sector.CeilHeight)) {
offset = slopeSource.End.Position;
} else {
offset = slopeSource.Start.Position;
}
offset = offset.GetRotated(Angle2D.DegToRad(sourceAngle));
if(alignx) {
if(Texture != null) offset.x %= Texture.Width / scaleX;
if(Sector.Sector.Fields.ContainsKey("xpanningceiling"))
Sector.Sector.Fields["xpanningceiling"].Value = (float)Math.Round(-offset.x);
else
Sector.Sector.Fields.Add("xpanningceiling", new UniValue(UniversalType.Float, (float)Math.Round(-offset.x)));
}
if(aligny) {
if(Texture != null) offset.y %= Texture.Height / scaleY;
if(Sector.Sector.Fields.ContainsKey("ypanningceiling"))
Sector.Sector.Fields["ypanningceiling"].Value = (float)Math.Round(offset.y);
else
Sector.Sector.Fields.Add("ypanningceiling", new UniValue(UniversalType.Float, (float)Math.Round(offset.y)));
}
//update geometry
Sector.UpdateSectorGeometry(false);
}
#endregion #endregion
} }
} }

View file

@ -87,7 +87,6 @@ namespace CodeImp.DoomBuilder.BuilderModes
s.Fields.GetValue("yscalefloor", 1.0f)); s.Fields.GetValue("yscalefloor", 1.0f));
//Load floor texture //Load floor texture
//if((s.FloorTexture.Length > 0) && (s.FloorTexture[0] != '-')) {
base.Texture = General.Map.Data.GetFlatImage(s.LongFloorTexture); base.Texture = General.Map.Data.GetFlatImage(s.LongFloorTexture);
if(base.Texture == null) { if(base.Texture == null) {
base.Texture = General.Map.Data.MissingTexture3D; base.Texture = General.Map.Data.MissingTexture3D;
@ -96,11 +95,6 @@ namespace CodeImp.DoomBuilder.BuilderModes
if(!base.Texture.IsImageLoaded) if(!base.Texture.IsImageLoaded)
setuponloadedtexture = s.LongFloorTexture; setuponloadedtexture = s.LongFloorTexture;
} }
/*} else {
// Use missing texture
base.Texture = General.Map.Data.MissingTexture3D;
setuponloadedtexture = 0;
}*/
// Determine texture scale // Determine texture scale
if(base.Texture.IsImageLoaded) if(base.Texture.IsImageLoaded)
@ -178,7 +172,6 @@ namespace CodeImp.DoomBuilder.BuilderModes
s.Fields.BeforeFieldsChange(); s.Fields.BeforeFieldsChange();
float oldx = s.Fields.GetValue("xpanningfloor", 0.0f); float oldx = s.Fields.GetValue("xpanningfloor", 0.0f);
float oldy = s.Fields.GetValue("ypanningfloor", 0.0f); float oldy = s.Fields.GetValue("ypanningfloor", 0.0f);
xy = getTranslatedTextureOffset(xy);
s.Fields["xpanningfloor"] = new UniValue(UniversalType.Float, oldx + (float)xy.X); s.Fields["xpanningfloor"] = new UniValue(UniversalType.Float, oldx + (float)xy.X);
s.Fields["ypanningfloor"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y); s.Fields["ypanningfloor"] = new UniValue(UniversalType.Float, oldy + (float)xy.Y);
s.UpdateNeeded = true; s.UpdateNeeded = true;
@ -340,6 +333,95 @@ namespace CodeImp.DoomBuilder.BuilderModes
} }
} }
//mxd
public void AlignTexture(bool alignx, bool aligny) {
if(!General.Map.UDMF) return;
float slopeAngle = level.plane.Normal.GetAngleZ() - Angle2D.PIHALF;
if(slopeAngle == 0) return; //it's a horizontal plane
//find slope source linedef
Linedef slopeSource = null;
bool isFront = false;
foreach(Sidedef side in Sector.Sector.Sidedefs) {
if(side.Line.Action == 181) {
if(side.Line.Args[0] == 1 && side.Line.Front != null && side.Line.Front == side) {
slopeSource = side.Line;
isFront = true;
break;
} else if(side.Line.Args[0] == 2 && side.Line.Back != null && side.Line.Back == side) {
slopeSource = side.Line;
break;
}
}
}
if(slopeSource == null) return;
Sector.Sector.Fields.BeforeFieldsChange();
float sourceAngle = (float)Math.Round(General.ClampAngle(isFront ? -Angle2D.RadToDeg(slopeSource.Angle) + 90 : -Angle2D.RadToDeg(slopeSource.Angle) - 90), 1);
if((isFront && slopeSource.Front.Sector.FloorHeight > slopeSource.Back.Sector.FloorHeight) ||
(!isFront && slopeSource.Front.Sector.FloorHeight < slopeSource.Back.Sector.FloorHeight)) {
sourceAngle = General.ClampAngle(sourceAngle + 180);
}
if(sourceAngle != 0) {
if(!Sector.Sector.Fields.ContainsKey("rotationfloor"))
Sector.Sector.Fields.Add("rotationfloor", new UniValue(UniversalType.Float, sourceAngle));
else
Sector.Sector.Fields["rotationfloor"].Value = sourceAngle;
} else if(Sector.Sector.Fields.ContainsKey("rotationfloor")) {
Sector.Sector.Fields.Remove("rotationfloor");
}
//update scaleY
float scaleX = Sector.Sector.Fields.GetValue("xscalefloor", 1.0f);
float scaleY = (float)Math.Round(scaleX * (1 / (float)Math.Cos(slopeAngle)), 2);
if(aligny) {
if(Sector.Sector.Fields.ContainsKey("yscalefloor"))
Sector.Sector.Fields["yscalefloor"].Value = scaleY;
else
Sector.Sector.Fields.Add("yscalefloor", new UniValue(UniversalType.Float, scaleY));
}
//update texture offsets
Vector2D offset;
if((isFront && slopeSource.Front.Sector.FloorHeight < slopeSource.Back.Sector.FloorHeight) ||
(!isFront && slopeSource.Front.Sector.FloorHeight > slopeSource.Back.Sector.FloorHeight)) {
offset = slopeSource.End.Position;
} else {
offset = slopeSource.Start.Position;
}
offset = offset.GetRotated(Angle2D.DegToRad(sourceAngle));
if(alignx) {
if(Texture != null) offset.x %= Texture.Width / scaleX;
if(Sector.Sector.Fields.ContainsKey("xpanningfloor"))
Sector.Sector.Fields["xpanningfloor"].Value = (float)Math.Round(-offset.x);
else
Sector.Sector.Fields.Add("xpanningfloor", new UniValue(UniversalType.Float, (float)Math.Round(-offset.x)));
}
if(aligny) {
if(Texture != null) offset.y %= Texture.Height / scaleY;
if(Sector.Sector.Fields.ContainsKey("ypanningfloor"))
Sector.Sector.Fields["ypanningfloor"].Value = (float)Math.Round(offset.y);
else
Sector.Sector.Fields.Add("ypanningfloor", new UniValue(UniversalType.Float, (float)Math.Round(offset.y)));
}
//update geometry
Sector.UpdateSectorGeometry(false);
}
#endregion #endregion
} }
} }

View file

@ -339,6 +339,7 @@ namespace CodeImp.DoomBuilder.ColorPicker.Windows {
private void colorPickerControl1_OnOkPressed(object sender, EventArgs e) { private void colorPickerControl1_OnOkPressed(object sender, EventArgs e) {
this.DialogResult = DialogResult.OK; this.DialogResult = DialogResult.OK;
General.Interface.RefreshInfo();
Close(); Close();
} }

View file

@ -514,6 +514,7 @@ namespace CodeImp.DoomBuilder.UDMFControls
} }
removeDefaultValues(); removeDefaultValues();
General.Interface.RefreshInfo();
this.DialogResult = DialogResult.OK; this.DialogResult = DialogResult.OK;
Close(); Close();
} }