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

183 lines
5.2 KiB
JavaScript
Raw Normal View History

2019-08-03 15:03:33 +02:00
import * as shared from './shared'
2018-07-24 10:16:31 +00:00
export default (part) => {
let {
store,
sa,
points,
Path,
paths,
Snippet,
snippets,
complete,
paperless,
2021-04-24 10:16:31 +02:00
macro,
options,
2021-08-30 11:40:16 +02:00
utils,
2019-08-03 15:03:33 +02:00
} = part.shorthand()
2018-08-03 17:44:55 +02:00
points.anchor = points.hps.clone()
// Adapt the shoulder seam according to the relevant options
// Note: s3 stands for Shoulder Seam Shift
if (options.s3Collar === 0) {
points.s3CollarSplit = points.hps
paths.backCollar = new Path()
.move(points.hps)
.curve_(points.neckCp2, points.cbNeck)
.setRender(false)
2021-08-30 11:40:16 +02:00
} else if (options.s3Collar > 0) {
// Shift shoulder seam forward on the collar side
points.s3CollarSplit = utils.curveIntersectsY(
points.hps,
points.mirroredNeckCp2Front,
points.mirroredCfNeckCp1,
points.mirroredCfNeck,
store.get('s3CollarMaxFront') * -1 * options.s3Collar
)
paths.backCollar = new Path()
.move(points.hps)
._curve(points.mirroredNeckCp2Front, points.mirroredCfNeckCp1, points.mirroredCfNeck)
.split(points.s3CollarSplit)[0]
.reverse()
2021-08-30 11:40:16 +02:00
.join(new Path().move(points.hps).curve_(points.neckCp2, points.cbNeck))
.setRender(false)
2021-08-30 11:40:16 +02:00
} else if (options.s3Collar < 0) {
// Shift shoulder seam backward on the collar side
points.s3CollarSplit = utils.curveIntersectsY(
2021-08-30 11:40:16 +02:00
points.hps,
points.neckCp2,
points.cbNeck,
points.cbNeck,
store.get('s3CollarMaxBack') * -1 * options.s3Collar
)
paths.backCollar = new Path()
.move(points.cbNeck)
._curve(points.neckCp2, points.neck)
.split(points.s3CollarSplit)[0]
.reverse()
.setRender(false)
}
if (options.s3Armhole === 0) {
points.s3ArmholeSplit = points.shoulder
paths.backArmhole = new Path()
.move(points.armholePitch)
.curve(points.armholePitchCp2, points.shoulderCp1, points.shoulder)
.setRender(false)
2021-08-30 11:40:16 +02:00
} else if (options.s3Armhole > 0) {
// Shift shoulder seam forward on the armhole side
points.s3ArmholeSplit = utils.curveIntersectsY(
points.shoulder,
points.mirroredShoulderCp1,
points.mirroredFrontArmholePitchCp2,
points.mirroredFrontArmholePitch,
store.get('s3ArmholeMax') * -1 * options.s3Armhole + points.shoulder.y
)
paths.backArmhole = new Path()
.move(points.armholePitch)
.curve(points.armholePitchCp2, points.shoulderCp1, points.shoulder)
2021-08-30 11:40:16 +02:00
.join(
new Path()
.move(points.shoulder)
.curve(
points.mirroredShoulderCp1,
points.mirroredFrontArmholePitchCp2,
points.mirroredFrontArmholePitch
)
.split(points.s3ArmholeSplit)[0]
)
.setRender(false)
2021-08-30 11:40:16 +02:00
} else if (options.s3Armhole < 0) {
// Shift shoulder seam backward on the armhole side
points.s3ArmholeSplit = utils.curveIntersectsY(
points.shoulder,
points.shoulderCp1,
points.armholePitchCp2,
points.armholePitch,
store.get('s3ArmholeMax') * -1 * options.s3Armhole + points.shoulder.y
)
paths.backArmhole = new Path()
.move(points.armholePitch)
.curve(points.armholePitchCp2, points.shoulderCp1, points.shoulder)
.split(points.s3ArmholeSplit)[0]
.setRender(false)
}
// Seamline
paths.saBase = new Path()
.move(points.cbHem)
.line(points.hem)
.line(points.armhole)
.curve(points.armholeCp2, points.armholeHollowCp1, points.armholeHollow)
.curve(points.armholeHollowCp2, points.armholePitchCp1, points.armholePitch)
.join(paths.backArmhole)
.line(points.s3CollarSplit)
.join(paths.backCollar)
.setRender(false)
paths.seam = new Path()
.move(points.cbNeck)
.line(points.cbHips)
.join(paths.saBase)
2019-08-03 15:03:33 +02:00
.attr('class', 'fabric')
2018-08-06 16:19:12 +02:00
// Store lengths to fit sleeve
2019-08-03 15:03:33 +02:00
store.set('backArmholeLength', shared.armholeLength(points, Path))
store.set('backShoulderToArmholePitch', shared.shoulderToArmholePitch(points, Path))
2018-07-19 14:43:27 +00:00
// Complete pattern?
if (complete) {
2019-08-03 15:03:33 +02:00
macro('cutonfold', {
from: points.cbNeck,
to: points.cbHips,
2021-04-24 10:16:31 +02:00
grainline: true,
2019-08-03 15:03:33 +02:00
})
2018-08-06 16:19:12 +02:00
2019-08-03 15:03:33 +02:00
macro('title', { at: points.title, nr: 2, title: 'back' })
snippets.armholePitchNotch = new Snippet('bnotch', points.armholePitch)
2021-01-31 09:22:15 +01:00
paths.waist = new Path().move(points.cbWaist).line(points.waist).attr('class', 'help')
if (sa) {
paths.sa = paths.saBase
.offset(sa)
2019-08-03 15:03:33 +02:00
.attr('class', 'fabric sa')
.line(points.cbNeck)
2019-08-03 15:03:33 +02:00
.move(points.cbHips)
paths.sa.line(paths.sa.start())
2018-07-19 14:43:27 +00:00
}
// Add notches if the shoulder seam is shifted
shared.s3Notches(part, 'bnotch')
}
2018-08-03 17:44:55 +02:00
// Paperless?
if (paperless) {
shared.dimensions(part, 'back')
2019-08-03 15:03:33 +02:00
macro('hd', {
from: points.cbHips,
to: points.hips,
y: points.hem.y + sa + 15,
2019-08-03 15:03:33 +02:00
})
macro('vd', {
from: points.cbHem,
to: points.cbWaist,
2021-04-24 10:16:31 +02:00
x: points.cbHips.x - sa - 15,
2019-08-03 15:03:33 +02:00
})
macro('vd', {
from: points.cbHem,
to: points.cbNeck,
2021-04-24 10:16:31 +02:00
x: points.cbHips.x - sa - 30,
})
2019-08-03 15:03:33 +02:00
macro('hd', {
from: points.cbNeck,
to: points.s3CollarSplit,
y: points.s3CollarSplit.y - sa - 15,
2019-08-03 15:03:33 +02:00
})
macro('hd', {
from: points.cbNeck,
to: points.s3ArmholeSplit,
y: points.s3CollarSplit.y - sa - 30,
2019-08-03 15:03:33 +02:00
})
}
2019-08-03 15:03:33 +02:00
return part
}