NumberPlane
是 Manim 中用于创建一个二维坐标平面的类。它可以帮助用户在场景中可视化坐标轴、网格线以及其他数学概念。具体来说,它的功能包括:
-
坐标轴:
NumberPlane
提供了 x 轴和 y 轴,通常是中心对称的,允许用户清楚地看到坐标系的划分。 -
网格线:默认情况下,
NumberPlane
会显示背景网格,这对于展示数学函数、几何形状等非常有帮助。 -
自定义范围:用户可以定义坐标平面的范围,比如 x 和 y 值的最小和最大值。
-
坐标标签:可以为坐标轴添加标签,以便更好地标识坐标系中的具体值。
-
与其他对象的交互:可以将其他形状、函数或动画放置在
NumberPlane
上,从而在动画中展示数学概念。
接下来我看看一下构造函数:
构造函数
class NumberPlane(x_range=(-7.111111111111111, 7.111111111111111, 1), y_range=(-4.0, 4.0,
1), x_length=None, y_length=None, background_line_style=None, faded_line_style=None,
faded_line_ratio=1, make_smooth_after_applying_functions=True, **kwargs)
NumberPlane
类的构造函数允许你创建一个二维坐标平面。以下是参数的详细说明:
参数详解
-
x_range (
tuple
):- 用于定义 x 轴的范围。
- 格式为
(min, max, step)
,其中min
是最小值,max
是最大值,step
是每个网格线之间的间距。 - 示例:
(-7, 7, 1)
表示 x 轴从 -7 到 7,网格线间隔为 1。
-
y_range (
tuple
):- 用于定义 y 轴的范围,格式与
x_range
相同。 - 示例:
(-4, 4, 1)
表示 y 轴从 -4 到 4,网格线间隔为 1。
- 用于定义 y 轴的范围,格式与
-
x_length (
float
或None
):- 可选参数,定义 x 轴的长度(像素或单位长度)。
- 如果设置为
None
,则会根据x_range
自动计算。
-
y_length (
float
或None
):- 可选参数,定义 y 轴的长度(像素或单位长度)。
- 如果设置为
None
,则会根据y_range
自动计算。
-
background_line_style (
dict
或None
):- 用于定义背景网格线的样式,如颜色、透明度等。
- 示例:
{'stroke_color': BLUE, 'stroke_width': 2}
。
-
faded_line_style (
dict
或None
):- 定义淡化网格线的样式。这些线条通常用于绘制更淡的背景线。
- 示例:
{'stroke_color': GRAY, 'stroke_opacity': 0.3}
。
-
faded_line_ratio (
float
):- 定义淡化线条与标准线条的比例。
- 默认值是
1
,表示淡化线和背景线会有相同的长度比率。
-
make_smooth_after_applying_functions (
bool
):- 如果设置为
True
,在应用变换函数后会对图形进行平滑处理。
- 如果设置为
-
kwargs:
- 其他参数,可用于进一步的自定义。
示例1:
from manim import *
class NumberPlaneExample01(Scene):
def construct(self):
number_plane = NumberPlane(
x_range=(-7, 7, 1), # x轴范围
y_range=(-4, 4, 1), # y轴范围
x_length=10, # x轴长度
y_length=6, # y轴长度
background_line_style={
"stroke_color": TEAL,
"stroke_width": 4,
"stroke_opacity": 0.6
},
faded_line_style={
"stroke_color": GRAY,
"stroke_opacity": 0.3
},
faded_line_ratio=0.8, # 淡化线与背景线的比例
make_smooth_after_applying_functions=True # 启用平滑处理
)
# 添加 NumberPlane 到场景
self.add(number_plane)
# 展示一些文字
title = Text("Number Plane Example").to_edge(UP)
self.add(title)
# 稍等一会儿,以便观看结果
self.wait(2)
参数说明
- x_range: 设置 x 轴的范围为 -7 到 7,步长为 1。
- y_range: 设置 y 轴的范围为 -4 到 4,步长为 1。
- x_length: 设置 x 轴的长度为 10(单位像素)。
- y_length: 设置 y 轴的长度为 6(单位像素)。
- background_line_style: 设置背景线的样式,包含颜色、宽度和透明度。
- faded_line_style: 设置淡化线的样式,通常用于更淡的背景线。
- faded_line_ratio: 比例设置为 0.8,表示淡化线条与标准线条长度的关系。
- make_smooth_after_applying_functions: 启用对应用函数后的平滑处理。
运行结果:
示例2:
from manim import *
class NumberPlaneExample(Scene):
def construct(self):
number_plane = NumberPlane(
background_line_style={
"stroke_color": TEAL,
"stroke_width": 4,
"stroke_opacity": 0.6
}
)
self.add(number_plane)
运行结果:
示例3:
class NumberPlaneScaled(Scene):
def construct(self):
number_plane = NumberPlane(
x_range=(-4, 11, 1),
y_range=(-3, 13, 1),
x_length=5,
y_length=5,
).move_to(LEFT*3)
number_plane_scaled_y = NumberPlane(
x_range=(-4, 11, 1),
x_length=5,
y_length=4,
).move_to(RIGHT*3)
self.add(number_plane)
self.add(number_plane_scaled_y)
运行结果: