diff --git a/docs/adv_traffic_manager.md b/docs/adv_traffic_manager.md index baa6c72aa..5e4296620 100644 --- a/docs/adv_traffic_manager.md +++ b/docs/adv_traffic_manager.md @@ -356,7 +356,7 @@ for actor in my_vehicles: ### 停止交通管理器 -TM 不是一个需要被摧毁的参与者;当创建它的客户端停止时,它将停止。这是由 API 自动管理的,用户无需执行任何操作。但是,在关闭 TM 时,用户必须摧毁由它控制的车辆,否则它们将在地图上保持不动。 `generate_traffic.py `脚本会自动执行此操作: +交通管理器是一个不需要被销毁的参与者;当创建它的客户端停止时,它将停止。这是由 API 自动管理的,用户无需执行任何操作。但是,在关闭交通管理器时,用户必须销毁由它控制的车辆,否则它们将在地图上保持不动。 `generate_traffic.py `脚本会自动执行此操作: ```py client.apply_batch([carla.command.DestroyActor(x) for x in vehicles_list]) diff --git a/docs/benchmark_creating.md b/docs/benchmark_creating.md index beca4833d..37c727628 100644 --- a/docs/benchmark_creating.md +++ b/docs/benchmark_creating.md @@ -9,6 +9,7 @@ 驾驶基准测试与其他两个模块相关联。代理模块是另一个模块(实验套件)中执行的控制器。这两个模块都是抽象类,必须由用户重新定义。 以下代码摘录是如何应用驾驶基准的示例; + ```python # 我们实例化了一个转发代理,这是一个简单的策略, # 只需将加速度设置为0.9,将转向设置为零 @@ -89,7 +90,7 @@ def test_weathers(self): ``` ## 构建实验 -实验由一组姿势定义的任务组成。让我们从选择其中一个城市的姿势开始,以 Town01 为例。首先,我们需要查看所有可能的位置,为此,在终端中运行 CARLA 模拟器,运行: +实验由一组姿势定义的任务组成。让我们从选择其中一个城市的姿势开始,以 Town01 为例。首先,我们需要查看所有可能的位置,为此,在终端中运行 CARLA 模拟器,运行 [view_start_positions.py](https://github.com/OpenHUTB/Self_Driving_Car_Trajectory_Tracking/blob/main/PythonClient/view_start_positions.py) : ```shell python view_start_positions.py ``` @@ -156,7 +157,7 @@ experiments_vector = [] ``` -完整代码可以在 [basic_experiment_suite.py](https://github.com/carla-simulator/carla/blob/master/PythonClient/carla/driving_benchmark/experiment_suites/basic_experiment_suite.py) 找到。 +完整代码可以在 [basic_experiment_suite.py](https://github.com/OpenHUTB/Self_Driving_Car_Trajectory_Tracking/blob/main/PythonClient/carla/driving_benchmark/experiment_suites/basic_experiment_suite.py) 找到。 ## 预期结果 diff --git a/docs/catalogue_vehicles.md b/docs/catalogue_vehicles.md index 50e2f74f7..a00a0dfcb 100644 --- a/docs/catalogue_vehicles.md +++ b/docs/catalogue_vehicles.md @@ -127,7 +127,7 @@ vehicle = world.spawn_actor(vehicle_bp, vehicle_trans) spectator.set_transform(camera_trans) ``` -在尝试生成另一辆车之前,不要忘记摧毁该车辆以避免碰撞: +在尝试生成另一辆车之前,不要忘记销毁该车辆以避免碰撞: ```py vehicle.destroy() diff --git a/docs/core_actors.md b/docs/core_actors.md index 9ba4b3f73..36e6bd294 100644 --- a/docs/core_actors.md +++ b/docs/core_actors.md @@ -2,14 +2,14 @@ Carla 中的参与者是在仿真中执行动作的元素,他们可以影响其他参与者。Carla 的参与者包括车辆和步行者,也包括传感器、交通标志、红绿灯和观看者。对如何操作它们有充分的了解是至关重要的。 -本节将介绍生成、摧毁、类型以及如何管理它们。然而,可能性几乎是无穷无尽的。实验、查看本文档中的 __教程__,并在 [Carla 论坛](https://github.com/carla-simulator/carla/discussions/) 中分享疑虑和想法。 +本节将介绍生成、销毁、类型以及如何管理它们。然而,可能性几乎是无穷无尽的。实验、查看本文档中的 __教程__,并在 [Carla 论坛](https://github.com/carla-simulator/carla/discussions/) 中分享疑虑和想法。 - [__蓝图__](#blueprints) - [管理蓝图库](#managing-the-blueprint-library) - [__参与者生命周期__](#actor-life-cycle) - [生成](#spawning) - [处理](#handling) - - [摧毁](#destruction) + - [销毁](#destruction) - [__参与者类型__](#types-of-actors) - [传感器](#sensors) - [观察者](#spectator) @@ -140,9 +140,9 @@ actor.set_simulate_physics(False) 大多数方法是异步向仿真器发送请求。仿真器每次更新解析它们的时间有限。使用 _set()_ 方法淹没仿真器将积累明显的延迟。 -### 摧毁 +### 销毁 -当 Python 脚本完成时,参与者不会被销毁。他们必须明确地摧毁自己。 +当 Python 脚本完成时,不回销毁参与者。他们必须明确地销毁自己。 ```py destroyed_sucessfully = actor.destroy() # 如果成功返回 True @@ -298,7 +298,7 @@ ai_controller.stop() [carla.Client](python_api.md#carla.Client.apply_batch_sync) 中的一个片段使用批次生成大量步行者并让它们四处游荡。 !!! 重要 - __要摧毁人工智能行人__,请停止人工智能控制器并摧毁参与者和控制器。 + __要销毁人工智能行人__,请停止人工智能控制器并销毁参与者和控制器。 --- 关于 Carla 中的参与者,这就是一个总结。下一步将仔细研究 Carla 的地图、道路和交通。 diff --git a/docs/core_world.md b/docs/core_world.md index 8bd3854ce..0657496e4 100644 --- a/docs/core_world.md +++ b/docs/core_world.md @@ -54,7 +54,7 @@ client.set_timeout(10.0) # 秒 world = client.get_world() ``` -客户端还可以获得可用地图列表来更改当前地图。这将摧毁当前的世界并创造一个新的世界。 +客户端还可以获得可用地图列表来更改当前地图。这将销毁当前的世界并创造一个新的世界。 ```py print(client.get_available_maps()) ... @@ -101,7 +101,7 @@ Python API 参考的 [最新部分](python_api.md#command.ApplyAngularVelocity) 世界上有不同的与参与者相关的方法,允许不同的功能。 -* 生成参与者(但不摧毁他们)。 +* 生成参与者(但不销毁他们)。 * 获得场景中的每一位参与者,或者找到一个特定的参与者 * 访问蓝图库。 * 访问观察参与者、仿真的视角。 diff --git a/docs/examples.md b/docs/examples.md index 206e7a554..3cd2a34ec 100644 --- a/docs/examples.md +++ b/docs/examples.md @@ -12,6 +12,11 @@ python examples/manual_control.py --host localhost --port 2000 --rolename hero - ``` ![](img/interactive_script/manual_control.png) +手动控制行人: +```shell +python examples/manual_control.py --filter walker.pedestrian.* +``` + ### [绘制边界框](https://github.com/OpenHUTB/carla_doc/blob/master/src/examples/sensor_bounding_box.py) 脚本将根据用户指定的视角 `view`(上方`above`、后面`behind`)附加一个 RGB 相机,并在距离`distance`之内绘制所有的参与者。 ```shell diff --git a/docs/foundations.md b/docs/foundations.md index e5d7469df..5d77606b1 100644 --- a/docs/foundations.md +++ b/docs/foundations.md @@ -51,7 +51,7 @@ client.start_recorder('recording.log') ### 世界 -__世界__ 是代表仿真的对象。它充当一个抽象层,包含生成参与者、改变天气、获取世界当前状态等的主要方法。每个仿真只有一个世界。当地图改变时,它会被摧毁并替换为新的。 +__世界__ 是代表仿真的对象。它充当一个抽象层,包含生成参与者、改变天气、获取世界当前状态等的主要方法。每个仿真只有一个世界。当地图改变时,它会被销毁并替换为新的。 使用客户端对象检索世界对象: @@ -188,7 +188,7 @@ world.on_tick(lambda world_snapshot: do_something(world_snapshot)) 记录器文件包括有关许多不同元素的信息。 -* __参与者__ — 创造和摧毁、边界和触发盒。 +* __参与者__ — 创造和销毁、边界和触发盒。 * __交通等__ — 状态变化和时间设置。 * __车辆__ — 位置和方向、线速度和角速度、光状态和物理控制。 * __行人__ — 位置和方向,以及线速度和角速度。 diff --git a/docs/img/Carla.pptx b/docs/img/Carla.pptx index 1dcad21b7..a79ca58e5 100644 Binary files a/docs/img/Carla.pptx and b/docs/img/Carla.pptx differ diff --git a/docs/python_api.md b/docs/python_api.md index 84c19f370..0f20684e3 100644 --- a/docs/python_api.md +++ b/docs/python_api.md @@ -1,4 +1,4 @@ -#Python API 参考 +# [Python API 参考](https://carla.readthedocs.io/en/latest/python_api/) 此参考包含 Python API 的所有详细信息。要查阅特定 Carla 版本的先前参考,请使用右下角的面板更改文档版本。
这会将整个文档更改为之前的状态。请记住, 最新 版本是 `dev` 分支,可能会显示任何 Carla 打包版本中不可用的功能。
## carla.AckermannControllerSettings @@ -487,12 +487,12 @@ Creates a new world with default settings using `map_name` map. All actors in th - **警告:** _`map_layers` 仅对"Opt"地图可用。 _ - **reload_world**(**self**, **reset_settings**=True) -重新加载当前世界,请注意,将使用同一地图使用默认设置创建一个新世界。世界上所有参与者都将被摧毁,__但__ 交通管理器实例将继续存在。 +重新加载当前世界,请注意,将使用同一地图使用默认设置创建一个新世界。世界上所有参与者都将被销毁,__但__ 交通管理器实例将继续存在。 - **参数:** - `reset_settings` (_bool_) - 选项可将情节设置重置为默认值,设置为false可保留当前设置。这对于在更改映射时保持同步模式和保持确定性场景非常有用。 - **Raises:** 对应的运行时错误 RuntimeError。 - **replay_file**(**self**, **name**, **start**, **duration**, **follow_id**, **replay_sensors**) -使用`map_name`加载具有默认设置的新世界。当前世界中的所有参与者都将被摧毁,__但__ 交通管理器实例将继续存在。 +使用`map_name`加载具有默认设置的新世界。当前世界中的所有参与者都将被销毁,__但__ 交通管理器实例将继续存在。 - **参数:** - `name` (_str_) - 包含仿真信息的文件的名称。 - `start` (_float - seconds_) - 开始播放仿真的时间。负数表示从结尾开始读取,在录制结束前10秒为-10。 @@ -2605,7 +2605,7 @@ _ - **参数:** - `r` (_float - 米_) - 启用物理的新半径。 - **set_osm_mode**(**self**, **mode_switch**=True) -启用或禁用 OSM 模式。该模式允许用户在使用 [OSM 功能](tuto_G_openstreetmap.md) 创建的地图中运行 TM。这些地图允许有死胡同。通常,如果车辆无法找到下一个航路点,交通管理器就会崩溃。如果启用 OSM 模式,它将显示警告,并在必要时摧毁车辆。 +启用或禁用 OSM 模式。该模式允许用户在使用 [OSM 功能](tuto_G_openstreetmap.md) 创建的地图中运行 TM。这些地图允许有死胡同。通常,如果车辆无法找到下一个航路点,交通管理器就会崩溃。如果启用 OSM 模式,它将显示警告,并在必要时销毁车辆。 - **参数:** - `mode_switch` (_bool_) - 如果 __True__ ,则启用 OSM 模式。 - **set_path**(**self**, **actor**, **path**) @@ -3167,7 +3167,7 @@ VehiclePhysicsControl 构造函数。 ## carla.Walker 从 _[carla.Actor](#carla.Actor)_ 继承
-该类从 [carla.Actor](#carla.Actor) 继承并定义仿真中的行人。Walkers 是一种特殊类型的 actor,可以由 AI ([carla.WalkerAIController](#carla.WalkerAIController)) 控制,也可以通过脚本手动控制,使用一系列 [carla.WalkerControl](#carla.WalkerControl) 来移动它们及其骨骼。 +该类从 [carla.Actor](#carla.Actor) 继承并定义仿真中的行人。Walkers 是一种特殊类型的参与者,可以由 AI ([carla.WalkerAIController](#carla.WalkerAIController)) 控制,也可以通过脚本手动控制,使用一系列 [carla.WalkerControl](#carla.WalkerControl) 来移动它们及其骨骼。 ### 方法 - **apply_control**(**self**, **control**) @@ -3192,7 +3192,7 @@ VehiclePhysicsControl 构造函数。 - name: 骨骼名称 - world: 世界坐标变换 - component: 基于参与者的枢轴进行变换 - - relative: 基于骨骼父级进行变换。 + - relative: 基于父级骨骼进行变换。 - **返回:** _[carla.WalkerBoneControlOut](#carla.WalkerBoneControlOut)_ - **Setter:** _[carla.Walker.set_bones](#carla.Walker.set_bones)_ - **get_control**(**self**) @@ -3967,7 +3967,7 @@ Actor affected by the command. --- ## command.ApplyVehicleControl -in [carla.Vehicle](#carla.Vehicle) 中 __apply_control()__ 的命令适应。对车辆应用某个控制。 +在 [carla.Vehicle](#carla.Vehicle) 中 __apply_control()__ 命令进行适应,实现对车辆应用某个控制。 ### 实例变量 - **actor_id** (_int_) @@ -4038,7 +4038,7 @@ in [carla.Vehicle](#carla.Vehicle) 中 __apply_control() -[carla.Actor](#carla.Actor) 中 __destroy()__ 命令的改编版,将告诉仿真器摧毁该参与者。如果参与者已经被摧毁则没有影响。当在 [carla.Client](#carla.Client) 中执行 __apply_batch_sync()__ 将会返回一个布尔值状态表示参与者是否被成功摧毁。 +[carla.Actor](#carla.Actor) 中 __destroy()__ 命令的改编版,将告诉仿真器销毁该参与者。如果参与者已经被销毁则没有影响。当在 [carla.Client](#carla.Client) 中执行 __apply_batch_sync()__ 将会返回一个布尔值状态表示参与者是否被成功销毁。 ### 实例变量 - **actor_id** (_int_) diff --git a/docs/ref_recorder_binary_file_format.md b/docs/ref_recorder_binary_file_format.md index c24404bee..a9d9debbd 100644 --- a/docs/ref_recorder_binary_file_format.md +++ b/docs/ref_recorder_binary_file_format.md @@ -185,4 +185,4 @@ ![layout](img/RecorderLayoutSample.jpg) -在**第 1 帧**中,创建了一些参与者并重新设置了父级,因此我们可以在图像中观察其事件。在**第 2 帧**中没有事件。在**第 3 帧**中,一些参与者发生了碰撞,因此碰撞事件会随该信息一起出现。在**第 4 帧**中,参与者被摧毁。 +在**第 1 帧**中,创建了一些参与者并重新设置了父级,因此我们可以在图像中观察其事件。在**第 2 帧**中没有事件。在**第 3 帧**中,一些参与者发生了碰撞,因此碰撞事件会随该信息一起出现。在**第 4 帧**中,参与者被销毁。 diff --git a/docs/run_ros.md b/docs/run_ros.md index 5bdc6810d..6f3a710b1 100644 --- a/docs/run_ros.md +++ b/docs/run_ros.md @@ -173,7 +173,7 @@ __2.__ 在另一个终端中,发布到主题 `/carla//vehicle_contr | 主题 | 类型 | 描述 | |-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------| -| `/carla/destroy_object` | [carla_msgs/DestroyObject.srv](https://github.com/carla-simulator/ros-carla-msgs/blob/f75637ce83a0b4e8fbd9818980c9b11570ff477c/srv/DestroyObject.srv) | 摧毁一个物体 | +| `/carla/destroy_object` | [carla_msgs/DestroyObject.srv](https://github.com/carla-simulator/ros-carla-msgs/blob/f75637ce83a0b4e8fbd9818980c9b11570ff477c/srv/DestroyObject.srv) | 销毁一个物体 | | `/carla/get_blueprints` | [carla_msgs/GetBlueprints.srv](https://github.com/carla-simulator/ros-carla-msgs/blob/f75637ce83a0b4e8fbd9818980c9b11570ff477c/srv/GetBlueprints.srv) | 获取蓝图 | | `/carla/spawn_object` | [carla_msgs/SpawnObject.srv](https://github.com/carla-simulator/ros-carla-msgs/blob/f75637ce83a0b4e8fbd9818980c9b11570ff477c/srv/SpawnObject.srv) | 生成一个对象 | diff --git a/docs/todo.md b/docs/todo.md index 3fd60b70c..ebf47a5c3 100644 --- a/docs/todo.md +++ b/docs/todo.md @@ -14,22 +14,34 @@ ## 学术研究 ### [感知](algorithms/perception.md) -目标跟踪、再识别、语义分割、骨架识别等。 +车辆/行人: +检测、跟踪、再识别、语义分割、行为建模、对抗训练、多模态融合、惯视融合等。 + +行人: +过马路和不过马路分类、姿态自编码(增加所提取骨架的质量)、姿态估计、姿态抬升;运动重定向、风格迁移; ### [规划](algorithms/planning.md) -[定位](algorithms/localization.md) 、惯视融合、建图、规划、决策。 +建图、[定位](algorithms/localization.md) 、规划、决策。 + +决策的伦理和公平。 ### [控制](algorithms/control.md) PID、基于模型的控制。 +通过 `carla.Walker.set_bones()` 对行人骨骼进行变换。 + ### 场景 -* 智能体、[智能驾驶](https://openhutb.github.io/carla_doc/ecosys_iss/) 、机器人、无人机等。 +* 代理、[智能驾驶](https://openhutb.github.io/carla_doc/ecosys_iss/) 等。 * 提供数据孪生建筑生成的 Python 接口。 +### 代理 +* 虚拟人预测驾驶行为的神经激活结构 +驾驶、行走、站立、跑步; -## 艺术改进 + +## 艺术增强 * 场景的自动化建模(删除):道路、[建筑](https://github.com/chenzhaiyu/footprint-detection) 等; * 资产:道路、建筑、[行人](https://github.com/EpicGames/MetaHuman-DNA-Calibration) 、车辆、树木等; * [体积雾、雪、脏](https://bitbucket.org/carla-simulator/carla-content/pull-requests/382) 的支持; @@ -39,10 +51,16 @@ PID、基于模型的控制。 https://bitbucket.org/carla-simulator/carla-content Unreal/CarlaUE4/Content/Carla ``` -参考[行人构建流程](https://ww2.mathworks.cn/help/roadrunner-scenario/ug/import-custom-character-meshes.html) 。 +* [中电软件园](https://overpass-api.de/api/map?bbox=112.8671,28.2281,112.8873,28.2412) 新安装apkpure,再安装RealityScan +### 行人 +参考[行人构建流程](https://ww2.mathworks.cn/help/roadrunner-scenario/ug/import-custom-character-meshes.html) 。 + +* 未定位功能:跑步;未实现功能:交谈、叫出租车、坐下。 + + ### 虚幻引擎 * 引擎优化:[文档](https://github.com/OpenHUTB/engine_doc) 本地化整理。 diff --git a/docs/tuto_G_control_walker_skeletons.md b/docs/tuto_G_control_walker_skeletons.md index 9518282ba..a1be6d481 100644 --- a/docs/tuto_G_control_walker_skeletons.md +++ b/docs/tuto_G_control_walker_skeletons.md @@ -11,10 +11,10 @@ !!! 笔记 **本文档假设用户熟悉 Python API。**。
用户在阅读本文档之前应阅读第一步教程: - [核心概念](core_concepts.md)。进行行人建模请参考[链接](./tuto_content_authoring_pedestrians.md) 。 + [核心概念](foundations.md)。进行行人建模请参考[链接](./tuto_content_authoring_pedestrians.md) 。 --- -## 行人骨骼结构 +## 行人骨骼结构 所有行人都具有相同的骨骼层次结构和骨骼名称。下面是骨架层次结构的图像。骨骼的层次结构图参考[链接](./tuto_content_authoring_pedestrians.md) 。 @@ -88,11 +88,11 @@ crl_root ``` --- -## 手动控制行人骨骼 +## 手动控制行人骨骼 以下是如何通过 Carla Python API 更改步行者骨骼变换的详细分步示例。 -### 连接到仿真器 +### 连接到仿真器 导入本例中使用的必要库 @@ -108,7 +108,7 @@ client = carla.Client('127.0.0.1', 2000) client.set_timeout(2.0) ``` -### 生成行人 +### 生成行人 在地图的一个生成点生成一个随机行人。 @@ -120,7 +120,7 @@ spawn_point = random.choice(spawn_points) if spawn_points else carla.Transform() world.try_spawn_actor(blueprint, spawn_point) ``` -### 控制行人骨骼 +### 控制行人骨骼 可以通过将 `WalkerBoneControl` 类的实例传递给行人的 `apply_control` 函数来修改行人的骨架。`WalkerBoneControl` 类包含要修改的骨骼的变换。它的 `bone_transforms` 成员是成对值元组的列表,其中第一个值是骨骼名称,第二个值是骨骼变换。可以在每个刻度上调用 `apply_control` 函数来为行人的骨骼设置动画。每个变换的位置和旋转都是相对于其父变换的。因此,当修改父骨骼的变换时,子骨骼在模型空间中的变换也会相对改变。 diff --git a/docs/tuto_G_openstreetmap.md b/docs/tuto_G_openstreetmap.md index 5113c6b10..3f6734ad7 100644 --- a/docs/tuto_G_openstreetmap.md +++ b/docs/tuto_G_openstreetmap.md @@ -204,7 +204,7 @@ python3 config.py --osm-path=/path/to/OSM/file
!!! 警告 - 生成的道路在地图的边界处突然结束。当车辆无法找到下一个路径点时,这将导致交通管理器崩溃。为了避免这种情况,流量管理器中的 OSM 模式默认设置为True ( [`set_osm_mode()`](python_api.md#carlatrafficmanager) )。这将在必要时显示警告并摧毁车辆。 + 生成的道路在地图的边界处突然结束。当车辆无法找到下一个路径点时,这将导致交通管理器崩溃。为了避免这种情况,流量管理器中的 OSM 模式默认设置为True ( [`set_osm_mode()`](python_api.md#carlatrafficmanager) )。这将在必要时显示警告并销毁车辆。 --- diff --git a/docs/tuto_G_pedestrian_navigation.md b/docs/tuto_G_pedestrian_navigation.md index d5c7c8299..ef2062d8c 100644 --- a/docs/tuto_G_pedestrian_navigation.md +++ b/docs/tuto_G_pedestrian_navigation.md @@ -265,7 +265,7 @@ for frame in range(0,360): ## 总结 -在本教程中,您学习了如何使用 AI 控制器生成行人,恢复行人骨骼的真实三维坐标,并将这些骨骼投影到相机传感器捕获的二维图像上。您可以使用本教程中学到的技术,使用 Carla 仿真器为人体姿势估计框架设置训练和验证,完整代码[链接](https://github.com/OpenHUTB/carla_doc/blob/master/src/tuto_G_pedestrian_bones.py)。 +在本教程中,您学习了如何使用 AI 控制器生成行人,恢复行人骨骼的真实三维坐标,并将这些骨骼投影到相机传感器捕获的二维图像上。您可以使用本教程中学到的技术,使用 Carla 仿真器为人体姿势估计框架设置训练和验证,完整代码[链接](https://github.com/OpenHUTB/carla_doc/blob/master/src/tuto_G_pedestrian_navigation.py)。 diff --git a/docs/tuto_G_retrieve_data.md b/docs/tuto_G_retrieve_data.md index 2d9b041ef..ad5e0a8a1 100644 --- a/docs/tuto_G_retrieve_data.md +++ b/docs/tuto_G_retrieve_data.md @@ -830,7 +830,7 @@ world.set_weather(weather) 新的仿真与记录没有严格的联系。它可以随时修改,即使记录器停止,仿真也会继续。 -这对于用户来说是有利可图的。例如,可以通过回放几秒钟前的仿真并生成或摧毁参与者来强制或避免碰撞。在特定时刻结束记录也很有用。这样做,车辆可能会采取不同的路径。 +这对于用户来说是有利可图的。例如,可以通过回放几秒钟前的仿真并生成或销毁参与者来强制或避免碰撞。在特定时刻结束记录也很有用。这样做,车辆可能会采取不同的路径。 改变条件并扰乱仿真。没有什么可失去的,因为记录器允许初始仿真始终可以重新进行。这是充分发挥 Carla 潜力的关键。 diff --git a/docs/tuto_first_steps.md b/docs/tuto_first_steps.md index 3f9291c85..19b362df9 100644 --- a/docs/tuto_first_steps.md +++ b/docs/tuto_first_steps.md @@ -219,6 +219,7 @@ Carla 附带了几张预制地图,专注于提供多种功能。这些地图 | [__城镇12__](map_town12.md) | 一张包含许多不同区域的大地图,包括高层建筑、住宅区和乡村环境。 | | [__城镇13__](map_town13.md) | 一张与 12 号镇规模相似的大地图,但具有鲜明的特色。 | | [__城镇15__](map_town15.md) | 基于巴塞罗那自治大学道路布局的地图。 | +| [__HUTB__](https://bitbucket.org/hutbcity/openhutbcarla/src/main/) | 基于湖南工商大学道路布局的地图。 | 您可以浏览 Carla 安装中的可用地图: diff --git a/src/examples/automatic_control.py b/src/examples/automatic_control.py index 02998886b..2407e7161 100644 --- a/src/examples/automatic_control.py +++ b/src/examples/automatic_control.py @@ -6,7 +6,7 @@ # This work is licensed under the terms of the MIT license. # For a copy, see . -"""来自客户端的车辆自动控制示例。""" +"""来自客户端的车辆自动控制示例(启动就进入自动驾驶模式)。""" from __future__ import print_function diff --git a/src/walker/move_jump.py b/src/walker/move_jump.py new file mode 100644 index 000000000..ceb82fd74 --- /dev/null +++ b/src/walker/move_jump.py @@ -0,0 +1,42 @@ +# 行人在生成时跳跃,视角并切换到行人的位置 +import random +import time + +import carla + +client = carla.Client('localhost', 2000) +client.set_timeout(10.0) +print(client.get_available_maps()) # 获取所有可使用地图名 + +world = client.get_world() + +bp = random.choice(world.get_blueprint_library().filter('walker')) +transform = world.get_map().get_spawn_points()[0] +pedestrain = world.spawn_actor(bp, transform) + +# 我们也会设置观察者以便我们能看到我们所做的 +spectator = world.get_spectator() +trans = pedestrain.get_transform() +spectator.set_transform(trans) + +control = carla.WalkerControl() + +i = 0 +while True: + control = carla.WalkerControl() + control.speed = 0.9 + control.direction.y = 1 + control.direction.x = 0 + control.direction.z = 0 + pedestrain.apply_control(control) + time.sleep(1) + + # boolean operation 1 for jump and 0 for not to jump + control.jump = 1 + pedestrain.apply_control(control) + time.sleep(1) + + pedestrain.apply_control(control) + time.sleep(1) + + i += 1 \ No newline at end of file