3b1b-manim/manimlib/animation/rotation.py

71 lines
1.9 KiB
Python
Raw Normal View History

from __future__ import annotations
from manimlib.animation.animation import Animation
2022-04-12 19:19:59 +08:00
from manimlib.constants import ORIGIN, OUT
from manimlib.constants import PI, TAU
from manimlib.utils.rate_functions import linear
from manimlib.utils.rate_functions import smooth
from typing import TYPE_CHECKING
if TYPE_CHECKING:
import numpy as np
2022-12-14 15:08:20 -08:00
from typing import Callable
from manimlib.mobject.mobject import Mobject
class Rotating(Animation):
def __init__(
self,
mobject: Mobject,
angle: float = TAU,
axis: np.ndarray = OUT,
2022-12-14 15:08:20 -08:00
about_point: np.ndarray | None = None,
about_edge: np.ndarray | None = None,
run_time: float = 5.0,
rate_func: Callable[[float], float] = linear,
suspend_mobject_updating: bool = False,
**kwargs
):
self.angle = angle
self.axis = axis
2022-12-14 15:08:20 -08:00
self.about_point = about_point
self.about_edge = about_edge
super().__init__(
mobject,
run_time=run_time,
rate_func=rate_func,
suspend_mobject_updating=suspend_mobject_updating,
**kwargs
)
def interpolate_mobject(self, alpha: float) -> None:
for sm1, sm2 in self.get_all_families_zipped():
sm1.set_points(sm2.get_points())
self.mobject.rotate(
self.rate_func(alpha) * self.angle,
axis=self.axis,
about_point=self.about_point,
about_edge=self.about_edge,
)
class Rotate(Rotating):
def __init__(
self,
mobject: Mobject,
angle: float = PI,
axis: np.ndarray = OUT,
2022-12-14 15:08:20 -08:00
run_time: float = 1,
rate_func: Callable[[float], float] = smooth,
about_edge: np.ndarray = ORIGIN,
**kwargs
):
2022-12-14 15:08:20 -08:00
super().__init__(
mobject, angle, axis,
run_time=run_time,
rate_func=rate_func,
about_edge=about_edge,
**kwargs
)