mirror of
https://github.com/JannisX11/blockbench.git
synced 2025-01-18 15:26:19 +08:00
Added tool and gizmo for stretching
This commit is contained in:
parent
3b6aba53fc
commit
9dbf99473d
@ -1848,6 +1848,16 @@ const BARS = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
new Tool('stretch_tool', {
|
||||||
|
icon: 'expand',
|
||||||
|
category: 'tools',
|
||||||
|
selectFace: true,
|
||||||
|
transformerMode: 'stretch',
|
||||||
|
toolbar: 'main_tools',
|
||||||
|
alt_tool: 'resize_tool',
|
||||||
|
modes: ['edit'],
|
||||||
|
keybind: new Keybind({key: 's', alt: true}),
|
||||||
|
})
|
||||||
|
|
||||||
//File
|
//File
|
||||||
new Action('new_window', {
|
new Action('new_window', {
|
||||||
@ -2050,6 +2060,7 @@ const BARS = {
|
|||||||
'rotate_tool',
|
'rotate_tool',
|
||||||
'pivot_tool',
|
'pivot_tool',
|
||||||
'vertex_snap_tool',
|
'vertex_snap_tool',
|
||||||
|
'stretch_tool',
|
||||||
'seam_tool',
|
'seam_tool',
|
||||||
'pan_tool',
|
'pan_tool',
|
||||||
'brush_tool',
|
'brush_tool',
|
||||||
|
@ -598,7 +598,8 @@
|
|||||||
|
|
||||||
"translate": new THREE.TransformGizmoTranslate(),
|
"translate": new THREE.TransformGizmoTranslate(),
|
||||||
"scale": new THREE.TransformGizmoScale(),
|
"scale": new THREE.TransformGizmoScale(),
|
||||||
"rotate": new THREE.TransformGizmoRotate()
|
"rotate": new THREE.TransformGizmoRotate(),
|
||||||
|
"stretch": new THREE.TransformGizmoScale()
|
||||||
};
|
};
|
||||||
|
|
||||||
for ( var type in _gizmo ) {
|
for ( var type in _gizmo ) {
|
||||||
@ -732,7 +733,7 @@
|
|||||||
if (Toolbox.selected.transformerMode === 'rotate') {
|
if (Toolbox.selected.transformerMode === 'rotate') {
|
||||||
_gizmo[ _mode ].update( worldRotation, eye );
|
_gizmo[ _mode ].update( worldRotation, eye );
|
||||||
this.rotation.set(0, 0, 0);
|
this.rotation.set(0, 0, 0);
|
||||||
} else if (Toolbox.selected.transformerMode === 'scale') {
|
} else if (Toolbox.selected.transformerMode === 'scale' || Toolbox.selected.transformerMode === 'stretch') {
|
||||||
_gizmo[ _mode ].update( worldRotation, eye );
|
_gizmo[ _mode ].update( worldRotation, eye );
|
||||||
object.getWorldQuaternion(this.rotation)
|
object.getWorldQuaternion(this.rotation)
|
||||||
} else {
|
} else {
|
||||||
@ -798,7 +799,7 @@
|
|||||||
Outliner.selected.forEach(element => {
|
Outliner.selected.forEach(element => {
|
||||||
if (
|
if (
|
||||||
(element.movable && Toolbox.selected.transformerMode == 'translate') ||
|
(element.movable && Toolbox.selected.transformerMode == 'translate') ||
|
||||||
((element.resizable) && Toolbox.selected.transformerMode == 'scale') ||
|
((element.resizable) && (Toolbox.selected.transformerMode == 'scale' || Toolbox.selected.transformerMode == 'stretch')) ||
|
||||||
(element.rotatable && Toolbox.selected.transformerMode == 'rotate')
|
(element.rotatable && Toolbox.selected.transformerMode == 'rotate')
|
||||||
) {
|
) {
|
||||||
scope.attach(element);
|
scope.attach(element);
|
||||||
@ -931,7 +932,7 @@
|
|||||||
|
|
||||||
let space = Transformer.getTransformSpace();
|
let space = Transformer.getTransformSpace();
|
||||||
//Rotation
|
//Rotation
|
||||||
if (space >= 2 || Toolbox.selected.id == 'resize_tool') {
|
if (space >= 2 || Toolbox.selected.id == 'resize_tool' || Toolbox.selected.id == 'stretch_tool') {
|
||||||
Transformer.rotation_ref = Group.selected ? Group.selected.mesh : (selected[0] && selected[0].mesh);
|
Transformer.rotation_ref = Group.selected ? Group.selected.mesh : (selected[0] && selected[0].mesh);
|
||||||
if (Toolbox.selected.id == 'rotate_tool' && Group.selected) {
|
if (Toolbox.selected.id == 'rotate_tool' && Group.selected) {
|
||||||
Transformer.rotation_ref = Group.selected.mesh;
|
Transformer.rotation_ref = Group.selected.mesh;
|
||||||
@ -960,7 +961,7 @@
|
|||||||
if (Toolbox.selected.transformerMode === 'translate') {
|
if (Toolbox.selected.transformerMode === 'translate') {
|
||||||
Transformer.rotation_ref = display_area;
|
Transformer.rotation_ref = display_area;
|
||||||
|
|
||||||
} else if (Toolbox.selected.transformerMode === 'scale') {
|
} else if (Toolbox.selected.transformerMode === 'scale' || Toolbox.selected.transformerMode === 'stretch') {
|
||||||
Transformer.rotation_ref = display_base;
|
Transformer.rotation_ref = display_base;
|
||||||
|
|
||||||
} else if (Toolbox.selected.transformerMode === 'rotate' && display_slot == 'gui') {
|
} else if (Toolbox.selected.transformerMode === 'rotate' && display_slot == 'gui') {
|
||||||
@ -979,7 +980,7 @@
|
|||||||
} else if (Toolbox.selected.id === 'move_tool' && BarItems.transform_space.value === 'global') {
|
} else if (Toolbox.selected.id === 'move_tool' && BarItems.transform_space.value === 'global') {
|
||||||
delete Transformer.rotation_ref;
|
delete Transformer.rotation_ref;
|
||||||
|
|
||||||
} else if (Toolbox.selected.id == 'resize_tool' || (Toolbox.selected.id === 'rotate_tool' && BarItems.rotation_space.value !== 'global')) {
|
} else if (Toolbox.selected.id == 'resize_tool' || Toolbox.selected.id === 'stretch_tool' || (Toolbox.selected.id === 'rotate_tool' && BarItems.rotation_space.value !== 'global')) {
|
||||||
Transformer.rotation_ref = Group.selected.mesh;
|
Transformer.rotation_ref = Group.selected.mesh;
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
@ -1014,6 +1015,7 @@
|
|||||||
var line = main_gizmo.children[axisNumber*2];
|
var line = main_gizmo.children[axisNumber*2];
|
||||||
break;
|
break;
|
||||||
case 'scale':
|
case 'scale':
|
||||||
|
case 'stretch':
|
||||||
var line = main_gizmo.children[(axisNumber*2 + (scope.direction?1:0)) * 2];
|
var line = main_gizmo.children[(axisNumber*2 + (scope.direction?1:0)) * 2];
|
||||||
break;
|
break;
|
||||||
case 'rotate':
|
case 'rotate':
|
||||||
@ -1022,7 +1024,7 @@
|
|||||||
}
|
}
|
||||||
line.scale[axis] = long ? 20000 : 1;
|
line.scale[axis] = long ? 20000 : 1;
|
||||||
if (Toolbox.selected.transformerMode !== 'rotate') {
|
if (Toolbox.selected.transformerMode !== 'rotate') {
|
||||||
line.position[axis] = long ? -10000 : ((scope.direction || Toolbox.selected.transformerMode !== 'scale')?0:-1);
|
line.position[axis] = long ? -10000 : ((scope.direction || (Toolbox.selected.transformerMode !== 'scale' && Toolbox.selected.transformerMode !== 'stretch'))?0:-1);
|
||||||
} else {
|
} else {
|
||||||
line.base_scale[axis] = long ? 20000 : 1;
|
line.base_scale[axis] = long ? 20000 : 1;
|
||||||
}
|
}
|
||||||
@ -1090,7 +1092,7 @@
|
|||||||
scope.last_valid_position.copy(scope.position)
|
scope.last_valid_position.copy(scope.position)
|
||||||
scope.hasChanged = false
|
scope.hasChanged = false
|
||||||
|
|
||||||
if (Toolbox.selected.id === 'resize_tool') {
|
if (Toolbox.selected.id === 'resize_tool' || Toolbox.selected.id === 'stretch_tool') {
|
||||||
scope.direction = scope.axis.substr(0, 1) !== 'N'
|
scope.direction = scope.axis.substr(0, 1) !== 'N'
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1111,7 +1113,7 @@
|
|||||||
|
|
||||||
if (Modes.edit || Modes.pose || Toolbox.selected.id == 'pivot_tool') {
|
if (Modes.edit || Modes.pose || Toolbox.selected.id == 'pivot_tool') {
|
||||||
|
|
||||||
if (Toolbox.selected.id === 'resize_tool') {
|
if (Toolbox.selected.id === 'resize_tool' || Toolbox.selected.id === 'stretch_tool') {
|
||||||
var axisnr = getAxisNumber(scope.axis.toLowerCase().replace('n', ''));
|
var axisnr = getAxisNumber(scope.axis.toLowerCase().replace('n', ''));
|
||||||
selected.forEach(function(obj) {
|
selected.forEach(function(obj) {
|
||||||
if (obj instanceof Mesh) {
|
if (obj instanceof Mesh) {
|
||||||
@ -1121,6 +1123,7 @@
|
|||||||
}
|
}
|
||||||
} else if (obj.resizable) {
|
} else if (obj.resizable) {
|
||||||
obj.oldScale = obj.size(axisnr);
|
obj.oldScale = obj.size(axisnr);
|
||||||
|
obj.oldStretch = obj.stretch.slice();
|
||||||
obj.oldUVOffset = obj.uv_offset.slice();
|
obj.oldUVOffset = obj.uv_offset.slice();
|
||||||
obj.oldCenter = obj.from.map((from, i) => (from + obj.to[i]) / 2);
|
obj.oldCenter = obj.from.map((from, i) => (from + obj.to[i]) / 2);
|
||||||
}
|
}
|
||||||
@ -1306,6 +1309,40 @@
|
|||||||
scope.hasChanged = true
|
scope.hasChanged = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} else if (Toolbox.selected.id === 'stretch_tool') {
|
||||||
|
if (axisB) {
|
||||||
|
if (axis == 'y') {axis = 'z';} else
|
||||||
|
if (axisB == 'y') {axis = 'y';} else
|
||||||
|
if (axisB == 'z') {axis = 'x';}
|
||||||
|
}
|
||||||
|
var snap_factor = canvasGridSize(event.shiftKey || Pressing.overrides.shift, event.ctrlOrCmd || Pressing.overrides.ctrl)
|
||||||
|
let move_value = point[axis];
|
||||||
|
if (axis == 'e') move_value = point.length() * Math.sign(point.y||point.x);
|
||||||
|
move_value = Math.round( move_value / snap_factor ) * snap_factor;
|
||||||
|
move_value *= (scope.direction ? 1 : -1);
|
||||||
|
|
||||||
|
if (previousValue !== move_value) {
|
||||||
|
beforeFirstChange(event)
|
||||||
|
|
||||||
|
selected.forEach(function(obj, i) {
|
||||||
|
if (obj.stretch && obj.oldStretch) {
|
||||||
|
if (axis == 'e') {
|
||||||
|
obj.stretch[0] = obj.oldStretch[0] + move_value;
|
||||||
|
obj.stretch[1] = obj.oldStretch[1] + move_value;
|
||||||
|
obj.stretch[2] = obj.oldStretch[2] + move_value;
|
||||||
|
} else if (!axisB) {
|
||||||
|
obj.stretch[axisNumber] = obj.oldStretch[axisNumber] + move_value;
|
||||||
|
} else {
|
||||||
|
obj.stretch[axisNumber] = obj.oldStretch[axisNumber] + move_value;
|
||||||
|
obj.stretch[axisNumberB] = obj.oldStretch[axisNumberB] + move_value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
displayDistance(move_value);
|
||||||
|
Canvas.updatePositions()
|
||||||
|
previousValue = move_value
|
||||||
|
scope.hasChanged = true
|
||||||
|
}
|
||||||
} else if (Toolbox.selected.id === 'rotate_tool') {
|
} else if (Toolbox.selected.id === 'rotate_tool') {
|
||||||
|
|
||||||
var snap = getRotationInterval(event)
|
var snap = getRotationInterval(event)
|
||||||
@ -1553,7 +1590,7 @@
|
|||||||
Project.display_settings[display_slot][channel][axisNumber] += difference;
|
Project.display_settings[display_slot][channel][axisNumber] += difference;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((event.shiftKey || Pressing.overrides.shift) && channel === 'scale') {
|
if ((event.shiftKey || Pressing.overrides.shift) && (channel === 'scale' || channel === 'stretch')) {
|
||||||
var val = Project.display_settings[display_slot][channel][(axisNumber||0)]
|
var val = Project.display_settings[display_slot][channel][(axisNumber||0)]
|
||||||
Project.display_settings[display_slot][channel][((axisNumber||0)+1)%3] = val
|
Project.display_settings[display_slot][channel][((axisNumber||0)+1)%3] = val
|
||||||
Project.display_settings[display_slot][channel][((axisNumber||0)+2)%3] = val
|
Project.display_settings[display_slot][channel][((axisNumber||0)+2)%3] = val
|
||||||
@ -1596,10 +1633,11 @@
|
|||||||
Blockbench.setCursorTooltip();
|
Blockbench.setCursorTooltip();
|
||||||
|
|
||||||
if (Modes.id === 'edit' || Modes.id === 'pose' || Toolbox.selected.id == 'pivot_tool') {
|
if (Modes.id === 'edit' || Modes.id === 'pose' || Toolbox.selected.id == 'pivot_tool') {
|
||||||
if (Toolbox.selected.id === 'resize_tool') {
|
if (Toolbox.selected.id === 'resize_tool' || Toolbox.selected.id === 'stretch_tool') {
|
||||||
//Scale
|
//Scale
|
||||||
selected.forEach(function(obj) {
|
selected.forEach(function(obj) {
|
||||||
delete obj.oldScale;
|
delete obj.oldScale;
|
||||||
|
delete obj.oldStretch;
|
||||||
delete obj.oldCenter;
|
delete obj.oldCenter;
|
||||||
delete obj.oldUVOffset;
|
delete obj.oldUVOffset;
|
||||||
})
|
})
|
||||||
|
@ -1155,6 +1155,8 @@
|
|||||||
"action.move_tool.desc": "Tool to select and move elements",
|
"action.move_tool.desc": "Tool to select and move elements",
|
||||||
"action.resize_tool": "Resize",
|
"action.resize_tool": "Resize",
|
||||||
"action.resize_tool.desc": "Tool to select and resize elements",
|
"action.resize_tool.desc": "Tool to select and resize elements",
|
||||||
|
"action.stretch_tool": "Stretch",
|
||||||
|
"action.stretch_tool.desc": "Tool to select and stretch elements",
|
||||||
"action.rotate_tool": "Rotate",
|
"action.rotate_tool": "Rotate",
|
||||||
"action.rotate_tool.desc": "Tool to select and rotate elements",
|
"action.rotate_tool.desc": "Tool to select and rotate elements",
|
||||||
"action.pivot_tool": "Pivot Tool",
|
"action.pivot_tool": "Pivot Tool",
|
||||||
|
Loading…
Reference in New Issue
Block a user