Made the scale top control have consideration for Height
This commit is contained in:
parent
c45371da69
commit
52c91d17b2
11 changed files with 461 additions and 34 deletions
|
|
@ -0,0 +1,423 @@
|
|||
/*
|
||||
Copyright (c) 2014, Lars Brubaker
|
||||
All rights reserved.
|
||||
|
||||
Redistribution and use in source and binary forms, with or without
|
||||
modification, are permitted provided that the following conditions are met:
|
||||
|
||||
1. Redistributions of source code must retain the above copyright notice, this
|
||||
list of conditions and the following disclaimer.
|
||||
2. Redistributions in binary form must reproduce the above copyright notice,
|
||||
this list of conditions and the following disclaimer in the documentation
|
||||
and/or other materials provided with the distribution.
|
||||
|
||||
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
||||
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
||||
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
||||
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
|
||||
ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
||||
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
||||
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
||||
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
||||
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
The views and conclusions contained in the software and documentation are those
|
||||
of the authors and should not be interpreted as representing official policies,
|
||||
either expressed or implied, of the FreeBSD Project.
|
||||
*/
|
||||
|
||||
using System.Collections.Generic;
|
||||
using MatterHackers.Agg;
|
||||
using MatterHackers.Agg.UI;
|
||||
using MatterHackers.DataConverters3D;
|
||||
using MatterHackers.MatterControl;
|
||||
using MatterHackers.MatterControl.CustomWidgets;
|
||||
using MatterHackers.MatterControl.DesignTools;
|
||||
using MatterHackers.MatterControl.DesignTools.Operations;
|
||||
using MatterHackers.MatterControl.PartPreviewWindow;
|
||||
using MatterHackers.MeshVisualizer;
|
||||
using MatterHackers.PolygonMesh;
|
||||
using MatterHackers.RayTracer;
|
||||
using MatterHackers.RenderOpenGl;
|
||||
using MatterHackers.VectorMath;
|
||||
|
||||
namespace MatterHackers.Plugins.EditorTools
|
||||
{
|
||||
|
||||
public class ScaleHeightControl : Object3DControl
|
||||
{
|
||||
private IObject3D activeSelectedItem;
|
||||
private PlaneShape hitPlane;
|
||||
private Vector3 initialHitPosition;
|
||||
private readonly Mesh topScaleMesh;
|
||||
private AxisAlignedBoundingBox mouseDownSelectedBounds;
|
||||
private double heightOnMouseDown = 0;
|
||||
|
||||
private double DistToStart => 5 * GuiWidget.DeviceScale;
|
||||
|
||||
private double LineLength => 55 * GuiWidget.DeviceScale;
|
||||
|
||||
private Vector3 originalPointToMove;
|
||||
private readonly double arrowSize = 7 * GuiWidget.DeviceScale;
|
||||
private readonly ThemeConfig theme;
|
||||
private readonly InlineEditControl zValueDisplayInfo;
|
||||
private bool hadClickOnControl;
|
||||
|
||||
public ScaleHeightControl(IObject3DControlContext context)
|
||||
: base(context)
|
||||
{
|
||||
theme = AppContext.Theme;
|
||||
|
||||
zValueDisplayInfo = new InlineEditControl()
|
||||
{
|
||||
ForceHide = () =>
|
||||
{
|
||||
// if the selection changes
|
||||
if (RootSelection != activeSelectedItem)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
// if another control gets a hover
|
||||
if (Object3DControlContext.HoveredObject3DControl != this
|
||||
&& Object3DControlContext.HoveredObject3DControl != null)
|
||||
{
|
||||
return true;
|
||||
}
|
||||
|
||||
// if we clicked on the control
|
||||
if (hadClickOnControl)
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
return false;
|
||||
},
|
||||
GetDisplayString = (value) => "{0:0.0}".FormatWith(value)
|
||||
};
|
||||
|
||||
zValueDisplayInfo.VisibleChanged += (s, e) =>
|
||||
{
|
||||
if (!zValueDisplayInfo.Visible)
|
||||
{
|
||||
hadClickOnControl = false;
|
||||
}
|
||||
};
|
||||
|
||||
zValueDisplayInfo.EditComplete += (s, e) =>
|
||||
{
|
||||
var selectedItem = activeSelectedItem;
|
||||
|
||||
if (selectedItem is IObjectWithHeight heightObject)
|
||||
{
|
||||
var startingHeight = heightObject.Height;
|
||||
var originalSelectedBounds = selectedItem.GetAxisAlignedBoundingBox();
|
||||
Vector3 topPosition = GetTopPosition(selectedItem);
|
||||
var lockedBottom = GetBottomPosition(selectedItem);
|
||||
|
||||
Vector3 newSize = Vector3.Zero;
|
||||
newSize.Z = zValueDisplayInfo.Value;
|
||||
Vector3 scaleAmount = ScaleCornerControl.GetScalingConsideringShiftKey(originalSelectedBounds, mouseDownSelectedBounds, newSize, Object3DControlContext.GuiSurface.ModifierKeys);
|
||||
|
||||
heightObject.Height *= scaleAmount.Z;
|
||||
|
||||
var scale = Matrix4X4.CreateScale(scaleAmount);
|
||||
|
||||
Invalidate();
|
||||
|
||||
SetHeightUndo(startingHeight);
|
||||
}
|
||||
};
|
||||
|
||||
Object3DControlContext.GuiSurface.AddChild(zValueDisplayInfo);
|
||||
|
||||
DrawOnTop = true;
|
||||
|
||||
topScaleMesh = PlatonicSolids.CreateCube(arrowSize, arrowSize, arrowSize);
|
||||
|
||||
CollisionVolume = topScaleMesh.CreateBVHData();
|
||||
|
||||
Object3DControlContext.GuiSurface.BeforeDraw += Object3DControl_BeforeDraw;
|
||||
}
|
||||
|
||||
public override void Draw(DrawGlContentEventArgs e)
|
||||
{
|
||||
bool shouldDrawScaleControls = true;
|
||||
var selectedItem = RootSelection;
|
||||
|
||||
if (Object3DControlContext.SelectedObject3DControl != null
|
||||
&& Object3DControlContext.SelectedObject3DControl as ScaleHeightControl == null)
|
||||
{
|
||||
shouldDrawScaleControls = false;
|
||||
}
|
||||
|
||||
if (selectedItem != null)
|
||||
{
|
||||
if (shouldDrawScaleControls)
|
||||
{
|
||||
// don't draw if any other control is dragging
|
||||
if (MouseIsOver)
|
||||
{
|
||||
GLHelper.Render(topScaleMesh, theme.PrimaryAccentColor, TotalTransform, RenderTypes.Shaded);
|
||||
}
|
||||
else
|
||||
{
|
||||
GLHelper.Render(topScaleMesh, theme.TextColor, TotalTransform, RenderTypes.Shaded);
|
||||
}
|
||||
}
|
||||
|
||||
if (e != null)
|
||||
{
|
||||
// evaluate the position of the up line to draw
|
||||
Vector3 topPosition = GetTopPosition(selectedItem);
|
||||
|
||||
var bottomPosition = GetBottomPosition(selectedItem);
|
||||
|
||||
// render with z-buffer full black
|
||||
Frustum clippingFrustum = Object3DControlContext.World.GetClippingFrustum();
|
||||
|
||||
if (e.ZBuffered)
|
||||
{
|
||||
Object3DControlContext.World.Render3DLine(clippingFrustum, bottomPosition, topPosition, theme.TextColor, width: GuiWidget.DeviceScale);
|
||||
}
|
||||
else
|
||||
{
|
||||
// render on top of everything very lightly
|
||||
Object3DControlContext.World.Render3DLine(clippingFrustum, bottomPosition, topPosition, theme.TextColor.WithAlpha(20), false, GuiWidget.DeviceScale);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
base.Draw(e);
|
||||
}
|
||||
|
||||
public Vector3 GetTopPosition(IObject3D selectedItem)
|
||||
{
|
||||
var meshBounds = selectedItem.GetAxisAlignedBoundingBox(selectedItem.Matrix.Inverted);
|
||||
var top = new Vector3(meshBounds.Center.X, meshBounds.Center.Y, meshBounds.MaxXYZ.Z);
|
||||
|
||||
var worldTop = top.Transform(selectedItem.Matrix);
|
||||
return worldTop;
|
||||
}
|
||||
|
||||
public Vector3 GetBottomPosition(IObject3D selectedItem)
|
||||
{
|
||||
var meshBounds = selectedItem.GetAxisAlignedBoundingBox(selectedItem.Matrix.Inverted);
|
||||
var bottom = new Vector3(meshBounds.Center.X, meshBounds.Center.Y, meshBounds.MinXYZ.Z);
|
||||
|
||||
var worldBottom = bottom.Transform(selectedItem.Matrix);
|
||||
return worldBottom;
|
||||
}
|
||||
|
||||
public override void OnMouseDown(Mouse3DEventArgs mouseEvent3D)
|
||||
{
|
||||
if (mouseEvent3D.info != null && Object3DControlContext.Scene.SelectedItem != null)
|
||||
{
|
||||
hadClickOnControl = true;
|
||||
activeSelectedItem = RootSelection;
|
||||
|
||||
zValueDisplayInfo.Visible = true;
|
||||
|
||||
var selectedItem = activeSelectedItem;
|
||||
|
||||
double distanceToHit = Vector3Ex.Dot(mouseEvent3D.info.HitPosition, mouseEvent3D.MouseRay.directionNormal);
|
||||
hitPlane = new PlaneShape(mouseEvent3D.MouseRay.directionNormal, distanceToHit, null);
|
||||
originalPointToMove = GetTopPosition(selectedItem);
|
||||
|
||||
initialHitPosition = mouseEvent3D.info.HitPosition;
|
||||
if (selectedItem is IObjectWithHeight heightObject)
|
||||
{
|
||||
heightOnMouseDown = heightObject.Height;
|
||||
}
|
||||
|
||||
mouseDownSelectedBounds = selectedItem.GetAxisAlignedBoundingBox();
|
||||
}
|
||||
|
||||
base.OnMouseDown(mouseEvent3D);
|
||||
}
|
||||
|
||||
public override async void OnMouseMove(Mouse3DEventArgs mouseEvent3D, bool mouseIsOver)
|
||||
{
|
||||
var selectedItem = RootSelection;
|
||||
|
||||
activeSelectedItem = selectedItem;
|
||||
if (MouseIsOver)
|
||||
{
|
||||
zValueDisplayInfo.Visible = true;
|
||||
}
|
||||
else if (!hadClickOnControl)
|
||||
{
|
||||
zValueDisplayInfo.Visible = false;
|
||||
}
|
||||
|
||||
if (MouseDownOnControl)
|
||||
{
|
||||
IntersectInfo info = hitPlane.GetClosestIntersection(mouseEvent3D.MouseRay);
|
||||
|
||||
if (info != null
|
||||
&& selectedItem != null)
|
||||
{
|
||||
var delta = info.HitPosition - initialHitPosition;
|
||||
|
||||
var newPosition = originalPointToMove + delta;
|
||||
|
||||
var lockedBottom = GetBottomPosition(selectedItem);
|
||||
|
||||
var newSize = (newPosition - lockedBottom).Length;
|
||||
|
||||
if (Object3DControlContext.SnapGridDistance > 0)
|
||||
{
|
||||
// snap this position to the grid
|
||||
double snapGridDistance = Object3DControlContext.SnapGridDistance;
|
||||
|
||||
// snap this position to the grid
|
||||
newSize = ((int)((newSize / snapGridDistance) + .5)) * snapGridDistance;
|
||||
}
|
||||
|
||||
if (selectedItem is IObjectWithHeight heightObject)
|
||||
{
|
||||
heightObject.Height = newSize;
|
||||
selectedItem.Invalidate(new InvalidateArgs(selectedItem, InvalidateType.DisplayValues));
|
||||
}
|
||||
|
||||
await selectedItem.Rebuild();
|
||||
|
||||
var postScaleBottom = GetBottomPosition(selectedItem);
|
||||
|
||||
selectedItem.Translate(lockedBottom - postScaleBottom);
|
||||
|
||||
Invalidate();
|
||||
}
|
||||
}
|
||||
|
||||
base.OnMouseMove(mouseEvent3D, mouseIsOver);
|
||||
}
|
||||
|
||||
public override void OnMouseUp(Mouse3DEventArgs mouseEvent3D)
|
||||
{
|
||||
if (activeSelectedItem is IObjectWithHeight heightObject)
|
||||
{
|
||||
SetHeightUndo(heightObject.Height);
|
||||
}
|
||||
|
||||
base.OnMouseUp(mouseEvent3D);
|
||||
}
|
||||
|
||||
private void SetHeightUndo(double height)
|
||||
{
|
||||
if (activeSelectedItem is IObjectWithHeight heightObject)
|
||||
{
|
||||
var undoBuffer = Object3DControlContext.Scene.UndoBuffer;
|
||||
undoBuffer.AddAndDo(new UndoRedoActions(() =>
|
||||
{
|
||||
heightObject.Height = heightOnMouseDown;
|
||||
activeSelectedItem?.Invalidate(new InvalidateArgs(activeSelectedItem, InvalidateType.Properties));
|
||||
},
|
||||
() =>
|
||||
{
|
||||
heightObject.Height = height;
|
||||
activeSelectedItem?.Invalidate(new InvalidateArgs(activeSelectedItem, InvalidateType.Properties));
|
||||
}));
|
||||
}
|
||||
}
|
||||
|
||||
public override void CancelOperation()
|
||||
{
|
||||
IObject3D selectedItem = RootSelection;
|
||||
if (selectedItem != null
|
||||
&& MouseDownOnControl)
|
||||
{
|
||||
if (activeSelectedItem is IObjectWithHeight heightObject)
|
||||
{
|
||||
heightObject.Height = heightOnMouseDown;
|
||||
}
|
||||
|
||||
MouseDownOnControl = false;
|
||||
MouseIsOver = false;
|
||||
|
||||
Object3DControlContext.Scene.DrawSelection = true;
|
||||
Object3DControlContext.Scene.ShowSelectionShadow = true;
|
||||
}
|
||||
|
||||
base.CancelOperation();
|
||||
}
|
||||
|
||||
public override void SetPosition(IObject3D selectedItem, MeshSelectInfo selectInfo)
|
||||
{
|
||||
AxisAlignedBoundingBox selectedBounds = selectedItem.GetAxisAlignedBoundingBox();
|
||||
|
||||
var topPosition = GetTopPosition(selectedItem);
|
||||
double distBetweenPixelsWorldSpace = Object3DControlContext.World.GetWorldUnitsPerScreenPixelAtPosition(topPosition);
|
||||
|
||||
Vector3 arrowCenter = topPosition;
|
||||
arrowCenter.Z += arrowSize / 2 * distBetweenPixelsWorldSpace;
|
||||
|
||||
var centerMatrix = Matrix4X4.CreateTranslation(arrowCenter);
|
||||
centerMatrix = Matrix4X4.CreateScale(distBetweenPixelsWorldSpace) * centerMatrix;
|
||||
TotalTransform = centerMatrix;
|
||||
}
|
||||
|
||||
private void Object3DControl_BeforeDraw(object sender, DrawEventArgs drawEvent)
|
||||
{
|
||||
var selectedItem = RootSelection;
|
||||
|
||||
if (selectedItem != null)
|
||||
{
|
||||
if (zValueDisplayInfo.Visible)
|
||||
{
|
||||
var topPosition = GetTopPosition(selectedItem);
|
||||
double distBetweenPixelsWorldSpace = Object3DControlContext.World.GetWorldUnitsPerScreenPixelAtPosition(topPosition);
|
||||
var topScreen = Object3DControlContext.World.GetScreenPosition(topPosition + new Vector3(DistToStart * distBetweenPixelsWorldSpace, 0, 0));
|
||||
|
||||
var bottomPosition = GetBottomPosition(selectedItem);
|
||||
var bottomScreen = Object3DControlContext.World.GetScreenPosition(bottomPosition + new Vector3(DistToStart * distBetweenPixelsWorldSpace, 0, 0));
|
||||
|
||||
var perpRight = (topScreen - bottomScreen).GetPerpendicularRight().GetNormal() * LineLength;
|
||||
if (perpRight.X < 0)
|
||||
{
|
||||
perpRight = -perpRight;
|
||||
}
|
||||
|
||||
var lines = new List<Vector2>();
|
||||
// left lines
|
||||
lines.Add(topScreen);
|
||||
lines.Add(topScreen + perpRight);
|
||||
|
||||
lines.Add(bottomScreen);
|
||||
lines.Add(bottomScreen + perpRight);
|
||||
|
||||
for (int i = 0; i < lines.Count; i += 2)
|
||||
{
|
||||
// draw the measure line
|
||||
drawEvent.Graphics2D.Line(lines[i], lines[i + 1], theme.TextColor);
|
||||
}
|
||||
|
||||
for (int i = 0; i < lines.Count; i += 4)
|
||||
{
|
||||
drawEvent.Graphics2D.DrawMeasureLine((lines[i] + lines[i + 1]) / 2,
|
||||
(lines[i + 2] + lines[i + 3]) / 2,
|
||||
LineArrows.Both,
|
||||
theme);
|
||||
}
|
||||
|
||||
int j = 0;
|
||||
|
||||
Vector2 heightDisplayCenter = (((lines[j] + lines[j + 1]) / 2) + ((lines[j + 2] + lines[j + 3]) / 2)) / 2;
|
||||
if (activeSelectedItem is IObjectWithHeight heightObject)
|
||||
{
|
||||
zValueDisplayInfo.Value = heightObject.Height;
|
||||
}
|
||||
|
||||
zValueDisplayInfo.OriginRelativeParent = heightDisplayCenter + new Vector2(10, -zValueDisplayInfo.LocalBounds.Center.Y);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public override void Dispose()
|
||||
{
|
||||
zValueDisplayInfo.Close();
|
||||
Object3DControlContext.GuiSurface.BeforeDraw -= Object3DControl_BeforeDraw;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -43,7 +43,7 @@ using MatterHackers.VectorMath;
|
|||
|
||||
namespace MatterHackers.Plugins.EditorTools
|
||||
{
|
||||
public abstract class ScaleTopControl : Object3DControl
|
||||
public class ScaleMatrixTopControl : Object3DControl
|
||||
{
|
||||
private IObject3D activeSelectedItem;
|
||||
private PlaneShape hitPlane;
|
||||
|
|
@ -63,7 +63,7 @@ namespace MatterHackers.Plugins.EditorTools
|
|||
private readonly InlineEditControl zValueDisplayInfo;
|
||||
private bool hadClickOnControl;
|
||||
|
||||
public ScaleTopControl(IObject3DControlContext context)
|
||||
public ScaleMatrixTopControl(IObject3DControlContext context)
|
||||
: base(context)
|
||||
{
|
||||
theme = AppContext.Theme;
|
||||
|
|
@ -149,7 +149,7 @@ namespace MatterHackers.Plugins.EditorTools
|
|||
var selectedItem = RootSelection;
|
||||
|
||||
if (Object3DControlContext.SelectedObject3DControl != null
|
||||
&& Object3DControlContext.SelectedObject3DControl as ScaleTopControl == null)
|
||||
&& Object3DControlContext.SelectedObject3DControl as ScaleMatrixTopControl == null)
|
||||
{
|
||||
shouldDrawScaleControls = false;
|
||||
}
|
||||
|
|
@ -372,20 +372,4 @@ namespace MatterHackers.Plugins.EditorTools
|
|||
Object3DControlContext.GuiSurface.BeforeDraw -= Object3DControl_BeforeDraw;
|
||||
}
|
||||
}
|
||||
|
||||
public class ScaleMatrixTopControl : ScaleTopControl
|
||||
{
|
||||
public ScaleMatrixTopControl(IObject3DControlContext context)
|
||||
: base(context)
|
||||
{
|
||||
}
|
||||
}
|
||||
|
||||
public class ScaleHeightControl : ScaleTopControl
|
||||
{
|
||||
public ScaleHeightControl(IObject3DControlContext context)
|
||||
: base(context)
|
||||
{
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
@ -50,9 +50,18 @@ using Newtonsoft.Json;
|
|||
|
||||
namespace MatterHackers.MatterControl.DesignTools.Operations
|
||||
{
|
||||
public enum FitType { Box, Cylinder }
|
||||
public enum FitType
|
||||
{
|
||||
Box,
|
||||
Cylinder
|
||||
}
|
||||
|
||||
public enum MaintainRatio { None, X_Y, X_Y_Z }
|
||||
public enum MaintainRatio
|
||||
{
|
||||
None,
|
||||
X_Y,
|
||||
X_Y_Z
|
||||
}
|
||||
|
||||
[Obsolete("Not used anymore. Replaced with FitToBoundsObject3D_2", true)]
|
||||
public class FitToBoundsObject3D : Object3D, IEditorDraw, IPropertyGridModifier
|
||||
|
|
@ -61,20 +70,27 @@ namespace MatterHackers.MatterControl.DesignTools.Operations
|
|||
public FitType FitType { get; set; } = FitType.Box;
|
||||
|
||||
public double Width { get; set; }
|
||||
|
||||
public double Depth { get; set; }
|
||||
|
||||
public double Diameter { get; set; }
|
||||
public double Height { get; set; }
|
||||
|
||||
public double Height { get; set; }
|
||||
|
||||
[Description("Set the rules for how to maintain the part while scaling.")]
|
||||
public MaintainRatio MaintainRatio { get; set; } = MaintainRatio.X_Y;
|
||||
|
||||
[Description("Allows you turn on and off applying the fit to the x axis.")]
|
||||
public bool StretchX { get; set; } = true;
|
||||
|
||||
[Description("Allows you turn on and off applying the fit to the y axis.")]
|
||||
public bool StretchY { get; set; } = true;
|
||||
|
||||
[Description("Allows you turn on and off applying the fit to the z axis.")]
|
||||
public bool StretchZ { get; set; } = true;
|
||||
|
||||
IObject3D ScaleItem => Children.First();
|
||||
private IObject3D ScaleItem => Children.First();
|
||||
|
||||
[JsonIgnore]
|
||||
public IObject3D ItemToScale => Children.First().Children.First();
|
||||
|
||||
|
|
@ -103,6 +119,7 @@ namespace MatterHackers.MatterControl.DesignTools.Operations
|
|||
list.AddRange(ScaleItem.Children);
|
||||
});
|
||||
}
|
||||
|
||||
Parent?.Invalidate(new InvalidateArgs(this, InvalidateType.Children));
|
||||
}
|
||||
|
||||
|
|
@ -150,7 +167,7 @@ namespace MatterHackers.MatterControl.DesignTools.Operations
|
|||
|
||||
public static async Task<FitToBoundsObject3D> Create(IObject3D itemToFit)
|
||||
{
|
||||
FitToBoundsObject3D fitToBounds = new FitToBoundsObject3D();
|
||||
var fitToBounds = new FitToBoundsObject3D();
|
||||
var aabb = itemToFit.GetAxisAlignedBoundingBox();
|
||||
|
||||
fitToBounds.Width = aabb.XSize;
|
||||
|
|
@ -193,10 +210,12 @@ namespace MatterHackers.MatterControl.DesignTools.Operations
|
|||
{
|
||||
size.X = Width;
|
||||
}
|
||||
|
||||
if (StretchY)
|
||||
{
|
||||
size.Y = Depth;
|
||||
}
|
||||
|
||||
if (StretchZ)
|
||||
{
|
||||
size.Z = Height;
|
||||
|
|
@ -215,10 +234,12 @@ namespace MatterHackers.MatterControl.DesignTools.Operations
|
|||
{
|
||||
scale.X = Width / aabb.XSize;
|
||||
}
|
||||
|
||||
if (StretchY)
|
||||
{
|
||||
scale.Y = Depth / aabb.YSize;
|
||||
}
|
||||
|
||||
if (StretchZ)
|
||||
{
|
||||
scale.Z = Height / aabb.ZSize;
|
||||
|
|
@ -259,7 +280,7 @@ namespace MatterHackers.MatterControl.DesignTools.Operations
|
|||
var minXyz = center - new Vector3(Width / 2, Depth / 2, Height / 2);
|
||||
var maxXyz = center + new Vector3(Width / 2, Depth / 2, Height / 2);
|
||||
var bounds = new AxisAlignedBoundingBox(minXyz, maxXyz);
|
||||
//var leftW = Vector3Ex.Transform(, worldMatrix);
|
||||
// var leftW = Vector3Ex.Transform(, worldMatrix);
|
||||
var right = Vector3Ex.Transform(center + new Vector3(Width / 2, 0, 0), worldMatrix);
|
||||
// layer.World.Render3DLine(left, right, Agg.Color.Red);
|
||||
layer.World.RenderAabb(bounds, worldMatrix, Agg.Color.Red, 1, 1);
|
||||
|
|
|
|||
|
|
@ -35,7 +35,7 @@ using MatterHackers.Localizations;
|
|||
|
||||
namespace MatterHackers.MatterControl.DesignTools
|
||||
{
|
||||
public class ConeObject3D : PrimitiveObject3D
|
||||
public class ConeObject3D : PrimitiveObject3D, IObjectWithHeight
|
||||
{
|
||||
public ConeObject3D()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -40,7 +40,7 @@ using MatterHackers.VectorMath;
|
|||
|
||||
namespace MatterHackers.MatterControl.DesignTools
|
||||
{
|
||||
public class CylinderObject3D : PrimitiveObject3D, IPropertyGridModifier
|
||||
public class CylinderObject3D : PrimitiveObject3D, IPropertyGridModifier, IObjectWithHeight
|
||||
{
|
||||
public CylinderObject3D()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -35,7 +35,7 @@ using MatterHackers.VectorMath;
|
|||
|
||||
namespace MatterHackers.MatterControl.DesignTools
|
||||
{
|
||||
public class HalfWedgeObject3D : PrimitiveObject3D
|
||||
public class HalfWedgeObject3D : PrimitiveObject3D, IObjectWithHeight
|
||||
{
|
||||
public HalfWedgeObject3D()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -36,7 +36,7 @@ using MatterHackers.VectorMath;
|
|||
|
||||
namespace MatterHackers.MatterControl.DesignTools
|
||||
{
|
||||
public class PyramidObject3D : PrimitiveObject3D
|
||||
public class PyramidObject3D : PrimitiveObject3D, IObjectWithHeight
|
||||
{
|
||||
public PyramidObject3D()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -37,7 +37,7 @@ using MatterHackers.VectorMath;
|
|||
|
||||
namespace MatterHackers.MatterControl.DesignTools
|
||||
{
|
||||
public class RingObject3D : PrimitiveObject3D, IPropertyGridModifier
|
||||
public class RingObject3D : PrimitiveObject3D, IPropertyGridModifier, IObjectWithHeight
|
||||
{
|
||||
public RingObject3D()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -46,7 +46,7 @@ using Newtonsoft.Json.Converters;
|
|||
namespace MatterHackers.MatterControl.DesignTools
|
||||
{
|
||||
[HideChildrenFromTreeView]
|
||||
public class TextObject3D : Object3D, IStaticThumbnail
|
||||
public class TextObject3D : Object3D, IStaticThumbnail, IObjectWithHeight
|
||||
{
|
||||
public TextObject3D()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -38,7 +38,7 @@ using MatterHackers.VectorMath;
|
|||
|
||||
namespace MatterHackers.MatterControl.DesignTools
|
||||
{
|
||||
public class WedgeObject3D : PrimitiveObject3D, IPropertyGridModifier
|
||||
public class WedgeObject3D : PrimitiveObject3D, IPropertyGridModifier, IObjectWithHeight
|
||||
{
|
||||
public WedgeObject3D()
|
||||
{
|
||||
|
|
|
|||
|
|
@ -165,8 +165,7 @@ namespace MatterHackers.MatterControl.PartPreviewWindow
|
|||
// add default controls
|
||||
if (selectedItem is IObjectWithHeight heightObject)
|
||||
{
|
||||
// Object3DControls.Add(new ScaleHeightControl(this));
|
||||
Object3DControls.Add(new ScaleMatrixTopControl(this));
|
||||
Object3DControls.Add(new ScaleHeightControl(this));
|
||||
}
|
||||
else
|
||||
{
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue