Description
Version
latest
Link to Minimal Reproduction
null
Steps to Reproduce
// 注册所有需要的内容
VStory.registerAll();
const rect = {
graphic: {
stroke: false,
fill: 'pink'
},
text: {
text: '这是一个矩形',
textBaseline: 'middle',
textAlign: 'center',
fill: 'white'
}
};
const text = {
graphic: {
text: '这是一个文本',
fontSize: 12,
fontWeight: 'bold',
fill: 'red',
textAlign: 'left',
textBaseline: 'top'
},
panel: {
fill: 'blue',
cornerRadius: 30
}
};
const image = {
rotate: 45,
angle: 45,
graphic: {
rotate: 45,
angle: 45,
stroke: false,
image:
''
}
};
const shape = {
graphic: {
stroke: 'red',
symbolType: 'star'
}
};
const arc = {
graphic: {
innerRadius: 20,
startAngle: 0,
endAngle: Math.PI * 2,
fill: 'orange'
}
};
const polygon = {
graphic: {
points: [
{ x: 50 + (200 / (2 * Math.sqrt(3))) * Math.cos(0), y: 50 + (200 / (2 * Math.sqrt(3))) * Math.sin(0) },
{
x: 50 + (200 / (2 * Math.sqrt(3))) * Math.cos(Math.PI / 3),
y: 50 + (200 / (2 * Math.sqrt(3))) * Math.sin(Math.PI / 3)
},
{
x: 50 + (200 / (2 * Math.sqrt(3))) * Math.cos((2 * Math.PI) / 3),
y: 50 + (200 / (2 * Math.sqrt(3))) * Math.sin((2 * Math.PI) / 3)
},
{
x: 50 + (200 / (2 * Math.sqrt(3))) * Math.cos(Math.PI),
y: 50 + (200 / (2 * Math.sqrt(3))) * Math.sin(Math.PI)
},
{
x: 50 + (200 / (2 * Math.sqrt(3))) * Math.cos((4 * Math.PI) / 3),
y: 50 + (200 / (2 * Math.sqrt(3))) * Math.sin((4 * Math.PI) / 3)
},
{
x: 50 + (200 / (2 * Math.sqrt(3))) * Math.cos((5 * Math.PI) / 3),
y: 50 + (200 / (2 * Math.sqrt(3))) * Math.sin((5 * Math.PI) / 3)
}
],
fill: {
gradient: 'linear',
x0: 0,
y0: 0,
x1: 1,
y1: 0,
stops: [
{ offset: 0, color: 'green' },
{ offset: 0.5, color: 'orange' },
{ offset: 1, color: 'red' }
]
}
}
};
const characterList = [
{ type: 'Rect', options: rect, effect: 'scale' },
{ type: 'Text', options: text, effect: 'typewriter' },
{ type: 'Image', options: image, effect: 'wipe', angle: 45 },
{ type: 'Shape', options: shape, effect: 'clipRange' },
{ type: 'Polygon', options: polygon, effect: 'fade' },
{ type: 'Arc', options: arc, effect: 'growAngle' }
];
const story = new VStory.Story(null, {
dom: CONTAINER_ID,
width: 500,
height: 400,
scaleX: 'auto',
scaleY: 'auto',
background: '#ebecf0'
});
const player = new VStory.Player(story);
story.init(player);
characterList.forEach((item, index) => {
story.addCharacter(
{
type: item.type,
id: item.type,
zIndex: 1,
position: {
top: 50 + Math.floor(index / 3) * 150,
left: 50 + Math.floor(index % 3) * 150,
width: 100,
height: 100
},
options: item.options
},
{
sceneId: 'defaultScene',
actions: [
{
action: 'appear',
startTime: 1000 * index,
payload: [
{
animation: {
duration: 1000,
easing: 'linear',
// effect: item.effect
}
}
]
}
]
}
);
});
player.play(1);
window['story'] = story;
window['vstory'] = story;
Current Behavior
没有旋转
Expected Behavior
可以旋转
Environment
- OS:
- Browser:
- Framework:
Any additional comments?
No response