mirror of
https://github.com/JannisX11/blockbench.git
synced 2025-01-18 15:26:19 +08:00
Improvements to graph editor
New keyframes inherit interpolation mode Update checkerboard color when updating
This commit is contained in:
parent
b8939212f8
commit
62b735c936
@ -765,7 +765,7 @@
|
|||||||
}
|
}
|
||||||
#timeline_timestamp {
|
#timeline_timestamp {
|
||||||
font-family: var(--font-code);
|
font-family: var(--font-code);
|
||||||
padding: 3px;
|
padding: 2px;
|
||||||
padding-left: 8px;
|
padding-left: 8px;
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
}
|
}
|
||||||
@ -856,13 +856,15 @@
|
|||||||
}
|
}
|
||||||
.channel_axis_selector {
|
.channel_axis_selector {
|
||||||
height: 24px;
|
height: 24px;
|
||||||
|
margin-right: 1px;
|
||||||
display: flex;
|
display: flex;
|
||||||
}
|
}
|
||||||
.channel_axis_selector > div {
|
.channel_axis_selector > div {
|
||||||
font-weight: bolder;
|
font-weight: bolder;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
width: 20px;
|
width: 22px;
|
||||||
height: 24px;
|
height: inherit;
|
||||||
|
padding-top: 2px;
|
||||||
}
|
}
|
||||||
.channel_axis_selector > div.selected {
|
.channel_axis_selector > div.selected {
|
||||||
border-bottom: 3px solid var(--color-accent);
|
border-bottom: 3px solid var(--color-accent);
|
||||||
|
@ -670,13 +670,14 @@ class GeneralAnimator {
|
|||||||
});
|
});
|
||||||
keyframes.push(keyframe);
|
keyframes.push(keyframe);
|
||||||
|
|
||||||
|
keyframe.channel = channel;
|
||||||
|
keyframe.time = time;
|
||||||
|
|
||||||
if (value) {
|
if (value) {
|
||||||
keyframe.extend(value);
|
keyframe.extend(value);
|
||||||
} else if (this.fillValues) {
|
} else if (this.fillValues) {
|
||||||
this.fillValues(keyframe, value, true);
|
this.fillValues(keyframe, value, true);
|
||||||
}
|
}
|
||||||
keyframe.channel = channel;
|
|
||||||
keyframe.time = time;
|
|
||||||
|
|
||||||
this[channel].push(keyframe);
|
this[channel].push(keyframe);
|
||||||
keyframe.animator = this;
|
keyframe.animator = this;
|
||||||
@ -831,7 +832,10 @@ class BoneAnimator extends GeneralAnimator {
|
|||||||
}]
|
}]
|
||||||
})
|
})
|
||||||
} else if (values == null) {
|
} else if (values == null) {
|
||||||
|
let original_time = Timeline.time;
|
||||||
|
Timeline.time = keyframe.time;
|
||||||
var ref = this.interpolate(keyframe.channel, allow_expression)
|
var ref = this.interpolate(keyframe.channel, allow_expression)
|
||||||
|
Timeline.time = original_time;
|
||||||
if (ref) {
|
if (ref) {
|
||||||
let e = 1e2
|
let e = 1e2
|
||||||
ref.forEach((r, i) => {
|
ref.forEach((r, i) => {
|
||||||
@ -847,6 +851,15 @@ class BoneAnimator extends GeneralAnimator {
|
|||||||
}]
|
}]
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
let closest;
|
||||||
|
this[keyframe.channel].forEach(kf => {
|
||||||
|
if (!closest || Math.abs(kf.time - keyframe.time) < Math.abs(closest.time - keyframe.time)) {
|
||||||
|
closest = kf;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
keyframe.extend({
|
||||||
|
interpolation: closest && closest.interpolation
|
||||||
|
})
|
||||||
} else {
|
} else {
|
||||||
keyframe.extend(values)
|
keyframe.extend(values)
|
||||||
}
|
}
|
||||||
|
@ -35,6 +35,7 @@ TimelineMarker.prototype.menu = new Menu([
|
|||||||
{icon: 'flag', color: markerColors[5].standard, name: 'cube.color.'+markerColors[5].name, click: function(marker) {marker.color = 5;}},
|
{icon: 'flag', color: markerColors[5].standard, name: 'cube.color.'+markerColors[5].name, click: function(marker) {marker.color = 5;}},
|
||||||
{icon: 'flag', color: markerColors[6].standard, name: 'cube.color.'+markerColors[6].name, click: function(marker) {marker.color = 6;}},
|
{icon: 'flag', color: markerColors[6].standard, name: 'cube.color.'+markerColors[6].name, click: function(marker) {marker.color = 6;}},
|
||||||
{icon: 'flag', color: markerColors[7].standard, name: 'cube.color.'+markerColors[7].name, click: function(marker) {marker.color = 7;}},
|
{icon: 'flag', color: markerColors[7].standard, name: 'cube.color.'+markerColors[7].name, click: function(marker) {marker.color = 7;}},
|
||||||
|
'_',
|
||||||
{icon: 'delete', name: 'generic.delete', click: function(marker) {
|
{icon: 'delete', name: 'generic.delete', click: function(marker) {
|
||||||
if (Animation.selected) Animation.selected.markers.remove(marker);
|
if (Animation.selected) Animation.selected.markers.remove(marker);
|
||||||
}}
|
}}
|
||||||
@ -426,6 +427,10 @@ const Timeline = {
|
|||||||
})
|
})
|
||||||
i += step;
|
i += step;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (Timeline.vue.graph_editor_open) {
|
||||||
|
Timeline.vue.graph_size += 1e-5;
|
||||||
|
}
|
||||||
},
|
},
|
||||||
updateScroll(e) {
|
updateScroll(e) {
|
||||||
$('.channel_head').css('left', scroll_amount+'px')
|
$('.channel_head').css('left', scroll_amount+'px')
|
||||||
@ -573,12 +578,12 @@ onVueSetup(function() {
|
|||||||
Timeline.vue = new Vue({
|
Timeline.vue = new Vue({
|
||||||
el: '#timeline_vue',
|
el: '#timeline_vue',
|
||||||
data: {
|
data: {
|
||||||
size: 150,
|
size: 200,
|
||||||
length: 10,
|
length: 10,
|
||||||
animation_length: 0,
|
animation_length: 0,
|
||||||
scroll_left: 0,
|
scroll_left: 0,
|
||||||
scroll_top: 0,
|
scroll_top: 0,
|
||||||
head_width: 200,
|
head_width: 196,
|
||||||
timecodes: [],
|
timecodes: [],
|
||||||
animators: Timeline.animators,
|
animators: Timeline.animators,
|
||||||
markers: [],
|
markers: [],
|
||||||
@ -832,6 +837,11 @@ onVueSetup(function() {
|
|||||||
<div id="timeline_header">
|
<div id="timeline_header">
|
||||||
<div id="timeline_corner" v-bind:style="{width: head_width+'px'}">
|
<div id="timeline_corner" v-bind:style="{width: head_width+'px'}">
|
||||||
<div id="timeline_timestamp"></div>
|
<div id="timeline_timestamp"></div>
|
||||||
|
<div class="channel_axis_selector" v-if="graph_editor_open">
|
||||||
|
<div @click="graph_editor_axis = 'x';" :class="{selected: graph_editor_axis == 'x'}" style="color: var(--color-axis-x);">X</div>
|
||||||
|
<div @click="graph_editor_axis = 'y';" :class="{selected: graph_editor_axis == 'y'}" style="color: var(--color-axis-y);">Y</div>
|
||||||
|
<div @click="graph_editor_axis = 'z';" :class="{selected: graph_editor_axis == 'z'}" style="color: var(--color-axis-z);">Z</div>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div id="timeline_time_wrapper">
|
<div id="timeline_time_wrapper">
|
||||||
<div id="timeline_time" v-bind:style="{width: (size*length)+'px', left: -scroll_left+'px'}">
|
<div id="timeline_time" v-bind:style="{width: (size*length)+'px', left: -scroll_left+'px'}">
|
||||||
@ -904,11 +914,6 @@ onVueSetup(function() {
|
|||||||
</template>
|
</template>
|
||||||
</div>
|
</div>
|
||||||
<span>{{ tl('timeline.'+channel) }}</span>
|
<span>{{ tl('timeline.'+channel) }}</span>
|
||||||
<div class="channel_axis_selector" v-if="graph_editor_open && animator.selected && graph_editor_channel == channel">
|
|
||||||
<div @click="graph_editor_axis = 'x';" :class="{selected: graph_editor_axis == 'x'}" style="color: var(--color-axis-x);">X</div>
|
|
||||||
<div @click="graph_editor_axis = 'y';" :class="{selected: graph_editor_axis == 'y'}" style="color: var(--color-axis-y);">Y</div>
|
|
||||||
<div @click="graph_editor_axis = 'z';" :class="{selected: graph_editor_axis == 'z'}" style="color: var(--color-axis-z);">Z</div>
|
|
||||||
</div>
|
|
||||||
<div class="text_button" v-on:click.stop="animator.createKeyframe(null, Timeline.time, channel, true)">
|
<div class="text_button" v-on:click.stop="animator.createKeyframe(null, Timeline.time, channel, true)">
|
||||||
<i class="material-icons">add</i>
|
<i class="material-icons">add</i>
|
||||||
</div>
|
</div>
|
||||||
|
@ -160,6 +160,11 @@ const CustomTheme = {
|
|||||||
CustomTheme.data.colors[key] = legacy_colors[key].hex;
|
CustomTheme.data.colors[key] = legacy_colors[key].hex;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Blockbench.onUpdateTo('3.8', () => {
|
||||||
|
if (CustomTheme.data.colors.checkerboard == '#2f3339') {
|
||||||
|
CustomTheme.data.colors.checkerboard = CustomTheme.defaultColors.checkerboard;
|
||||||
|
}
|
||||||
|
})
|
||||||
},
|
},
|
||||||
import(file) {
|
import(file) {
|
||||||
var data = JSON.parse(file.content)
|
var data = JSON.parse(file.content)
|
||||||
|
Loading…
Reference in New Issue
Block a user