From fca9ab6ee700357537a6b7f6f9ba69f1ed21fe30 Mon Sep 17 00:00:00 2001 From: Neucrack Date: Fri, 10 May 2024 15:07:03 +0800 Subject: [PATCH] optimize __init__ and add maixvision auto compleletion doc --- .github/workflows/build_maixcam.yml | 2 +- docs/doc/en/basic/maixvision.md | 16 ++++++++++++++++ docs/doc/zh/basic/maixvision.md | 14 ++++++++++++++ maix/__init__.py | 15 +++++++++++---- maix/version.py | 4 ++-- 5 files changed, 44 insertions(+), 7 deletions(-) diff --git a/.github/workflows/build_maixcam.yml b/.github/workflows/build_maixcam.yml index dd87312f..43a540b0 100755 --- a/.github/workflows/build_maixcam.yml +++ b/.github/workflows/build_maixcam.yml @@ -80,7 +80,7 @@ jobs: git init git config user.name ${user_name} git config user.email ${user_email} - remote_addr="https://${user_name}:${{ secrets.GITHUB_TOKEN }}@${remote_addr}" + remote_addr="https://Neutree:${{ secrets.GITHUB_TOKEN }}@${remote_addr}" echo "-- user ${user_name}" echo "-- remote addr: ${remote_addr}" git remote add origin "${remote_addr}" diff --git a/docs/doc/en/basic/maixvision.md b/docs/doc/en/basic/maixvision.md index 636e84ea..5d64cfe3 100644 --- a/docs/doc/en/basic/maixvision.md +++ b/docs/doc/en/basic/maixvision.md @@ -86,3 +86,19 @@ scp /path/to/your/file.py root@maixcam-xxxx.local:/root * **Method 2**: Use tools like [FileZilla](https://filezilla-project.org/) to connect to the device, transfer the files to the device, choose the `SFTP` protocol, fill in the device and account information, and connect. + + +## Code Completion + +Code completion depends on the Python packages installed locally on your computer. To enable code completion, you need to install Python on your computer and also the Python packages required for completion. + +* To install Python, visit the [Python official website](https://python.org/) for installation. +* To install the packages required for completion, for instance, for MaixPy, you need to install the MaixPy package on your computer as well by using `pip install MaixPy`. +* Restart MaixVision to see the code completion. + +> If the completion still does not work, you can manually set the path to the python executable in the settings and restart. + +>! Note that installing Python packages on your computer is only for code completion purposes. The actual code still runs on the device (development board), and the device must also have the corresponding packages for proper operation. + +> Additionally, although you have installed the MaixPy package on your computer, due to our limited resources, we do not guarantee that you will be able to directly import the maix package in Python on your computer for use. Please run it on supported devices. + diff --git a/docs/doc/zh/basic/maixvision.md b/docs/doc/zh/basic/maixvision.md index 61646146..85789882 100644 --- a/docs/doc/zh/basic/maixvision.md +++ b/docs/doc/zh/basic/maixvision.md @@ -96,8 +96,22 @@ scp /path/to/your/file.py root@maixcam-xxxx.local:/root * **方法二**:使用 [FileZilla](https://filezilla-project.org/) 等工具连接设备,将文件传输到设备上,选择 `SFTP` 协议填写设备和账号信息连接即可。 +## 代码提示 +代码提示依赖电脑本地的 Python 包,为了实现代码提示,我们需要在电脑中安装 Python,并且安装需要提示的 Python 包。 + +* 安装 Python 请访问 [Python 官网](https://python.org/)安装。 +* 安装需要提示的包,比如对于 MaixPy, 你需要在电脑也安装一份 MaixPy 包,在电脑使用`pip install MaixPy`即可安装好。 +> 中国国内用户可以使用国内镜像`pip install -i https://pypi.tuna.tsinghua.edu.cn/simple MaixPy`。 +* 重启 MaixVision 就能够看到代码提示了。 +> 如果仍然不能提示,可以手动在设置中设置 python 可执行文件的路径后重启。 + +>! 注意在电脑安装 Python 包这里只是为了用作代码提示,实际代码运行还是在设备(开发板)上,设备上也要有对应的包才能正常运行。 + + +> 另外,虽然你在电脑上安装了 MaixPy 包,但是由于我们精力有限,我们不确保你能直接在电脑的 Python 导入 maix 包进行使用,请在支持的设备上运行。 + diff --git a/maix/__init__.py b/maix/__init__.py index b456a0da..b9249c62 100644 --- a/maix/__init__.py +++ b/maix/__init__.py @@ -15,19 +15,26 @@ for m in members: if m[0].startswith("__"): continue - new_members["maix." + m[0]] = m[1] + new_members["maix." + m[0]] = m members = inspect.getmembers(_maix.peripheral) for m in members: if m[0].startswith("__"): continue - new_members["maix." + m[0]] = m[1] + new_members["maix." + m[0]] = m # clear all temp vars del m, members, inspect +__all__ = [] + import sys for k, v in new_members.items(): - sys.modules[k] = v + sys.modules[k] = v[1] + __all__.append(v[0]) + +del k, v, new_members, sys + -del k, v, new_members +from ._maix import * +from ._maix.peripheral import * diff --git a/maix/version.py b/maix/version.py index 30594bf0..f4d66a0d 100644 --- a/maix/version.py +++ b/maix/version.py @@ -2,7 +2,7 @@ # Versions should comply with PEP440: https://peps.python.org/pep-0440/ version_major = 4 -version_minor = 0 -version_patch = 11 +version_minor = 1 +version_patch = 0 __version__ = "{}.{}.{}".format(version_major, version_minor, version_patch)