1
0
Fork 0
freesewing/packages/brian/src/front.js

82 lines
2.3 KiB
JavaScript
Raw Normal View History

2018-08-03 17:44:55 +02:00
import freesewing from "freesewing";
import base from "./base";
2018-08-06 16:19:12 +02:00
import * as shared from "./shared";
2018-08-03 17:44:55 +02:00
var front = {
draft: function(pattern) {
let part = new pattern.Part().copy(pattern.parts.back);
2018-08-03 17:44:55 +02:00
// prettier-ignore
2018-08-06 16:19:12 +02:00
let {store, sa, Point, points, Path, paths, Snippet, snippets, options, measurements, final, paperless, macro} = freesewing.utils.shorthand(part);
2018-08-06 07:48:37 +02:00
// Cut arm a bit deeper at the front
let deeper = measurements.chestCircumference * options.frontArmholeDeeper;
points.armholeHollowCp2.x -= deeper;
points.armholePitch.x -= deeper;
points.armholePitchCp1.x -= deeper;
2018-08-06 07:48:37 +02:00
// Rename cb (center back) to cf (center front)
for (let key of ["Neck", "Shoulder", "Armhole", "Waist", "Hips"]) {
points[`cf${key}`] = new Point(
points[`cb${key}`].x,
points[`cb${key}`].y
);
delete points[`cb${key}`];
}
// Adapt neck opening
points.cfNeck = points.cfNeck.shift(-90, points.neck.x);
points.neckCp2 = points.cfNeck.shift(0, points.neck.x * 0.7);
2018-08-06 16:19:12 +02:00
paths.seam = shared.seamLine("front", points, Path);
// Store lengths to fit sleeve
store.set("frontArmholeLength", shared.armholeLength(points, Path));
store.set(
"frontShoulderToArmholePitch",
shared.shoulderToArmholePitch(points, Path)
);
// Final?
if (final) {
2018-08-06 16:19:12 +02:00
macro("cutonfold", {
from: points.cfNeck,
to: points.cfHips,
grainline: true
});
macro("title", { at: points.title, nr: 1, title: "front" });
snippets.armholePitchNotch = new Snippet("notch", points.armholePitch);
if (sa) paths.sa = paths.seam.offset(sa).attr("class", "fabric sa");
}
// Paperless?
if (paperless) {
2018-08-06 16:19:12 +02:00
shared.dimensions(macro, points, Path, sa);
macro("hd", {
from: points.cfHips,
to: points.hips,
y: points.hips.y + sa + 15
});
macro("vd", {
from: points.cfHips,
to: points.cfNeck,
x: points.cfHips.x - sa - 15
});
macro("hd", {
from: points.cfNeck,
to: points.neck,
y: points.neck.y - sa - 15
});
2018-08-06 16:19:12 +02:00
macro("hd", {
from: points.cfNeck,
to: points.shoulder,
y: points.neck.y - sa - 30
});
}
2018-08-03 17:44:55 +02:00
return part;
}
};
export default front;