from manimlib.imports import * class tnb(ThreeDScene): def construct(self): t = TextMobject(r'T', color = YELLOW) n = TextMobject(r'N', color = BLUE).next_to(t, RIGHT, buff=0) b = TextMobject(r'B', color = GREEN_E).next_to(n, RIGHT, buff=0) frame = TextMobject(r'Frame').next_to(b, RIGHT, buff=0.2) text = VGroup(*[t,n,b,frame]).move_to(ORIGIN).shift(3*UP) curve = ParametricFunction( lambda t: np.array([ np.sin(TAU*t), np.cos(TAU*t), 0 ]) ).scale(2.5) dot = Dot(color = RED).scale(1.5).shift(1.05*LEFT) tgt = Arrow(dot.get_center(), (-2, 2, 0), color = YELLOW).shift(0.3*DOWN + 0.09*RIGHT) normal = Arrow(tgt.get_start(), (1, 1, 0), color = BLUE).shift(0.2*LEFT + 0.05*DOWN) binormal = Arrow(dot.get_center() - np.array([0,0,0.3]), (tgt.get_start()[0], tgt.get_start()[1],2), color = GREEN) square = Square(color = DARK_BROWN, fill_color = WHITE, fill_opacity=0.3).move_to(tgt.get_start()).rotate(27*DEGREES).shift(UP+0.4*RIGHT).scale(1.2) group = VGroup(*[dot, tgt, normal, square, binormal]).shift(np.array([-1.24,-1,0])) self.add_fixed_in_frame_mobjects(text) self.add(curve, group) self.wait(1) self.move_camera(phi = 75*DEGREES, theta=45*DEGREES, run_time = 2) self.begin_ambient_camera_rotation(rate = 0.5) self.wait(5) self.play(FadeOut(VGroup(*[text, curve, dot, tgt, normal, square, binormal])))