mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-01 02:38:43 -05:00
120 lines
No EOL
5.1 KiB
HTML
120 lines
No EOL
5.1 KiB
HTML
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
|
<title>Example</title>
|
|
<script type="text/javascript" src="../../lib/bootstrap.js"></script>
|
|
<script type="text/javascript" src="../../lib/parse-js.js"></script>
|
|
<script type="text/javascript" src="../../src/Paper.js"></script>
|
|
<script type="text/javascript" src="../../src/tool/ToolEvent.js"></script>
|
|
<script type="text/javascript" src="../../src/tool/ToolHandler.js"></script>
|
|
<script type="text/javascript" src="../../src/tool/Tool.js"></script>
|
|
<script type="text/javascript" src="../../src/basic/Point.js"></script>
|
|
<script type="text/javascript" src="../../src/basic/Rectangle.js"></script>
|
|
<script type="text/javascript" src="../../src/basic/Size.js"></script>
|
|
<script type="text/javascript" src="../../src/basic/Matrix.js"></script>
|
|
<script type="text/javascript" src="../../src/document/DocumentView.js"></script>
|
|
<script type="text/javascript" src="../../src/document/Document.js"></script>
|
|
<script type="text/javascript" src="../../src/document/Symbol.js"></script>
|
|
<script type="text/javascript" src="../../src/item/Item.js"></script>
|
|
<script type="text/javascript" src="../../src/item/PlacedSymbol.js"></script>
|
|
<script type="text/javascript" src="../../src/item/Group.js"></script>
|
|
<script type="text/javascript" src="../../src/item/Layer.js"></script>
|
|
<script type="text/javascript" src="../../src/item/Raster.js"></script>
|
|
<script type="text/javascript" src="../../src/item/PathStyle.js"></script>
|
|
<script type="text/javascript" src="../../src/path/Segment.js"></script>
|
|
<script type="text/javascript" src="../../src/path/PathItem.js"></script>
|
|
<script type="text/javascript" src="../../src/path/Path.js"></script>
|
|
<script type="text/javascript" src="../../src/path/CompoundPath.js"></script>
|
|
<script type="text/javascript" src="../../src/path/Path.Constructors.js"></script>
|
|
<script type="text/javascript" src="../../src/color/Color.js"></script>
|
|
<script type="text/javascript" src="../../src/color/RGBColor.js"></script>
|
|
<script type="text/javascript" src="../../src/color/GrayColor.js"></script>
|
|
<script type="text/javascript" src="../../src/color/GradientColor.js"></script>
|
|
<script type="text/javascript" src="../../src/color/Gradient.js"></script>
|
|
<script type="text/javascript" src="../../src/color/GradientStop.js"></script>
|
|
<script type="text/javascript" src="../../src/util/BlendMode.js"></script>
|
|
<script type="text/javascript" src="../../src/util/CanvasProvider.js"></script>
|
|
<script type="text/javascript" src="../../src/util/Events.js"></script>
|
|
<script type="text/javascript" src="../../src/util/PaperScript.js"></script>
|
|
<script type="text/paperscript" canvas="canvas">
|
|
document.currentStyle = {
|
|
strokeColor: '#4f7aff',
|
|
strokeWidth: 1
|
|
};
|
|
|
|
var path = new Path();
|
|
path.style = {
|
|
strokeColor: 'black',
|
|
strokeWidth: 1
|
|
};
|
|
var currentSegment;
|
|
var inLine = new Path([0, 0], [0, 0]);
|
|
var outLine = new Path([0, 0], [0, 0]);
|
|
var lastInLine = new Path([0, 0], [0, 0]);
|
|
lastInLine.visible = false;
|
|
|
|
var rect = new Path.Rectangle([0.5, 0.5], [4, 4]);
|
|
rect.fillColor = 'white';
|
|
var rectSymbol = new Symbol(rect);
|
|
|
|
var circle = new Path.Circle(0, 2);
|
|
circle.fillColor = '#4f7aff';
|
|
circle.strokeColor = null;
|
|
var circleSymbol = new Symbol(circle);
|
|
var inCircle = new PlacedSymbol(circleSymbol);
|
|
var outCircle = new PlacedSymbol(circleSymbol);
|
|
var lastInCircle = new PlacedSymbol(circleSymbol);
|
|
inCircle.position = [-100, -100];
|
|
outCircle.position = [-100, -100];
|
|
lastInCircle.position = [-100, -100];
|
|
|
|
var curRect;
|
|
function onMouseDown(event) {
|
|
if (event.count > 1) {
|
|
var first = lastInLine.firstSegment;
|
|
first.point = inLine.firstSegment.point;
|
|
var last = lastInLine.lastSegment;
|
|
last.point = inLine.lastSegment.point;
|
|
lastInLine.visible = true;
|
|
lastInCircle.position = last.point;
|
|
}
|
|
currentSegment = path.add(event.point);
|
|
inLine.firstSegment.point = event.point;
|
|
outLine.firstSegment.point = event.point;
|
|
inLine.lastSegment.point = event.point;
|
|
outLine.lastSegment.point = event.point;
|
|
inLine.visible = true;
|
|
outLine.visible = true;
|
|
|
|
outCircle.position = event.point.round() + [0.5, 0.5];
|
|
inCircle.position = event.point.round() + [0.5, 0.5];
|
|
|
|
var rect = new PlacedSymbol(rectSymbol);
|
|
rect.position = event.point.round() + [0.5, 0.5];
|
|
|
|
curRect = new Path.Rectangle([0.5, 0.5], [4, 4]);
|
|
curRect.position = event.point.round();
|
|
curRect.fillColor = '#4f7aff';
|
|
curRect.strokeWidth = 0;
|
|
}
|
|
|
|
function onMouseDrag(event) {
|
|
var delta = event.point - event.downPoint;
|
|
currentSegment.handleOut = delta;
|
|
currentSegment.handleIn = -delta;
|
|
outLine.lastSegment.point = currentSegment.handleIn + event.downPoint;
|
|
inLine.lastSegment.point = currentSegment.handleOut + event.downPoint;
|
|
outCircle.position = outLine.lastSegment.point;
|
|
inCircle.position = inLine.lastSegment.point;
|
|
}
|
|
|
|
function onMouseUp(event) {
|
|
curRect.remove();
|
|
}
|
|
</script>
|
|
</head>
|
|
<body>
|
|
Click and drag to draw a path:
|
|
<canvas id='canvas' width=1024 height=768></canvas>
|
|
</body> |