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

53 lines
1.4 KiB
Python
Raw Normal View History

from manimlib.animation.animation import Animation
from manimlib.animation.transform import Transform
2019-02-09 15:48:36 -08:00
from manimlib.constants import OUT
from manimlib.constants import PI
from manimlib.constants import TAU
from manimlib.utils.rate_functions import linear
class Rotating(Animation):
CONFIG = {
"axis": OUT,
"radians": TAU,
"run_time": 5,
"rate_func": linear,
"about_point": None,
"about_edge": None,
}
def interpolate_mobject(self, alpha):
2019-02-09 15:48:36 -08:00
self.mobject.become(self.starting_mobject)
self.mobject.rotate(
alpha * self.radians,
axis=self.axis,
about_point=self.about_point,
about_edge=self.about_edge,
)
class Rotate(Transform):
CONFIG = {
"about_point": None,
2019-02-09 15:48:36 -08:00
"about_edge": None,
}
2019-02-09 15:48:36 -08:00
def __init__(self, mobject, angle=PI, axis=OUT, **kwargs):
if "path_arc" not in kwargs:
kwargs["path_arc"] = angle
if "path_arc_axis" not in kwargs:
kwargs["path_arc_axis"] = axis
2019-02-09 15:48:36 -08:00
self.angle = angle
self.axis = axis
super().__init__(mobject, **kwargs)
def create_target(self):
target = self.mobject.copy()
target.rotate(
2019-02-09 15:48:36 -08:00
self.angle,
axis=self.axis,
about_point=self.about_point,
2019-02-09 15:48:36 -08:00
about_edge=self.about_edge,
)
2019-02-09 15:48:36 -08:00
return target