use of net.sf.latexdraw.models.interfaces.shape.IPolygon in project latexdraw by arnobl.
the class TestModifyShapeProperty method configureShapes.
private void configureShapes() {
final IGrid grid = ShapeFactory.INST.createGrid(ShapeFactory.INST.createPoint());
final IAxes axes = ShapeFactory.INST.createAxes(ShapeFactory.INST.createPoint());
final IDot dot = ShapeFactory.INST.createDot(ShapeFactory.INST.createPoint());
final ICircle circle = ShapeFactory.INST.createCircle();
final IEllipse ell = ShapeFactory.INST.createEllipse();
final IText txt = ShapeFactory.INST.createText();
final IBezierCurve bc = ShapeFactory.INST.createBezierCurve(Collections.emptyList());
final IPolyline pl = ShapeFactory.INST.createPolyline(Collections.emptyList());
final IPolygon pg = ShapeFactory.INST.createPolygon(Collections.emptyList());
final ITriangle tr = ShapeFactory.INST.createTriangle();
final IRhombus rh = ShapeFactory.INST.createRhombus();
final IRectangle r1 = ShapeFactory.INST.createRectangle();
final IPlot plot = ShapeFactory.INST.createPlot(ShapeFactory.INST.createPoint(), 0d, 1d, "x", false);
final ICircleArc carc = ShapeFactory.INST.createCircleArc();
final ISquare sq = ShapeFactory.INST.createSquare();
final IFreehand fh = ShapeFactory.INST.createFreeHand(Collections.emptyList());
r1.setLineStyle(LineStyle.DASHED);
r1.setBordersPosition(BorderPos.INTO);
r1.setFillingStyle(FillingStyle.PLAIN);
r1.setThickness(2.3);
r1.setHasDbleBord(true);
r1.setLineArc(0.2);
r1.setDbleBordSep(1.3);
r1.setHatchingsAngle(0.33);
r1.setHatchingsSep(9.1);
r1.setHatchingsWidth(12.11);
r1.setShadowAngle(0.1);
r1.setGradMidPt(0.66);
r1.setHatchingsCol(DviPsColors.CYAN);
r1.setLineColour(DviPsColors.NAVYBLUE);
r1.setShadowSize(87.2);
r1.setFillingCol(DviPsColors.CARNATIONPINK);
r1.setShadowCol(DviPsColors.CORNFLOWERBLUE);
r1.setDashSepBlack(1.2);
r1.setDashSepWhite(2.1);
r1.setDotSep(23.1);
r1.setGradAngle(1.3);
r1.setDbleBordCol(DviPsColors.RED);
r1.setGradColEnd(DviPsColors.BITTERSWEET);
r1.setGradColStart(DviPsColors.FORESTGREEN);
r1.setShowPts(true);
final IRectangle r2 = ShapeFactory.INST.createRectangle();
r2.setLineStyle(LineStyle.SOLID);
r2.setBordersPosition(BorderPos.MID);
r2.setFillingStyle(FillingStyle.HLINES);
r2.setThickness(6.3);
r2.setHasShadow(true);
r2.setLineArc(0.33);
r2.setDbleBordSep(2.3);
r2.setHatchingsAngle(-0.53);
r2.setHatchingsSep(1.1);
r2.setHatchingsWidth(2.11);
r2.setShadowAngle(-0.1);
r2.setGradMidPt(0.31);
r2.setHatchingsCol(DviPsColors.APRICOT);
r2.setLineColour(DviPsColors.YELLOW);
r2.setShadowSize(8.1);
r2.setFillingCol(DviPsColors.CERULEAN);
r2.setShadowCol(DviPsColors.DARKORCHID);
r1.setDashSepBlack(11.2);
r1.setDashSepWhite(21.1);
r1.setDotSep(231.1);
r1.setGradAngle(11.3);
r1.setDbleBordCol(DviPsColors.ROYALBLUE);
r1.setGradColEnd(DviPsColors.CADETBLUE);
r1.setGradColStart(DviPsColors.OLIVE);
txt.copy(r1);
ell.copy(r1);
circle.copy(r2);
dot.copy(r2);
bc.copy(r2);
pl.copy(r1);
pg.copy(r2);
tr.copy(r1);
rh.copy(r2);
plot.copy(r1);
carc.copy(r2);
sq.copy(r1);
fh.copy(r2);
group.addShape(r1);
group.addShape(txt);
group.addShape(grid);
group.addShape(pl);
group.addShape(pg);
group.addShape(r2);
group.addShape(axes);
group.addShape(ell);
group.addShape(circle);
group.addShape(tr);
group.addShape(rh);
group.addShape(dot);
group.addShape(bc);
group.addShape(plot);
group.addShape(carc);
group.addShape(sq);
group.addShape(fh);
}
use of net.sf.latexdraw.models.interfaces.shape.IPolygon in project latexdraw by arnobl.
the class LPolygon method duplicate.
@Override
public IPolygon duplicate() {
final IPolygon dup = ShapeFactory.INST.createPolygon(points);
dup.copy(this);
return dup;
}
use of net.sf.latexdraw.models.interfaces.shape.IPolygon in project latexdraw by arnobl.
the class Pencil method bindMultiClic2AddShape.
/**
* Binds a multi-click interaction to creates multi-point shapes.
*/
private void bindMultiClic2AddShape() {
final Function<MultiClick, AddShape> creation = i -> new AddShape(setInitialPtsShape(createShapeInstance(), i.getPoints().get(0)), canvas.getDrawing());
// Binding for polygons
nodeBinder(AddShape.class, new MultiClick(3)).on(canvas).map(creation).then((c, i) -> {
final IPoint currPoint = getAdaptedPoint(i.getCurrentPosition());
if (c.getShape().get().getNbPoints() == i.getPoints().size() && i.getCurrentButton() == MouseButton.PRIMARY) {
c.setShape(ShapeFactory.INST.createPolygonFrom((IPolygon) c.getShape().get(), ShapeFactory.INST.createPoint(currPoint.getX(), currPoint.getY())));
} else {
((IModifiablePointsShape) c.getShape().get()).setPoint(currPoint.getX(), currPoint.getY(), -1);
}
canvas.setTempView(ViewFactory.INSTANCE.createView(c.getShape().orElse(null)).orElse(null));
}).endOrCancel((c, i) -> canvas.setTempView(null)).bind().activationProperty().bind(currentChoice.isEqualTo(EditionChoice.POLYGON).and(activatedProp));
// Binding for polyline
nodeBinder(AddShape.class, new MultiClick()).on(canvas).map(creation).then((c, i) -> {
final IPoint currPoint = getAdaptedPoint(i.getCurrentPosition());
if (c.getShape().get().getNbPoints() == i.getPoints().size() && i.getCurrentButton() == MouseButton.PRIMARY) {
c.setShape(ShapeFactory.INST.createPolylineFrom((IPolyline) c.getShape().get(), ShapeFactory.INST.createPoint(currPoint.getX(), currPoint.getY())));
} else {
((IModifiablePointsShape) c.getShape().get()).setPoint(currPoint.getX(), currPoint.getY(), -1);
}
canvas.setTempView(ViewFactory.INSTANCE.createView(c.getShape().orElse(null)).orElse(null));
}).endOrCancel((c, i) -> canvas.setTempView(null)).bind().activationProperty().bind(currentChoice.isEqualTo(EditionChoice.LINES).and(activatedProp));
// Binding for bézier curves
nodeBinder(AddShape.class, new MultiClick()).on(canvas).map(creation).then((c, i) -> {
final IPoint currPoint = getAdaptedPoint(i.getCurrentPosition());
if (c.getShape().get().getNbPoints() == i.getPoints().size() && i.getCurrentButton() == MouseButton.PRIMARY) {
c.setShape(ShapeFactory.INST.createBezierCurveFrom((IBezierCurve) c.getShape().get(), ShapeFactory.INST.createPoint(currPoint.getX(), currPoint.getY())));
} else {
((IModifiablePointsShape) c.getShape().get()).setPoint(currPoint.getX(), currPoint.getY(), -1);
}
((IControlPointShape) c.getShape().get()).balance();
canvas.setTempView(ViewFactory.INSTANCE.createView(c.getShape().orElse(null)).orElse(null));
}).endOrCancel((c, i) -> canvas.setTempView(null)).bind().activationProperty().bind(currentChoice.isEqualTo(EditionChoice.BEZIER_CURVE).and(activatedProp));
}
use of net.sf.latexdraw.models.interfaces.shape.IPolygon in project latexdraw by arnobl.
the class TestParsingPspolygon method testCoordinatesMm.
@Test
public void testCoordinatesMm() {
parser("\\pspolygon(350mm,200mm)(10mm, 30.3mm)(-10mm, -30.3mm)");
IPolygon line = getShapeAt(0);
assertEquals(3, line.getNbPoints());
assertEquals(35d * IShape.PPC, line.getPtAt(0).getX(), 0.0001);
assertEquals(-20d * IShape.PPC, line.getPtAt(0).getY(), 0.0001);
assertEquals(1d * IShape.PPC, line.getPtAt(1).getX(), 0.0001);
assertEquals(-3.03 * IShape.PPC, line.getPtAt(1).getY(), 0.0001);
assertEquals(-1d * IShape.PPC, line.getPtAt(2).getX(), 0.0001);
assertEquals(3.03 * IShape.PPC, line.getPtAt(2).getY(), 0.0001);
}
use of net.sf.latexdraw.models.interfaces.shape.IPolygon in project latexdraw by arnobl.
the class TestParsingPspolygon method testCoordinatesPt.
@Test
public void testCoordinatesPt() {
parser("\\pspolygon(35pt,20pt)(10pt,5pt)(-10pt,-5pt)");
IPolygon line = getShapeAt(0);
assertEquals(3, line.getNbPoints());
assertEquals(35d * IShape.PPC / PSTricksConstants.CM_VAL_PT, line.getPtAt(0).getX(), 0.0001);
assertEquals(-20d * IShape.PPC / PSTricksConstants.CM_VAL_PT, line.getPtAt(0).getY(), 0.0001);
assertEquals(10d * IShape.PPC / PSTricksConstants.CM_VAL_PT, line.getPtAt(1).getX(), 0.0001);
assertEquals(-5d * IShape.PPC / PSTricksConstants.CM_VAL_PT, line.getPtAt(1).getY(), 0.0001);
assertEquals(-10d * IShape.PPC / PSTricksConstants.CM_VAL_PT, line.getPtAt(2).getX(), 0.0001);
assertEquals(5d * IShape.PPC / PSTricksConstants.CM_VAL_PT, line.getPtAt(2).getY(), 0.0001);
}
Aggregations