2011-03-09 10:15:01 -05:00
|
|
|
<!DOCTYPE html>
|
|
|
|
<html>
|
|
|
|
<head>
|
|
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
|
|
|
<title>Example</title>
|
2011-05-05 11:25:17 -04:00
|
|
|
<link rel="stylesheet" href="../css/style.css">
|
2011-06-12 14:03:18 -04:00
|
|
|
<script type="text/javascript" src="../../dist/paper.js"></script>
|
2011-03-09 10:15:01 -05:00
|
|
|
<script type="text/paperscript" canvas="canvas">
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
// Values
|
|
|
|
|
|
|
|
var values = {
|
|
|
|
radius: 10,
|
|
|
|
tolerance: 5
|
|
|
|
};
|
|
|
|
|
|
|
|
checkValues();
|
|
|
|
|
2011-05-16 08:33:15 -04:00
|
|
|
project.currentStyle = {
|
2011-03-09 10:15:01 -05:00
|
|
|
strokeColor: 'black',
|
|
|
|
strokeWidth: 5,
|
|
|
|
strokeCap: 'round'
|
|
|
|
};
|
|
|
|
|
|
|
|
/////////////////////////////////////////////////////////////////////
|
|
|
|
// Mouse handling
|
|
|
|
|
|
|
|
var handle;
|
|
|
|
function checkValues() {
|
|
|
|
var min = values.radius * 2;
|
|
|
|
if (values.tolerance < min) values.tolerance = min;
|
|
|
|
handle = values.radius * 0.5522847498; // kappa
|
|
|
|
}
|
|
|
|
|
|
|
|
var path;
|
|
|
|
function onMouseDown(event) {
|
|
|
|
path = new Path();
|
|
|
|
path.segments = [event.point, event.point];
|
|
|
|
prevPoint = path.firstSegment.point;
|
|
|
|
curPoint = path.lastSegment.point;
|
|
|
|
curHandleSeg = null;
|
|
|
|
}
|
|
|
|
|
|
|
|
function onMouseUp(event) {
|
|
|
|
// path.pointsToCurves(0, 0, 1, 0.001);
|
|
|
|
}
|
|
|
|
|
|
|
|
var curPoint, prevPoint, curHandleSeg;
|
|
|
|
function onMouseDrag(event) {
|
|
|
|
var point = event.point;
|
|
|
|
var diff = (point - prevPoint).abs();
|
|
|
|
if (diff.x < diff.y) {
|
|
|
|
curPoint.x = prevPoint.x;
|
|
|
|
curPoint.y = point.y;
|
|
|
|
} else {
|
|
|
|
curPoint.x = point.x;
|
|
|
|
curPoint.y = prevPoint.y;
|
|
|
|
}
|
|
|
|
var normal = curPoint - prevPoint;
|
|
|
|
normal.length = 1;
|
|
|
|
if (curHandleSeg) {
|
|
|
|
curHandleSeg.point = prevPoint + (normal * values.radius);
|
|
|
|
curHandleSeg.handleIn = normal * -handle;
|
|
|
|
}
|
|
|
|
var minDiff = Math.min(diff.x, diff.y);
|
|
|
|
if (minDiff > values.tolerance) {
|
|
|
|
var point = curPoint - (normal * values.radius);
|
|
|
|
var segment = new Segment(point, null, normal * handle);
|
|
|
|
path.insert(path.segments.length - 1, segment);
|
|
|
|
curHandleSeg = path.lastSegment;
|
|
|
|
// clone as we want the unmodified one:
|
|
|
|
prevPoint = curHandleSeg.point.clone();
|
2011-03-25 13:57:49 -04:00
|
|
|
path.add(curHandleSeg);
|
2011-03-09 10:15:01 -05:00
|
|
|
curPoint = path.lastSegment.point;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
</script>
|
|
|
|
</head>
|
|
|
|
<body>
|
2011-06-29 07:44:06 -04:00
|
|
|
<canvas id="canvas" resize></canvas>
|
2011-05-30 18:27:39 -04:00
|
|
|
</body>
|
|
|
|
</html>
|