樹莓派Zero 2 W(ubuntu-22.04)通過.NET6和libusb操作USB讀寫

来源:https://www.cnblogs.com/GreenShade/archive/2022/10/16/16795988.html
-Advertisement-
Play Games

有這個想法的初衷 喜歡電子和DIY硬體的朋友對稚暉君應該都不陌生,他定期都會分享一些自己做的好玩的硬體,他之前做了一個ElectronBot桌面機器人我就很感興趣,所以就自己也做了一個。 起初我只是自己開發了一個叫電子腦殼的上位機軟體,大家在之前的博客里應該也有見到,是個用WinUI(WASDK)開 ...


有這個想法的初衷

喜歡電子和DIY硬體的朋友對稚暉君應該都不陌生,他定期都會分享一些自己做的好玩的硬體,他之前做了一個ElectronBot桌面機器人我就很感興趣,所以就自己也做了一個。
electronbot
起初我只是自己開發了一個叫電子腦殼的上位機軟體,大家在之前的博客里應該也有見到,是個用WinUI(WASDK)開發的Windows應用軟體。

ElectronBot機器人要一直和電腦連接通過應用進行控制,很多的網友都想ElectronBot脫離電腦使用,於是我也想著能有什麼好辦法,所以也就有了這個標題的想法。

項目代碼地址

技術選型

大家想到樹莓派肯定就會想起python,大學的時候玩樹莓派確實用python比較多,但是作為一個.NET開發人員當然要嘗試下.NET的跨平臺能力到底如何了。

由於先有了之前寫的上位機軟體電子腦殼,也想著讓之前封裝的SDK能夠直接用在樹莓派上,所以選擇.NET是順理成章的事情了。

  • 應用開發選擇.NET框架
  • 通訊方式選擇GRPC
  • USB操作選擇LibUsbDotNet調用libusb

整體方案如下圖:

img

環境配置

1. 樹莓派系統安裝及網路配置

樹莓派支持的系統有很多種,像官方的Debian,Ubuntu等等。
我平時使用Debian比較多,但是測試的時候好像usb操作有些問題,應該是我用的.net互操作庫對Debian支持的不太好,所以我選擇了ubuntu的系統。

安裝燒錄工具,下載系統,然後燒錄系統。如下圖所示:
img

目前樹莓派Zero 2 W的Ubuntu只有Server版本和Core版本,需要使用命令行做操作。

網路配置可以參考下麵的文章進行配置。

樹莓派4B ubuntu server ssh伺服器部署全過程詳解(內網穿透)

能正常聯網安裝軟體就可以了。

2. .NET6的運行環境

由於.NET6 Arm64官方沒提供包管理安裝,所以需要大家通過腳本,或者下載文件安裝。
網路好的可以通過腳本安裝,簡單,本文以腳本安裝示例。

參考文檔如下:

使用安裝腳本或通過提取二進位文件在 Linux 上安裝 .NET

下載安裝腳本dotnet-install.sh放到用戶家目錄

執行以下指令添加執行許可權

sudo chmod +x ./dotnet-install.sh

執行指令安裝

./dotnet-install.sh -c Current

下載解壓結束需要我們配置環境變數,就像windows安裝軟體一樣,配置完環境變數,才可以直接通過dotnet直接使用了,不然是提示找不到指令的。

以下指令是編輯環境變數的,我選擇了~/.bashrc,在文檔最底部添加環境變數內容。

sudo vim ~/.bashrc

內容

export DOTNET_ROOT=$HOME/.dotnet
export PATH=$PATH:$HOME/.dotnet:$HOME/.dotnet/tools

保存並退出,然後執行dotnet如果正常就可以進行下麵的操作了。

實踐過程記錄

1. GRPC服務的開發與調試

首先用創建一個grpc服務

微軟官方的文檔協議文件編寫介紹

gprc

協議文件編寫和服務編寫

以我的協議內容為例包含了float,bool,bytes類型

float 對應 c# float

bool 對應 c# bool

bytes 對應 c# byte[]

syntax = "proto3";

option csharp_namespace = "Verdure.ElectronBot.GrpcService";

package electronbotactiongrpc;

// The electronbotaction service definition.
service ElectronBotActionGrpc {
  // Sends a greeting
  rpc PlayEmoticonAction (EmoticonActionFrameRequest) returns (EbHelloReply);
}

// The request message containing the user's name.
message EmoticonActionFrameRequest {
 float J1 = 1;
 float J2 = 2;
 float J3 = 3;
 float J4 = 4;
 float J5 = 5;
 float J6 = 6;
 bool Enable = 7;
 bytes FrameBuffer = 8;
}

// The response message containing the greetings.
message EbHelloReply {
  string message = 9;
}

然後生成對應的服務代碼

主要註意點是bytes類型的轉換

grpc-code

服務端寫好了以後,就可以寫調用端代碼了,為了圖方便我就在電子腦殼代碼裡加了調用代碼。

WinUI調用GRPC註意事項

直接將gprc相關的東西放到winui項目里好像有一些問題,所以我把它放到了一個庫項目里進行操作了。

配置協議文件生成client代碼

grpc-client

電子腦殼註入grpc-client

            services.AddGrpcClient<ElectronBotActionGrpc.ElectronBotActionGrpcClient>(o =>
            {
                o.Address = new Uri("http://192.168.3.236:5241");
            });

數據發送端也要註意bytes類型的轉換

img

grpc服務的打包發佈

打包的時候選擇目標運行時為可移植(windows和linux都可以運行)
img

項目代碼地址

2. 服務的部署與效果驗證

通過ftp工具將grpc服務放到樹莓派上,首先需要連接ElectronBot之後再運行服務

進入項目所在目錄執行指令如下:

 dotnet Verdure.ElectronBot.GrpcService.dll --urls="http://*:5241"

如果通訊正常,那麼應該會報錯,提示libusb找不到,系統已經安裝了libusb,只是.net調用的時候目錄沒有找到,需要我們創建軟連接。

LibUsbDotNet README最底部有說

樹莓派實際操作如下:

  sudo find / -name "libusb-1.0*.so*" //列出庫的目錄位置
  cd /usr/lib/aarch64-linux-gnu/ //進入庫所在目錄
  sudo ln -s libusb-1.0.so.0 libusb-1.0.so //創建鏈接

通過上面的操作 libusb的操作應該就沒有問題了。

運行的效果如下圖:

img

特殊問題與心得體會

最大的一個問題就是在sdk放到linux系統上測試寫入數據異常。

  • 需要sdk單獨處理linux環境
  • 需要sdk補一些內核驅動卸載邏輯
  • 特別註意otg數據線不要使用那種一拖幾的,用一個口的就行不然數據發送不過去

由於使用的LibUsbDotNet上述邏輯沒暴露到上層,我只好拉了一個分支改了發了一個包,問pr也沒人理我。

sdk內部特別處理的代碼如下:

執行了一個設備的SetAutoDetachKernelDriver

if (wholeUsbDevice.DriverMode == UsbDevice.DriverModeType.MonoLibUsb)
{
_logger.LogInformation("MonoLibUsb DetachKernelDriver");

var retDetach = wholeUsbDevice.SetAutoDetachKernelDriver(true);

_logger.LogInformation(retDetach.ToString());
}

通過這次的嘗試,我算是明白了理想很豐滿,現實很骨感的意思,本來覺得樹莓派Zero 2 W小巧便攜,而且我只是用它接收數據發送數據,結果數據發送的時候屏幕的刷新很慢,不知道是性能差勁,還是usb傳輸是瓶頸。下次換個4b進行測試一下。

至此整個過程就分享完了,這個項目基本上涵蓋了.net技術內的很多東西,如果ElectronBot和樹莓派結合獨立以後能夠很好的使用,我覺得用MAUI開發一個手機端的管理工具也是順理成章了,可以期待一下,能看到這裡的可以在評論區給點意見了。

電子腦殼 GRPC服務項目代碼地址

LibUsbDotNet地址


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 首先聲明,本文參照(7條消息) 【中文】【吳恩達課後編程作業】Course 1 - 神經網路和深度學習 - 第三周作業_何寬的博客-CSDN博客_吳恩達課後編程作業(https://blog.csdn.net/u013733326/article/details/79702148) 本文所使用的資料 ...
  • 上一章講到利用路由器鏡像的功能轉發消息,本章介紹物聯網終端的另一應用場景——通過智能終端收發QQ消息。 硬體準備 (無) 環境搭建 實現QQ消息轉發需要依賴社區維護的QQ客戶端gocqhttp以及聊天機器人框架nonebot2,而在這個社區內fubuki-iot是作為一個插件的形式存在的。因此完整的 ...
  • 在上一篇文章`《驅動開發:內核枚舉DpcTimer定時器》`中我們通過枚舉特征碼的方式找到了`DPC`定時器基址並輸出了內核中存在的定時器列表,本章將學習如何通過特征碼定位的方式尋找`Windows 10`系統下麵的`PspCidTable`內核句柄表地址。 ...
  • 1.字元串capitalize函數 (capitalize vt. 資本化,用大寫字母書寫(或印刷); 把…首字母大寫;) 將字元串的首字母大寫,其它字母小寫; 用法:newstr = string.capitalize() 修改後生成一個新字元串(因為字元串是不可更改數據類型); ''.capit ...
  • 大家好,我是陶朱公Boy,又和大家見面了。 前言 在文章開始前,想先問大家一個問題,大家平時在項目需求評審完後,是直接開始編碼了呢?還是會先寫詳細設計文檔,後再開始進行編碼開發? ☆現實 這個時候可能有部分小伙伴會出來反駁:還詳細設計呢連給開發的時間都不夠,項目經常被倒排期。 作者其實能感同身受上述 ...
  • 學會了技術就要使用,否則很容易忘記,因為自然界壓根就不存在什麼代碼、變數之類的玩意,這都是一些和生活常識格格不入的東西。只能多用多練,形成肌肉記憶才行。 在一次實際的產品開發中,由於業務需求的緣故,需要使用Elasticsearch搜索引擎。搜索引擎是通過索引和文檔檢索數據的,索引類似於MySQL的 ...
  • 首先依賴註入 懶得下載autofac了 直接用程式集進行批量註入 private static WebApplicationBuilder builder; internal static void Load(WebApplicationBuilder web) { builder = web; b ...
  • 前面簡單介紹了騰訊雲的由來和定義,本編介紹騰訊的簡單使用(我這個展示的是把最近寫的vs項目部署到雲服務中): 1、首先根據前面的定義註冊個騰訊雲賬戶,然後購買個雲伺服器,當然首次註冊的都有免費體驗資格,我這裡用到的是免費體驗輕量式伺服器: 進入購買然後開通就會顯示在你的輕量伺服器上,會根據你選的wi ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...