mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-03 19:45:44 -05:00
Merge branch 'master' of git://github.com/Stetson-Team-Alpha/paper.js
This commit is contained in:
commit
799d7cacf1
3 changed files with 153 additions and 5 deletions
35
examples/Tools/SVGCircles.html
Normal file
35
examples/Tools/SVGCircles.html
Normal file
|
@ -0,0 +1,35 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
||||
<title>Circles</title>
|
||||
<link rel="stylesheet" href="../css/style.css">
|
||||
<script type="text/javascript" src="../../dist/paper.js"></script>
|
||||
<script type="text/javascript" src="../../src/svg/ExportSVG.js"></script>
|
||||
<script type="text/paperscript" canvas="canvas">
|
||||
// All newly created items will receive
|
||||
// these style properties:
|
||||
project.currentStyle = {
|
||||
fillColor: 'white',
|
||||
strokeColor: 'black'
|
||||
};
|
||||
|
||||
var path;
|
||||
function onMouseDrag(event) {
|
||||
// The radius is the distance between the position
|
||||
// where the user clicked and the current position
|
||||
// of the mouse.
|
||||
var radius = (event.downPoint - event.point).length;
|
||||
path = new Path.Circle(event.downPoint, radius);
|
||||
var svg = new ExportSVG();
|
||||
var svgout = svg.exportPath(path);
|
||||
console.log(svgout);
|
||||
path.removeOnDrag();
|
||||
|
||||
};
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
<canvas id="canvas" resize></canvas>
|
||||
</body>
|
||||
</html>
|
34
examples/Tools/SVGStars.html
Normal file
34
examples/Tools/SVGStars.html
Normal file
|
@ -0,0 +1,34 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
|
||||
<title>Stars</title>
|
||||
<link rel="stylesheet" href="../css/style.css">
|
||||
<script type="text/javascript" src="../../dist/paper.js"></script>
|
||||
<script type="text/javascript" src="../../src/svg/ExportSVG.js"></script>
|
||||
<script type="text/paperscript" canvas="canvas">
|
||||
function onMouseDown(event) {
|
||||
var hue = Math.random() * 360;
|
||||
project.currentStyle.fillColor = new HsbColor(hue, 1, 1);
|
||||
}
|
||||
|
||||
function onMouseDrag(event) {
|
||||
var delta = event.point - event.downPoint;
|
||||
var radius = delta.length;
|
||||
var points = 5 + Math.round(radius / 50);
|
||||
var position = event.downPoint;
|
||||
var path = new Path.Star(position, points, radius / 2, radius);
|
||||
var svg = new ExportSVG();
|
||||
var svgout = svg.exportPath(path);
|
||||
console.log(svgout);
|
||||
path.rotate(delta.angle);
|
||||
// Remove the path automatically before the next mouse drag
|
||||
// event:
|
||||
path.removeOnDrag();
|
||||
}
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
<canvas id="canvas" resize></canvas>
|
||||
</body>
|
||||
</html>
|
|
@ -7,15 +7,22 @@
|
|||
*/
|
||||
|
||||
|
||||
|
||||
|
||||
var ExportSVG = function()
|
||||
{
|
||||
var svgObj = null; // xml dom object (svg typed)
|
||||
//var blarg = this;
|
||||
|
||||
//initialize the svgObj and what ever else.
|
||||
function initialize()
|
||||
/*function initialize()
|
||||
{
|
||||
var NS = "http://www.w3.org/2000/svg";
|
||||
svgObj = document.createElementNS(NS,"svg");
|
||||
|
||||
};
|
||||
console.log(svgObj);
|
||||
|
||||
};*/
|
||||
|
||||
/**
|
||||
*
|
||||
|
@ -83,8 +90,80 @@ var ExportSVG = function()
|
|||
*/
|
||||
this.exportPath = function(path)
|
||||
{
|
||||
//this.initialize();
|
||||
//console.log(blarg.svgObj);
|
||||
var NS = "http://www.w3.org/2000/svg";
|
||||
svgObj = document.createElementNS(NS,"svg");
|
||||
svgRect = document.createElementNS(NS,"rect");
|
||||
svgRect.height.baseVal.value = 50;
|
||||
svgRect.width.baseVal.value = 60;
|
||||
svgRect.x.baseVal.value = 50;
|
||||
svgObj.appendChild(svgRect);
|
||||
|
||||
svgPoint = document.createElementNS(NS,"point");
|
||||
svgPoint.setAttribute("x",50);
|
||||
svgPoint.setAttribute("y",100);
|
||||
svgObj.appendChild(svgPoint);
|
||||
|
||||
svgPath = document.createElementNS(NS, "path");
|
||||
|
||||
console.log(svgObj);
|
||||
var pathClone = path.clone();
|
||||
var segArray = pathClone.getSegments();
|
||||
|
||||
var pointArray = new Array();
|
||||
for(i = 0; i < segArray.length; i++)
|
||||
{
|
||||
pointArray[i] = segArray[i].getPoint();
|
||||
}
|
||||
var pointString = "";
|
||||
for(i = 0; i < pointArray.length; i++)
|
||||
{
|
||||
var x = pointArray[i].getX();
|
||||
x = x - (x % 1);
|
||||
var y = pointArray[i].getY();
|
||||
y = y - (y % 1);
|
||||
if(i === 0)
|
||||
{
|
||||
pointString+= "M " + x + " " + y + " ";
|
||||
}
|
||||
else
|
||||
{
|
||||
pointString+= "L " + x + " " + y + " ";
|
||||
}
|
||||
}
|
||||
if(pathClone.getClosed())
|
||||
{
|
||||
pointString += "z";
|
||||
}
|
||||
|
||||
var strokeRed = RGBconverter(pathClone.strokeColor.red);
|
||||
var strokeGreen = RGBconverter(pathClone.strokeColor.green);
|
||||
var strokeBlue = RGBconverter(pathClone.strokeColor.blue);
|
||||
var strokeRGB = "#" + strokeRed + strokeGreen + strokeBlue;
|
||||
|
||||
var fillRed = RGBconverter(pathClone.fillColor.red);
|
||||
var fillGreen = RGBconverter(pathClone.fillColor.green);
|
||||
var fillBlue = RGBconverter(pathClone.fillColor.blue);
|
||||
var fillRGB = "#" + fillRed + fillGreen + fillBlue;
|
||||
|
||||
svgPath.setAttribute("d", pointString);
|
||||
svgPath.setAttribute("stroke", strokeRGB);
|
||||
svgPath.setAttribute("fill", fillRGB);
|
||||
svgPath.setAttribute("stroke-width",pathClone.strokeWidth);
|
||||
svgObj.appendChild(svgPath);i
|
||||
|
||||
console.log(svgObj);
|
||||
return svgObj;
|
||||
};
|
||||
|
||||
initialize(); // calls the init function after class is loaded
|
||||
function RGBconverter(deciColor)
|
||||
{
|
||||
var decColor = Math.round(deciColor * 255);
|
||||
var hexColor = decColor.toString(16);
|
||||
hexColor = hexColor.length > 1? hexColor : "0" + hexColor;
|
||||
return hexColor;
|
||||
};
|
||||
|
||||
//initialize(); // calls the init function after class is loaded
|
||||
};
|
Loading…
Reference in a new issue