private void NormalPartOfUpdateMultPointCurve(UpdateCurveOperation ucof) { if (polygonEdgeSet.Count >= 2) { List <Point> tpl = new List <Point>(); polygonEdgeSet.ForEach((l) => { tpl.Add(l.firstPoint); }); tpl.Add(curPos); if (oldSelectedCurve != null) { userCanvas.RemoveGraphics(oldSelectedCurve); } oldSelectedCurve = ucof(ref tpl); userCanvas.AddGraphics(oldSelectedCurve); ghs.DrawImage(userCanvas.bmp, this.ClientRectangle); } }
// return true if can clear old graphics private bool NormalPartOfUpdateTwoPointGraphics(CGUserGraphics graphics) { bool ret = false; if (canClearGraphics) { userCanvas.ClearStateOfSelectedGraphics(); userCanvas.RemoveGraphics(curUserGraphics); ret = true; } userCanvas.AddGraphics(graphics); userCanvas.SetGraphicsSelected(graphics); ghs.DrawImage(userCanvas.bmp, this.ClientRectangle); curUserGraphics = graphics; canClearGraphics = true; return(ret); }
private void MainWindow_RightMouseDown(object sender, MouseEventArgs e) { // note: the order of each event when double clicked // down -> up -> down -> dbclick -> up if (buttonClicked == this.buttonDrawPolygon) { // log.write("mouse double click"); if (polygonEdgeSet.Count == 0) { return; } int dx = e.X - polygonEdgeSet[0].firstPoint.X; int dy = e.Y - polygonEdgeSet[0].firstPoint.Y; if (dx * dx + dy * dy > 3 * 3) { CGUserGraphicsLine pline = new CGUserGraphicsLine(new Point(e.X, e.Y), polygonEdgeSet[0].firstPoint); userCanvas.AddGraphics(pline); polygonEdgeSet.Add(pline); } mouseState = CGMouseState.CGMouseStateUp; // log.write("canUpdateGraphics --> false"); canUpdateGraphics = false; isUpdatingGraphicsWhenMouseUp = false; userCanvas.ClearStateOfSelectedGraphics(); polygonEdgeSet.ForEach((l) => { userCanvas.RemoveGraphics(l); }); CGUserGraphicsPolygon polygon = new CGUserGraphicsPolygon(polygonEdgeSet); userCanvas.AddGraphics(polygon); userCanvas.SetGraphicsSelected(polygon); ghs.DrawImage(userCanvas.bmp, this.ClientRectangle); polygonEdgeSet.Clear(); } else if (buttonClicked == this.buttonDrawBezier) { if (polygonEdgeSet.Count <= 1) { return; } if (oldSelectedCurve != null) { userCanvas.RemoveGraphics(oldSelectedCurve); oldSelectedCurve = null; } int dx = e.X - polygonEdgeSet[0].firstPoint.X; int dy = e.Y - polygonEdgeSet[0].firstPoint.Y; List <Point> downPointSet = new List <Point>(); foreach (CGUserGraphicsLine l in polygonEdgeSet) { downPointSet.Add(l.firstPoint); } if (dx * dx + dy * dy < 3 * 3) { downPointSet.Add(polygonEdgeSet[0].firstPoint); } else { downPointSet.Add(polygonEdgeSet[polygonEdgeSet.Count - 1].nextPoint); } mouseState = CGMouseState.CGMouseStateUp; // log.write("canUpdateGraphics --> false"); canUpdateGraphics = false; isUpdatingGraphicsWhenMouseUp = false; userCanvas.ClearStateOfSelectedGraphics(); polygonEdgeSet.ForEach((l) => { userCanvas.RemoveGraphics(l); }); polygonEdgeSet.Clear(); CGUserGraphicsBezier curve = new CGUserGraphicsBezier(downPointSet); userCanvas.AddGraphics(curve); userCanvas.SetGraphicsSelected(curve); ghs.DrawImage(userCanvas.bmp, this.ClientRectangle); downPointSet.Clear(); } else if (buttonClicked == this.buttonDrawBStyleCurve) { if (polygonEdgeSet.Count <= 1) { return; } if (oldSelectedCurve != null) { userCanvas.RemoveGraphics(oldSelectedCurve); oldSelectedCurve = null; } int dx = e.X - polygonEdgeSet[0].firstPoint.X; int dy = e.Y - polygonEdgeSet[0].firstPoint.Y; List <Point> downPointSet = new List <Point>(); foreach (CGUserGraphicsLine l in polygonEdgeSet) { downPointSet.Add(l.firstPoint); } if (dx * dx + dy * dy < 3 * 3) { downPointSet.Add(polygonEdgeSet[0].firstPoint); } else { downPointSet.Add(polygonEdgeSet[polygonEdgeSet.Count - 1].nextPoint); } mouseState = CGMouseState.CGMouseStateUp; // log.write("canUpdateGraphics --> false"); canUpdateGraphics = false; isUpdatingGraphicsWhenMouseUp = false; userCanvas.ClearStateOfSelectedGraphics(); polygonEdgeSet.ForEach((l) => { userCanvas.RemoveGraphics(l); }); polygonEdgeSet.Clear(); CGUserGraphicsBStyleCurve curve = new CGUserGraphicsBStyleCurve(downPointSet); userCanvas.AddGraphics(curve); userCanvas.SetGraphicsSelected(curve); ghs.DrawImage(userCanvas.bmp, this.ClientRectangle); downPointSet.Clear(); } else if (buttonClicked == this.buttonRotation || buttonClicked == this.buttonZoomGraphics) { userCanvas.SetBasePoint(new Point(e.X, e.Y)); ghs.DrawImage(userCanvas.bmp, this.ClientRectangle); } }