# 树莓派(Raspberry Pi) [树莓派](https://raspberrypi.org)是一个单板机,你可以用大量的设备和生态系统来给树莓派加上传感器和执行器,在这些课程中我们使用一个叫做[Grove](https://www.seeedstudio.com/category/Grove-c-1003.html)的硬件生态系统,你将会用Python来给你的Pi编程和读取传感器。 ![一个树莓派 4](../../../../images/raspberry-pi-4.jpg) ## 设置 如果你要使用树莓派来作为你的物联网硬件,那么你有两个选择来完成这些课程 - 直接在树莓派上编码,或者从你的计算机远程连接到无界面的树莓派上来编码。 在你开始之前,你还需要把Grove基础扩展板连接到你的Pi上。 ### 任务 - 设置 安装Grove基础扩展板并配置好你的树莓派 1. 安装Grove基础扩展板到你的树莓派,扩展板上的插孔与Pi上的GPIO引脚一一对应,沿着引脚一路滑下去来压住底部,扩展板会在上面盖住树莓派。 ![安装grove扩展板](../../../../images/pi-grove-hat-fitting.gif) 2. 决定你要如何来编码你的树莓派,并直接跳到下面相关的部分: * [在树莓派上直接编码](#在树莓派上直接编码) * [远程连接来编码树莓派](#远程连接来编码树莓派) ### 在树莓派上直接编码 如果你想要直接在树莓派上编码,你可以使用Raspberry Pi OS的桌面版本并安装你需要的所有工具。 #### 任务 - 在树莓派上直接编码 配置树莓派的开发环境。 1. 跟着[树莓派配置指南](https://projects.raspberrypi.org/en/projects/raspberry-pi-setting-up)的步骤来配置你的树莓派,给它连上一个键盘/鼠标/显示器,把它接入你的Wi-Fi或者以太网络,然后更新软件。你要安装的是**Raspberry Pi OS (32 bit)**,用Raspberry Pi Imager来烧写SD卡的时候一般都会推荐这个操作系统。 想要使用Grove传感器和执行器来给树莓派编程的话,你需要安装一个编辑器来编写设备代码和各种用来与Grove硬件交互的函数库、工具。 1. 当你的树莓派重启后,点击上方菜单栏的**Terminal** 图标或者选择*Menu -> Accessories -> Terminal*来启动终端。 1. 运行下面的命令来确保操作系统和已安装的软件都是最新的: ```sh sudo apt update && sudo apt full-upgrade --yes ``` 1. 运行下面的命令来安装所有Grove硬件需要的函数库: ```sh curl -sL https://github.com/Seeed-Studio/grove.py/raw/master/install.sh | sudo bash -s - ``` Python一个强大的特性是可以安装[pip包](https://pypi.org) - 这些都是其他人编写了发布到网上的软件包,用一个命令你就可以把一个pip包安装到你的计算机上,然后在代码里面使用这个软件包了,这个Grove安装脚本会安装你用Python来操控Grove硬件时将会用到的pip软件包。 1. 用菜单点击或者运行下面的命令来重启树莓派: ```sh sudo reboot ``` 1. 树莓派重启后,重新打开终端并运行下面的命令来安装[Visual Studio Code (VS Code)](https://code.visualstudio.com?WT.mc_id=academic-17441-jabenn) - 你会使用这个编辑器来编写你的设备Python代码。 ```sh sudo apt install code ``` 安装完成后,上面的菜单栏就会出现VS Code了。 > 💁 如果你有更喜欢的工具,你也可以自由使用任意的Python IDE或者编辑器来学习课程,但是课程中会基于VS Code来给出指示。 1. 安装Pylance,这是给VS Code提供Python语言支持的扩展插件,可以参考这个[Pylance扩展文档](https://marketplace.visualstudio.com/items?itemName=ms-python.vscode-pylance&WT.mc_id=academic-17441-jabenn)中的指示在VS Code中安装这个插件。 ### 远程连接来编码树莓派 除了直接在树莓派上编码,它也可以无界面运行,不连接键盘/鼠标/显示器,使用Visual Studio Code从你的计算机来配置和编码树莓派。 #### 配置树莓派操作系统 树莓派操作系统需要被安装在一张SD卡上才能远程编码。 ##### 任务 - 配置树莓派操作系统 配置无界面树莓派系统 1. 从[树莓派操作系统软件页面](https://www.raspberrypi.org/software/)下载**Raspberry Pi Imager**并安装 1. 在你的计算机上插入一张SD卡,必要时需要使用一个转换器 1. 启动Raspberry Pi Imager 1. 在Raspberry Pi Imager点击**CHOOSE OS**,选择*Raspberry Pi OS (Other)*,然后选择*Raspberry Pi OS Lite (32-bit)* ![Raspberry Pi Imager选择Raspberry Pi OS Lite](../../../../images/raspberry-pi-imager.png) > 💁 Raspberry Pi OS Lite是一个没有桌面UI或者基于UI的工具的操作系统版本,这些对于无界面树莓派来说都是不需要的,而且这样可以安装更小的空间、启动速度也更快。 1. 点击**CHOOSE STORAGE** 按钮,然后选择你的SD卡 1. 按下`Ctrl+Shift+X`来启动**Advanced Options**,这些选项允许你在烧写到SD卡之前对Raspberry Pi OS进行一些预配置。 1. 勾选**Enable SSH**,然后给用户`pi`设置一个密码,这是你等会用来登录的密码。 2. 如果你打算通过WiFi连接到树莓派,那么需要勾选**Configure WiFi**,然后输入你WiFi的SSID和密码并选择你的国家码。如果打算使用以太网线缆来连接,那就不需要做这一步了,只需要确保树莓派和你的计算机连接的是同一个网络就行。 3. 勾选**Set locale settings**,设置你的国家和时区。 4. 点击 **SAVE** 按钮 2. 点击**WRITE**按钮把OS烧写到SD卡上,如果你使用的是MacOS,你会被要求输入你的密码,因为底层的写磁盘镜像的工具需要访问权限。 操作系统会被烧写到SD卡上,完成之后SD卡会被弹出,并且你会收到通知。从你的计算机拔出SD卡,再把它插到树莓派上并上电启动。 #### 连接到树莓派 接下来的一个步骤是远程连接树莓派,你可以使用`ssh`,这个工具在macOS、Linux和最近几个版本的Windows上都可以直接使用。 ##### 任务 - 连接到树莓派 远程连接树莓派。 1. 启动一个终端或者命令提示符,输入下面的命令来连接树莓派: ```sh ssh pi@raspberrypi.local ``` 如果你是在一个老版本没有安装`ssh`的Windows上,可以使用OpenSSH,你可以在[OpenSSH安装文档](https://docs.microsoft.com//windows-server/administration/openssh/openssh_install_firstuse?WT.mc_id=academic-17441-jabenn)里找到安装指南。 2. 这应该会连上你的树莓派,并且会请求密码。 通过`.local`来寻找你的网络中的计算机是Linux和Windows最近才加入的功能,如果你是在使用Linux或者Windows过程中遇到一些Hostname无法找到的问题,你会需要安装一些额外的软件来启用ZeroConf网络(也被Apple称为Bonjour): 1. 如果你在使用Linux,用下面的命令来安装Avahi: ```sh sudo apt-get install avahi-daemon ``` 2. 如果你在使用Windows,启用ZeroConf最简单的方法是安装[Bonjour Print Services for Windows](http://support.apple.com/kb/DL999),你也可以安装[iTunes for Windows](https://www.apple.com/itunes/download/)来获取更新版本的组件(无法独立下载安装)。 > 💁 如果你无法通过`raspberrypi.local`连接,那么你也可以使用你的树莓派的IP地址,参考[树莓派IP地址文档](https://www.raspberrypi.org/documentation/remote-access/ip-address.md)上大量的获取IP地址的方法。 3. 输入你在Raspberry Pi Imager高级选项中输入的密码 #### 在树莓派上配置软件 当你连接上树莓派之后,你需要确保这个操作系统是最新的,并且安装各类用于和Grove硬件交互的函数库和工具。 ##### 任务 - 在树莓派上配置软件 配置已安装的树莓派软件并安装Grove的函数库。 1. 从你的`ssh`会话中,运行下面的命令来更新并重启树莓派: ```sh sudo apt update && sudo apt full-upgrade --yes && sudo reboot ``` 树莓派会被更新并重启,这个`ssh`会话在树莓派重启的时候会中断,等待30秒后重连就行。 2. 从重连的`ssh`会话中,运行下面的命令来安装Grove硬件需要的函数库: ```sh curl -sL https://github.com/Seeed-Studio/grove.py/raw/master/install.sh | sudo bash -s - ``` Python一个强大的特性是可以安装[pip包](https://pypi.org) - 这些都是其他人编写了发布到网上的软件包,用一个命令你就可以把一个pip包安装到你的计算机上,然后在代码里面使用这个软件包了,这个Grove安装脚本会安装你用Python来操控Grove硬件时将会用到的pip软件包。 3. 用下面的命令来重启树莓派: ```sh sudo reboot ``` 树莓派重启的时候`ssh`会话会中断,不要再重新连接。 #### 配置VS Code的远程连接 树莓派配置完以后,你可以从你的计算机通过Visual Studio Code (VS Code)来连接到它 - 这是一个你将要用Python来写设备代码的免费开发者编辑器。 ##### 任务 - 配置VS Code的远程连接 安装需要的软件并远程连接到你的树莓派。 1. 跟着[VS Code 文档](https://code.visualstudio.com?WT.mc_id=academic-17441-jabenn)在你的计算机上安装 VS Code 2. 根据[VS Code远程SSH开发文档](https://code.visualstudio.com/docs/remote/ssh?WT.mc_id=academic-17441-jabenn)的步骤来安装需要的组件 3. 根据相同的指示,连接VS Code到树莓派 4. 连接上之后,根据[管理扩展程序](https://code.visualstudio.com/docs/remote/ssh#_managing-extensions?WT.mc_id=academic-17441-jabenn)的指示来远程安装[Pylance扩展程序](https://marketplace.visualstudio.com/items?itemName=ms-python.vscode-pylance&WT.mc_id=academic-17441-jabenn)到树莓派上 ## Hello world 开始一门新的编程语言或者技术时创建一个'Hello World'的程序是一个传统 - 一个输出类似于`"Hello World"`文本的小程序,用来证明所有的工具都已经配置正确了。 树莓派的这个Hello World程序可以确保你已经把Python和Visual Studio Code正确安装了。 这个程序会在一个叫`nightlight`的文件夹里面,他会在这个任务后面部分的不同代码里面再次使用,用来构建夜灯程序。 ### 任务 - hello world 创建Hello World应用。 1. 直接在树莓派上启动VS Code,或者在你的计算机上用远程SSH扩展来连接到树莓派。 2. 选择 *Terminal -> New Terminal* 或者按下`` CTRL+` `` 来启动VS Code,这会打开在`pi`的home目录。 3. 运行下面的命令来为你的代码创建一个目录,并在目录里创建一个叫`app.py`的Python文件: ```sh mkdir nightlight cd nightlight touch app.py ``` 4. 在VS Code中点击*File -> Open...*并选择*nightlight*文件夹和 **OK** 来打开这个文件夹 ![VS Code打开nightlight文件夹的对话框](../../../../images/vscode-open-nightlight-remote.png) 5. 从VS Code窗口打开 `app.py` 文件并增加下面的代码: ```python print('Hello World!') ``` `print`函数会在终端打印任何传递给它的东西。 6. 从VS Code的终端运行下面的命令来运行你的Python应用: ```sh python3 app.py ``` > 💁 你需要显式的调用`python3`来运行这个代码,以防你除了Python 3(最新版本)还安装了Python 2,如果你安装了Python 2,那么调用`python`命令时会使用Python 2 而不是Python 3 终端里会出现下面的输出: ```output pi@raspberrypi:~/nightlight $ python3 app.py Hello World! ``` > 💁 你可以在[code/pi](../code/pi) 文件夹里找到这个代码 😀 你的'Hello World'程序成功了!