public ShowPropertyLine(Line line, IFrame frame) : base(frame) { this.line = line; startPointProperty = new GeoPointProperty("Line.StartPoint", Frame, true); startPointProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetStartPoint); startPointProperty.SetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.SetGeoPointDelegate(OnSetStartPoint); startPointProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyStartPointWithMouse); startPointProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); endPointProperty = new GeoPointProperty("Line.EndPoint", Frame, true); endPointProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetEndPoint); endPointProperty.SetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.SetGeoPointDelegate(OnSetEndPoint); endPointProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyEndPointWithMouse); endPointProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); lengthProperty = new LengthProperty("Line.Length", Frame, true); lengthProperty.GetLengthEvent += new CADability.UserInterface.LengthProperty.GetLengthDelegate(OnGetLength); lengthProperty.SetLengthEvent += new CADability.UserInterface.LengthProperty.SetLengthDelegate(OnSetLength); lengthProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyLengthWithMouse); lengthProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); lengthHotSpot = new LengthHotSpot(lengthProperty); lengthHotSpot.Position = line.PointAt(2.0 / 3.0); directionProperty = new GeoVectorProperty("Line.Direction", Frame, false); directionProperty.IsNormedVector = true; directionProperty.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetDirection); directionProperty.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetDirection); directionProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyDirectionWithMouse); directionProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); directionHotSpot = new GeoVectorHotSpot(directionProperty); directionHotSpot.Position = line.PointAt(1.0 / 3.0); IPropertyEntry[] sp = line.GetAttributeProperties(Frame); // change signature of GetAttributeProperties attributeProperties = new IPropertyEntry[sp.Length]; for (int i = 0; i < sp.Length; i++) { attributeProperties[i] = sp[i] as IPropertyEntry; } base.resourceId = "Line.Object"; }
private IPropertyEntry[] attributeProperties; // Anzeigen für die Attribute (Ebene, Farbe u.s.w) public ShowPropertyEllipse(Ellipse Ellipse, IFrame frame) : base(frame) { this.ellipse = Ellipse; centerProperty = new GeoPointProperty("Ellipse.Center", Frame, true); centerProperty.SetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.SetGeoPointDelegate(OnSetCenter); centerProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetCenter); centerProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyCenterWithMouse); centerProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); majorRadiusProperty = new LengthProperty("Ellipse.MajorRadius", Frame, true); majorRadiusProperty.SetLengthEvent += new CADability.UserInterface.LengthProperty.SetLengthDelegate(OnSetMajorRadius); majorRadiusProperty.GetLengthEvent += new CADability.UserInterface.LengthProperty.GetLengthDelegate(OnGetMajorRadius); majorRadiusProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyMajorRadiusWithMouse); majorRadiusProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); majorRadiusHotSpot = new LengthHotSpot[2]; majorRadiusHotSpot[0] = new LengthHotSpot(majorRadiusProperty); majorRadiusHotSpot[0].Position = ellipse.Center + 2.0 / 3.0 * ellipse.MajorAxis; majorRadiusHotSpot[1] = new LengthHotSpot(majorRadiusProperty); majorRadiusHotSpot[1].Position = ellipse.Center - 2.0 / 3.0 * ellipse.MajorAxis; minorRadiusProperty = new LengthProperty("Ellipse.MinorRadius", Frame, true); minorRadiusProperty.SetLengthEvent += new CADability.UserInterface.LengthProperty.SetLengthDelegate(OnSetMinorRadius); minorRadiusProperty.GetLengthEvent += new CADability.UserInterface.LengthProperty.GetLengthDelegate(OnGetMinorRadius); minorRadiusProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyMinorRadiusWithMouse); minorRadiusProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); minorRadiusHotSpot = new LengthHotSpot[2]; minorRadiusHotSpot[0] = new LengthHotSpot(minorRadiusProperty); minorRadiusHotSpot[0].Position = ellipse.Center + 2.0 / 3.0 * ellipse.MinorAxis; minorRadiusHotSpot[1] = new LengthHotSpot(minorRadiusProperty); minorRadiusHotSpot[1].Position = ellipse.Center - 2.0 / 3.0 * ellipse.MinorAxis; majorAxisProperty = new GeoVectorProperty("Ellipse.MajorAxis", Frame, true); majorAxisProperty.SetHotspotPosition(ellipse.Center + ellipse.MajorAxis); majorAxisProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyMajorAxisWithMouse); majorAxisProperty.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetMajorAxis); majorAxisProperty.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetMajorAxis); majorAxisProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); majorAxisHotSpot = new GeoVectorHotSpot[2]; majorAxisHotSpot[0] = new GeoVectorHotSpot(majorAxisProperty); majorAxisHotSpot[0].Position = ellipse.Center + ellipse.MajorAxis; majorAxisHotSpot[1] = new GeoVectorHotSpot(majorAxisProperty); majorAxisHotSpot[1].Position = ellipse.Center - ellipse.MajorAxis; minorAxisProperty = new GeoVectorProperty("Ellipse.MinorAxis", Frame, true); minorAxisProperty.SetHotspotPosition(ellipse.Center + ellipse.MinorAxis); minorAxisProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyMinorAxisWithMouse); minorAxisProperty.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetMinorAxis); minorAxisProperty.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetMinorAxis); minorAxisProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); minorAxisHotSpot = new GeoVectorHotSpot[2]; minorAxisHotSpot[0] = new GeoVectorHotSpot(minorAxisProperty); minorAxisHotSpot[0].Position = ellipse.Center + ellipse.MinorAxis; minorAxisHotSpot[1] = new GeoVectorHotSpot(minorAxisProperty); minorAxisHotSpot[1].Position = ellipse.Center - ellipse.MinorAxis; if (Ellipse.IsArc) { startAngleProperty = new AngleProperty("Ellipse.StartAngle", Frame, true); startAngleProperty.GetAngleEvent += new AngleProperty.GetAngleDelegate(OnGetStartAngle); startAngleProperty.SetAngleEvent += new AngleProperty.SetAngleDelegate(OnSetStartAngle); startAngleProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyStartAngleWithMouse); startAngleProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); startAngleHotSpot = new AngleHotSpot(startAngleProperty); startAngleHotSpot.Position = ellipse.StartPoint; endAngleProperty = new AngleProperty("Ellipse.EndAngle", Frame, true); endAngleProperty.GetAngleEvent += new AngleProperty.GetAngleDelegate(OnGetEndAngle); endAngleProperty.SetAngleEvent += new AngleProperty.SetAngleDelegate(OnSetEndAngle); endAngleProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyEndAngleWithMouse); endAngleProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); endAngleHotSpot = new AngleHotSpot(endAngleProperty); endAngleHotSpot.Position = ellipse.EndPoint; directionProperty = new BooleanProperty("Ellipse.Direction", "Arc.Direction.Values"); directionProperty.BooleanValue = ellipse.SweepParameter > 0.0; directionProperty.GetBooleanEvent += new CADability.UserInterface.BooleanProperty.GetBooleanDelegate(OnGetDirection); directionProperty.SetBooleanEvent += new CADability.UserInterface.BooleanProperty.SetBooleanDelegate(OnSetDirection); // hat keinen Hotspot startPointProperty = new GeoPointProperty("Ellipse.StartPoint", Frame, false); startPointProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetStartPoint); startPointProperty.ReadOnly = true; startPointProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); endPointProperty = new GeoPointProperty("Ellipse.EndPoint", Frame, false); endPointProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetEndPoint); endPointProperty.ReadOnly = true; endPointProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); base.resourceId = "EllipseArc.Object"; } else { if (Settings.GlobalSettings.GetBoolValue("CircleShowStartPointProperty", false)) { startAngleProperty = new AngleProperty("Ellipse.StartAngle", Frame, true); startAngleProperty.GetAngleEvent += new AngleProperty.GetAngleDelegate(OnGetStartAngle); startAngleProperty.SetAngleEvent += new AngleProperty.SetAngleDelegate(OnSetStartAngle); startAngleProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyStartAngleWithMouse); startAngleProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); startAngleHotSpot = new AngleHotSpot(startAngleProperty); startAngleHotSpot.Position = ellipse.StartPoint; directionProperty = new BooleanProperty("Ellipse.Direction", "Arc.Direction.Values"); directionProperty.BooleanValue = ellipse.SweepParameter > 0.0; directionProperty.GetBooleanEvent += new CADability.UserInterface.BooleanProperty.GetBooleanDelegate(OnGetDirection); directionProperty.SetBooleanEvent += new CADability.UserInterface.BooleanProperty.SetBooleanDelegate(OnSetDirection); // hat keinen Hotspot startPointProperty = new GeoPointProperty("Ellipse.StartPoint", Frame, false); startPointProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetStartPoint); startPointProperty.ReadOnly = true; startPointProperty.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); } base.resourceId = "Ellipse.Object"; } attributeProperties = ellipse.GetAttributeProperties(Frame); }
private void Init() { // Initialisiert den gesammten Inhalt des TreeViews // danach sollte meist propertyPage.Refresh(this); aufgerufen werden subProperties = null; if (dimension.DimType == Dimension.EDimType.DimPoints || dimension.DimType == Dimension.EDimType.DimCoord) { points = new MultiGeoPointProperty(this, "Dimension.Points", this.Frame); points.ModifyWithMouseEvent += new CADability.UserInterface.MultiGeoPointProperty.ModifyWithMouseIndexDelegate(OnModifyPointWithMouse); points.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnPointsStateChanged); points.GeoPointSelectionChangedEvent += new CADability.UserInterface.GeoPointProperty.SelectionChangedDelegate(OnPointsSelectionChanged); direction = new GeoVectorProperty("Dimension.Direction", Frame, true); direction.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetDirection); direction.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetDirection); } if (dimension.DimType == Dimension.EDimType.DimRadius) { radiusProperty = new DoubleProperty("Dimension.Radius", Frame); radiusProperty.SetDoubleEvent += new CADability.UserInterface.DoubleProperty.SetDoubleDelegate(OnSetRadius); radiusProperty.GetDoubleEvent += new CADability.UserInterface.DoubleProperty.GetDoubleDelegate(OnGetRadius); radiusProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyRadiusWithMouse); radiusProperty.DoubleChanged(); } if (dimension.DimType == Dimension.EDimType.DimDiameter) { radiusProperty = new DoubleProperty("Dimension.Diameter", Frame); radiusProperty.SetDoubleEvent += new CADability.UserInterface.DoubleProperty.SetDoubleDelegate(OnSetRadius); radiusProperty.GetDoubleEvent += new CADability.UserInterface.DoubleProperty.GetDoubleDelegate(OnGetRadius); radiusProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyRadiusWithMouse); radiusProperty.DoubleChanged(); } if (dimension.DimType == Dimension.EDimType.DimDiameter || dimension.DimType == Dimension.EDimType.DimRadius || dimension.DimType == Dimension.EDimType.DimLocation || dimension.DimType == Dimension.EDimType.DimAngle) { // haben alle einen Mittelpunkt als Punkt 0 centerProperty = new GeoPointProperty("Dimension.Center", Frame, true); centerProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetCenter); centerProperty.SetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.SetGeoPointDelegate(OnSetCenter); centerProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyCenterWithMouse); } if (dimension.DimType == Dimension.EDimType.DimAngle) { // start- und Endwinkel startAngle = new GeoVectorProperty("Dimension.Startangle", Frame, true); startAngle.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetStartAngle); startAngle.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetStartAngle); startAngle.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyStartAngleWithMouse); startAngle.SetHotspotPosition(dimension.GetPoint(1)); endAngle = new GeoVectorProperty("Dimension.Endangle", Frame, true); endAngle.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetEndAngle); endAngle.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetEndAngle); endAngle.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyEndAngleWithMouse); endAngle.SetHotspotPosition(dimension.GetPoint(2)); startAngleHotSpot = new GeoVectorHotSpot(startAngle); endAngleHotSpot = new GeoVectorHotSpot(endAngle); } dimLineRef = new GeoPointProperty("Dimension.DimLineRef", Frame, true); dimLineRef.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetDimLineRef); dimLineRef.SetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.SetGeoPointDelegate(OnSetDimLineRef); dimLineRef.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyDimLineRef); dimLineRef.PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); // die String Eingabefelder: int numprop = 1; if (dimension.DimType == Dimension.EDimType.DimPoints || dimension.DimType == Dimension.EDimType.DimCoord) { numprop = dimension.PointCount - 1; } textPosHotSpot = new DoubleHotSpot[numprop]; textPos = new DoubleProperty[numprop]; dimText = new StringProperty[numprop]; tolPlusText = new StringProperty[numprop]; tolMinusText = new StringProperty[numprop]; prefix = new StringProperty[numprop]; postfix = new StringProperty[numprop]; postfixAlt = new StringProperty[numprop]; for (int i = 0; i < numprop; ++i) { textPos[i] = new DoubleProperty("Dimension.TextPos", Frame); textPos[i].UserData.Add("Index", i); textPos[i].GetDoubleEvent += new CADability.UserInterface.DoubleProperty.GetDoubleDelegate(OnGetTextPos); textPos[i].SetDoubleEvent += new CADability.UserInterface.DoubleProperty.SetDoubleDelegate(OnSetTextPos); textPos[i].DoubleChanged(); textPos[i].ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyTextPosWithMouse); textPos[i].PropertyEntryChangedStateEvent += new PropertyEntryChangedStateDelegate(OnStateChanged); textPosHotSpot[i] = new DoubleHotSpot(textPos[i]); textPosHotSpot[i].Position = dimension.GetTextPosCoordinate(i, Frame.ActiveView.Projection); dimText[i] = new StringProperty(dimension.GetDimText(i), "Dimension.DimText"); dimText[i].UserData.Add("Index", i); dimText[i].SetStringEvent += new CADability.UserInterface.StringProperty.SetStringDelegate(OnSetDimText); dimText[i].GetStringEvent += new CADability.UserInterface.StringProperty.GetStringDelegate(OnGetDimText); tolPlusText[i] = new StringProperty(dimension.GetTolPlusText(i), "Dimension.TolPlusText"); tolPlusText[i].UserData.Add("Index", i); tolPlusText[i].SetStringEvent += new CADability.UserInterface.StringProperty.SetStringDelegate(OnSetTolPlusText); tolPlusText[i].GetStringEvent += new CADability.UserInterface.StringProperty.GetStringDelegate(OnGetTolPlusText); tolMinusText[i] = new StringProperty(dimension.GetTolMinusText(i), "Dimension.TolMinusText"); tolMinusText[i].UserData.Add("Index", i); tolMinusText[i].SetStringEvent += new CADability.UserInterface.StringProperty.SetStringDelegate(OnSetTolMinusText); tolMinusText[i].GetStringEvent += new CADability.UserInterface.StringProperty.GetStringDelegate(OnGetTolMinusText); prefix[i] = new StringProperty(dimension.GetPrefix(i), "Dimension.Prefix"); prefix[i].UserData.Add("Index", i); prefix[i].SetStringEvent += new CADability.UserInterface.StringProperty.SetStringDelegate(OnSetPrefix); prefix[i].GetStringEvent += new CADability.UserInterface.StringProperty.GetStringDelegate(OnGetPrefix); postfix[i] = new StringProperty(dimension.GetPostfix(i), "Dimension.Postfix"); postfix[i].UserData.Add("Index", i); postfix[i].SetStringEvent += new CADability.UserInterface.StringProperty.SetStringDelegate(OnSetPostfix); postfix[i].GetStringEvent += new CADability.UserInterface.StringProperty.GetStringDelegate(OnGetPostfix); postfixAlt[i] = new StringProperty(dimension.GetPostfixAlt(i), "Dimension.PostfixAlt"); postfixAlt[i].UserData.Add("Index", i); postfixAlt[i].SetStringEvent += new CADability.UserInterface.StringProperty.SetStringDelegate(OnSetPostfixAlt); postfixAlt[i].GetStringEvent += new CADability.UserInterface.StringProperty.GetStringDelegate(OnGetPostfixAlt); } }
private void InitSubEntries() { vertexProperty = new MultiGeoPointProperty(new VertexIndexedGeoPoint(this), "Polyline.Vertex", this.Frame); vertexProperty.ModifyWithMouseEvent += new CADability.UserInterface.MultiGeoPointProperty.ModifyWithMouseIndexDelegate(OnModifyVertexWithMouse); vertexProperty.GeoPointSelectionChangedEvent += new CADability.UserInterface.GeoPointProperty.SelectionChangedDelegate(OnPointsSelectionChanged); (vertexProperty as IPropertyEntry).PropertyEntryChangedStateEvent += OnVertexPropertyStateChanged; vertexProperty.PrependContextMenue = MenuResource.LoadMenuDefinition("MenuId.Path.Vertex", false, this); if (polyline.IsRectangle) { subEntries = new IPropertyEntry[2]; locationProperty = new GeoPointProperty("Rectangle.Location", Frame, true); locationProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetLocation); locationProperty.SetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.SetGeoPointDelegate(OnSetLocation); locationProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyLocationWithMouse); LengthProperty width = new LengthProperty("Rectangle.Width", Frame, true); width.GetLengthEvent += new CADability.UserInterface.LengthProperty.GetLengthDelegate(OnGetWidth); width.SetLengthEvent += new CADability.UserInterface.LengthProperty.SetLengthDelegate(OnSetWidth); width.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyWidthWithMouse); widthHotSpot = new ShowPropertyHotSpot(width, Frame); widthHotSpot.Position = polyline.RectangleLocation + 0.5 * polyline.ParallelogramSecondaryDirection + polyline.ParallelogramMainDirection; widthHotSpot.PositionChangedEvent += new CADability.UserInterface.ShowPropertyHotSpot.PositionChangedDelegate(OnWidthPositionChanged); LengthProperty height = new LengthProperty("Rectangle.Height", Frame, true); height.GetLengthEvent += new CADability.UserInterface.LengthProperty.GetLengthDelegate(OnGetHeight); height.SetLengthEvent += new CADability.UserInterface.LengthProperty.SetLengthDelegate(OnSetHeight); height.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyHeightWithMouse); heightHotSpot = new ShowPropertyHotSpot(height, Frame); heightHotSpot.Position = polyline.RectangleLocation + polyline.ParallelogramSecondaryDirection + 0.5 * polyline.ParallelogramMainDirection; heightHotSpot.PositionChangedEvent += new CADability.UserInterface.ShowPropertyHotSpot.PositionChangedDelegate(OnHeightPositionChanged); GeoVectorProperty direction = new GeoVectorProperty("Rectangle.Direction", Frame, true); direction.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetDirectionX); direction.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetDirectionX); direction.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyDirectionXWithMouse); directionHotSpot = new GeoVectorHotSpot(direction); directionHotSpot.Position = polyline.RectangleLocation + polyline.ParallelogramMainDirection; sizeHotSpot = new GeoPointHotSpot(polyline.RectangleLocation + polyline.ParallelogramSecondaryDirection + polyline.ParallelogramMainDirection); sizeHotSpot.StartDragHotspotEvent += new GeoPointHotSpot.StartDragHotspotDelegate(OnSizeHotSpotStartDragHotspot); rectangleProperty = new GroupProperty("Polyline.Rectangle", new IPropertyEntry[] { locationProperty, width, height, direction }); subEntries[0] = rectangleProperty; (rectangleProperty as IPropertyEntry).PropertyEntryChangedStateEvent += OnRectanglePropertyStateChanged; subEntries[1] = vertexProperty; } else if (polyline.IsParallelogram) { subEntries = new IPropertyEntry[2]; locationParallelProperty = new GeoPointProperty("Rectangle.Location", Frame, true); locationParallelProperty.GetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.GetGeoPointDelegate(OnGetParallelLocation); locationParallelProperty.SetGeoPointEvent += new CADability.UserInterface.GeoPointProperty.SetGeoPointDelegate(OnSetParallelLocation); locationParallelProperty.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyLocationWithMouse); /* * LengthProperty widthParallel = new LengthProperty("Rectangle.Width",Frame,true); * widthParallel.OnGetLength += new Condor.LengthProperty.GetLengthDelegate(OnGetWidthParallel); * widthParallel.OnSetLength += new Condor.LengthProperty.SetLengthDelegate(OnSetWidthParallel); * widthParallel.ModifyWithMouse += new ModifyWithMouseDelegate(ModifyWidthWithMouse); * widthParallelHotSpot = new ShowPropertyHotSpot(widthParallel,Frame); * widthParallelHotSpot.Position = polyline.ParallelogramLocation+0.5*polyline.ParallelogramSecondaryDirection+polyline.ParallelogramMainDirection; * widthParallelHotSpot.PositionChanged += new Condor.ShowPropertyHotSpot.PositionChangedDelegate(OnWidthParallelPositionChanged); * * LengthProperty heightParallel = new LengthProperty("Rectangle.Height",Frame,true); * heightParallel.OnGetLength += new Condor.LengthProperty.GetLengthDelegate(OnGetHeightParallel); * heightParallel.OnSetLength += new Condor.LengthProperty.SetLengthDelegate(OnSetHeightParallel); * heightParallel.ModifyWithMouse += new ModifyWithMouseDelegate(ModifyHeightParallelWithMouse); * heightParallelHotSpot = new ShowPropertyHotSpot(height,Frame); * heightParallelHotSpot.Position = polyline.ParallelogramLocation+polyline.ParallelogramSecondaryDirection+0.5*polyline.ParallelogramMainDirection; * heightParallelHotSpot.PositionChanged += new Condor.ShowPropertyHotSpot.PositionChangedDelegate(OnHeightPositionChanged); * */ GeoVectorProperty directionXParallel = new GeoVectorProperty("Parallelogram.DirectionX", Frame, true); directionXParallel.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetDirectionXParallel); directionXParallel.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetDirectionXParallel); directionXParallel.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyDirectionXParallelWithMouse); directionXParallelHotSpot = new GeoVectorHotSpot(directionXParallel); directionXParallelHotSpot.Position = polyline.ParallelogramLocation + polyline.ParallelogramMainDirection; GeoVectorProperty directionYParallel = new GeoVectorProperty("Parallelogram.DirectionY", Frame, true); directionYParallel.GetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.GetGeoVectorDelegate(OnGetDirectionYParallel); directionYParallel.SetGeoVectorEvent += new CADability.UserInterface.GeoVectorProperty.SetGeoVectorDelegate(OnSetDirectionYParallel); directionYParallel.ModifyWithMouseEvent += new ModifyWithMouseDelegate(ModifyDirectionXParallelWithMouse); directionYParallelHotSpot = new GeoVectorHotSpot(directionYParallel); directionYParallelHotSpot.Position = polyline.ParallelogramLocation + polyline.ParallelogramSecondaryDirection; // parallelProperty = new GroupProperty("Polyline.Parallel", new IPropertyEntry [] {locationParallelProperty,widthParallel,heightParallel,directionParallel}); sizeHotSpot = new GeoPointHotSpot(polyline.ParallelogramLocation + polyline.ParallelogramSecondaryDirection + polyline.ParallelogramMainDirection); sizeHotSpot.StartDragHotspotEvent += new GeoPointHotSpot.StartDragHotspotDelegate(OnSizeHotSpotStartDragHotspot); parallelProperty = new GroupProperty("Polyline.Parallel", new IPropertyEntry[] { locationParallelProperty, directionXParallel, directionYParallel }); subEntries[0] = parallelProperty; (parallelProperty as IPropertyEntry).PropertyEntryChangedStateEvent += OnParallelPropertyStateChanged; subEntries[1] = vertexProperty; } else { subEntries = new IPropertyEntry[1]; subEntries[0] = vertexProperty; } attributeProperties = polyline.GetAttributeProperties(Frame); }