控制Tello無人機掃描條形碼
一直想玩無人機,之前租了一個大疆的發現禁飛。好在最近發現了Tello,買來過了一把癮。順便試了下集成條形碼掃描功能。現在有很多倉儲管理會用到無人機來掃碼做庫存盤點。
Python 3控制Tello無人機
DJI的官方GitHub倉庫里已經放了示例代碼dji-sdk/Tello-Python
。不過這份代碼只能支持Python 2.7,而且也好久無人維護。要在Python 3上運行這份代碼需要做些修改。
首先獲取源碼:
git clone https://github.com/dji-sdk/Tello-Python.git
在vscode中打開工程,通過全局查找替換以下部分:
# 2.7
import Tkinter
# 3.7
import tkinter
# 2.7
print ""
# 3.7
print()
# 2.7
packet_data = ""
# 3.7
packet_data = bytes()
另外,h264解碼庫需要重新編譯成Python 3的版本。我的環境是Windows,首先下載編譯vcpkg
:
git clone https://github.com/microsoft/vcpkg
cd vcpkg
bootstrap-vcpkg.bat
然后通過vcpkg安裝ffmpeg
:
vcpkg.exe install ffmpeg:x64-windows
接下來編譯h264解碼庫的Python模塊:
git clone https://github.com/DaWelter/h264decoder.git
cd h264decoder
python setup.py build_ext --cmake-args="-DCMAKE_TOOLCHAIN_FILE=[path to vcpkg]/scripts/buildsystems/vcpkg.cmake"
現在可以用Python 3正常運行Tello的示例代碼了:
python3 main.py
集成Python條形碼識別SDK
條形碼識別會占用CPU,如果運行在Python的線程中,由于Python的GIL會導致視頻流卡頓。用Dynamsoft Python條形碼識別SDK可以避免這種情況。因為提供的視頻流解碼接口是運行在C/C++線程上的:
- start_video_mode()
- append_video_frame()
- stop_video_mode()
安裝Python barcode SDK:
pip install dbr
在tello.py
文件中創建BarcodeReader
對象:
from dbr import *
self.reader = BarcodeReader()
self.reader.init_license('LICENSE-KEY') # 獲取license: https://www.dynamsoft.com/customer/license/trialLicense
設置參數以及回調函數:
parameters = self.reader.init_frame_decoding_parameters()
self.frameWidth = 640 # max: 960
self.frameHeight = 480 # max: 720
self.results = None
parameters.image_pixel_format = EnumImagePixelFormat.IPF_RGB_888
parameters.max_queue_length = 2
parameters.max_result_queue_length = 2
parameters.width = self.frameWidth
parameters.height = self.frameHeight
parameters.stride = self.frameWidth * 3
parameters.auto_filter = 1
self.reader.start_video_mode(parameters, self.on_barcode_result)
已知Tello的攝像頭是720P的。我準備把得到的圖像縮小到640x480。
在回調函數中保存結果,用于UI繪制:
def on_barcode_result(self, data):
self.results = data
找到視頻流接收函數_receive_video_thread()
。把獲得的幀縮小并放到解碼隊列里:
for frame in self._h264_decode(packet_data):
self.frame = cv2.resize(frame, (self.frameWidth, self.frameHeight))
try:
ret = self.reader.append_video_frame(self.frame)
except:
pass
最后在析構函數中調用stop_video_mode()
:
def __del__(self):
self.reader.stop_video_mode()
測試
我在辦公室里做了測試。從顯示效果來看,不是很理想,在光線較差的環境中,圖像沒有對焦:
此外,懸停也會出現問題。Tello無人機在辦公室里懸停會漂移。
源碼
智能推薦
freemarker + ItextRender 根據模板生成PDF文件
1. 制作模板 2. 獲取模板,并將所獲取的數據加載生成html文件 2. 生成PDF文件 其中由兩個地方需要注意,都是關于獲取文件路徑的問題,由于項目部署的時候是打包成jar包形式,所以在開發過程中時直接安照傳統的獲取方法沒有一點文件,但是當打包后部署,總是出錯。于是參考網上文章,先將文件讀出來到項目的臨時目錄下,然后再按正常方式加載該臨時文件; 還有一個問題至今沒有解決,就是關于生成PDF文件...
電腦空間不夠了?教你一個小秒招快速清理 Docker 占用的磁盤空間!
Docker 很占用空間,每當我們運行容器、拉取鏡像、部署應用、構建自己的鏡像時,我們的磁盤空間會被大量占用。 如果你也被這個問題所困擾,咱們就一起看一下 Docker 是如何使用磁盤空間的,以及如何回收。 docker 占用的空間可以通過下面的命令查看: TYPE 列出了docker 使用磁盤的 4 種類型: Images:所有鏡像占用的空間,包括拉取下來的鏡像,和本地構建的。 Con...
requests實現全自動PPT模板
http://www.1ppt.com/moban/ 可以免費的下載PPT模板,當然如果要人工一個個下,還是挺麻煩的,我們可以利用requests輕松下載 訪問這個主頁,我們可以看到下面的樣式 點每一個PPT模板的圖片,我們可以進入到詳細的信息頁面,翻到下面,我們可以看到對應的下載地址 點擊這個下載的按鈕,我們便可以下載對應的PPT壓縮包 那我們就開始做吧 首先,查看網頁的源代碼,我們可以看到每一...
猜你喜歡
Linux C系統編程-線程互斥鎖(四)
互斥鎖 互斥鎖也是屬于線程之間處理同步互斥方式,有上鎖/解鎖兩種狀態。 互斥鎖函數接口 1)初始化互斥鎖 pthread_mutex_init() man 3 pthread_mutex_init (找不到的情況下首先 sudo apt-get install glibc-doc sudo apt-get install manpages-posix-dev) 動態初始化 int pthread_...
統計學習方法 - 樸素貝葉斯
引入問題:一機器在良好狀態生產合格產品幾率是 90%,在故障狀態生產合格產品幾率是 30%,機器良好的概率是 75%。若一日第一件產品是合格品,那么此日機器良好的概率是多少。 貝葉斯模型 生成模型與判別模型 判別模型,即要判斷這個東西到底是哪一類,也就是要求y,那就用給定的x去預測。 生成模型,是要生成一個模型,那就是誰根據什么生成了模型,誰就是類別y,根據的內容就是x 以上述例子,判斷一個生產出...
styled-components —— React 中的 CSS 最佳實踐
https://zhuanlan.zhihu.com/p/29344146 Styled-components 是目前 React 樣式方案中最受關注的一種,它既具備了 css-in-js 的模塊化與參數化優點,又完全使用CSS的書寫習慣,不會引起額外的學習成本。本文是 styled-components 作者之一 Max Stoiber 所寫,首先總結了前端組件化樣式中的最佳實踐原則,然后在此基...
19.vue中封裝echarts組件
19.vue中封裝echarts組件 1.效果圖 2.echarts組件 3.使用組件 按照組件格式整理好數據格式 傳入組件 home.vue 4.接口返回數據格式...