3b1b-manim/scene/zoomed_scene.py

116 lines
3.8 KiB
Python
Raw Normal View History

2016-02-27 18:50:33 -08:00
import numpy as np
from scene import Scene
from mobject import Mobject
2016-02-29 20:52:25 -08:00
from topics.geometry import Rectangle
2016-02-27 18:50:33 -08:00
from camera import MovingCamera, Camera
from helpers import *
class ZoomedScene(Scene):
CONFIG = {
"zoomed_canvas_space_shape" : (3, 3),
2016-02-29 20:52:25 -08:00
"zoomed_canvas_center" : None,
"zoomed_canvas_corner" : UP+RIGHT,
"zoomed_camera_background" : None,
"zoom_factor" : 6,
"square_color" : WHITE,
"zoom_activated" : False,
2016-02-27 18:50:33 -08:00
}
2016-02-29 20:52:25 -08:00
def activate_zooming(self):
self.generate_big_rectangle()
2016-02-27 18:50:33 -08:00
self.setup_zoomed_canvas()
2016-02-29 20:52:25 -08:00
self.setup_zoomed_camera()
self.zoom_activated = True
2016-02-27 18:50:33 -08:00
2016-02-29 20:52:25 -08:00
def disactivate_zooming(self):
self.remove(self.big_rectangle, self.little_rectangle)
self.zoom_activated = False
def get_zoomed_camera_mobject(self):
return self.little_rectangle
2016-03-07 19:07:00 -08:00
def get_zoomed_screen(self):
return self.big_rectangle
2016-02-29 20:52:25 -08:00
def generate_big_rectangle(self):
2016-02-27 18:50:33 -08:00
height, width = self.zoomed_canvas_space_shape
2016-02-29 20:52:25 -08:00
self.big_rectangle = Rectangle(
height = height,
width = width,
color = self.square_color
)
2016-02-27 18:50:33 -08:00
if self.zoomed_canvas_center is not None:
2016-02-29 20:52:25 -08:00
self.big_rectangle.shift(self.zoomed_canvas_center)
2016-02-27 18:50:33 -08:00
elif self.zoomed_canvas_corner is not None:
2016-02-29 20:52:25 -08:00
self.big_rectangle.to_corner(self.zoomed_canvas_corner)
self.add(self.big_rectangle)
2016-02-27 18:50:33 -08:00
2016-02-29 20:52:25 -08:00
def setup_zoomed_canvas(self):
upper_left = self.big_rectangle.get_corner(UP+LEFT)
lower_right = self.big_rectangle.get_corner(DOWN+RIGHT)
pixel_coords = self.camera.points_to_pixel_coords(
np.array([upper_left, lower_right])
)
2016-02-27 18:50:33 -08:00
self.zoomed_canvas_pixel_indices = pixel_coords
2016-02-29 20:52:25 -08:00
(up, left), (down, right) = pixel_coords
2016-02-27 18:50:33 -08:00
self.zoomed_canvas_pixel_shape = (
2016-02-29 20:52:25 -08:00
down-up,
right-left
)
def setup_zoomed_camera(self):
self.little_rectangle = self.big_rectangle.copy()
self.little_rectangle.scale(1./self.zoom_factor)
self.little_rectangle.center()
self.zoomed_camera = MovingCamera(
self.little_rectangle,
pixel_shape = self.zoomed_canvas_pixel_shape,
background = self.zoomed_camera_background
2016-02-27 18:50:33 -08:00
)
2016-02-29 20:52:25 -08:00
self.add(self.little_rectangle)
2016-03-07 19:07:00 -08:00
#TODO, is there a better way to hanld this?
self.zoomed_camera.adjusted_thickness = lambda x : x
2016-02-27 18:50:33 -08:00
def get_frame(self):
frame = Scene.get_frame(self)
2016-02-29 20:52:25 -08:00
if self.zoom_activated:
(up, left), (down, right) = self.zoomed_canvas_pixel_indices
frame[left:right, up:down, :] = self.zoomed_camera.get_image()
2016-02-27 18:50:33 -08:00
return frame
2016-11-11 11:18:41 -08:00
def set_camera_background(self, background):
self.camera.set_image(background)
if self.zoom_activated:
(up, left), (down, right) = self.zoomed_canvas_pixel_indices
self.zoomed_camera.set_image(background[left:right, up:down])
#TODO, check this..
def reset_camera(self):
self.camera.reset()
2016-02-29 20:52:25 -08:00
if self.zoom_activated:
self.zoomed_camera.reset()
2016-02-27 18:50:33 -08:00
2016-11-11 11:18:41 -08:00
def capture_mobjects_in_camera(self, mobjects, **kwargs):
self.camera.capture_mobjects(mobjects, **kwargs)
if self.zoom_activated:
self.zoomed_camera.capture_mobjects(
mobjects, **kwargs
)
def separate_moving_and_static_mobjects(self, *animations):
moving_mobjects, static_mobjects = Scene.separate_moving_and_static_mobjects(
self, *animations
)
if self.zoom_activated and self.little_rectangle in moving_mobjects:
# When the camera is moving, so is everything...
return self.get_mobjects(), []
else:
return moving_mobjects, static_mobjects
2016-02-27 18:50:33 -08:00