色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

電子發燒友App

硬聲App

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示
電子發燒友網>電子資料下載>電子資料>物聯網項目之助旅客了解公交車繁忙程度

物聯網項目之助旅客了解公交車繁忙程度

2022-10-21 | zip | 0.71 MB | 次下載 | 免費

資料介紹

描述

這是一個物聯網項目,它可以幫助公交車旅客了解公交車的繁忙程度,以便在此基礎上做出正確的決定。例如,如果有人在他/她的手中有沉重和易碎的東西,那么在擁擠的公共汽車中旅行是不安全的,但為了了解公共汽車的狀態,應該等到公共汽車到達車站。但是,如果您知道公交車到達車站之前的乘客人數,那么我們可以節省時間并乘坐出租車。

現在讓我們從項目開始,因為有一些步驟:

  • 在 Artik Cloud 中設置設備
  • 創建網頁和應用程序

在 Artik 云中設置設備

我喜歡 artik cloud 的地方在于它可以一次處理多個請求而無需停機,而且使用簡單。

首先創建一個免費的 Artik Cloud 帳戶,方法是clicking here ?如果您已經有一個帳戶,那么只需在登錄。然后通過單擊菜單欄中的開發人員菜單或直接打開開發人員門戶

單擊儀表板菜單中設備類型或單擊此處

?
pYYBAGNR4n2AHPXcAADr5TnCWHY505.png
?

然后給它一個顯示設備名稱和唯一名稱(它應該是唯一的,不允許有空格),然后單擊Create Device type 在這里,我將我的設備顯示名稱設為Artik Bus ,并將唯一名稱設為artik.bus

?
poYBAGNR4oCAfdi3AADGICiT4MA368.png
?

之后在 Manifest 菜單上單擊 NEW MANIFEST

?
pYYBAGNR4oSASlP0AAD48f6Oc08534.png
?

然后輸入count作為字段名稱和數據類型只要(如果您選擇count作為字段名稱,它應該自動選擇)

?
pYYBAGNR4oeAAfJNAADz3cmvx-I013.png
?

然后點擊保存

單擊下一步:設備操作,然后單擊下一步:激活清單,最后單擊激活清單

?
poYBAGNR4oqAALM2AADNvL4FBqI164.png
?

現在您已成功創建了第一個用于存儲乘客數量的設備清單。

現在讓我們使用我們創建的清單創建一個虛擬設備。為此轉到https://artik.cloud 并單擊My Artik Cloud菜單中的設備或轉到https://artik.cloud /my/devices

?
pYYBAGNR4oyAetU9AAF0XHqKmRM319.png
?

如果您尚未創建任何設備,它會直接要求搜索您的設備。其他方法單擊連接另一臺設備并搜索您之前創建的設備名稱并選擇它并為其命名,然后單擊連接設備:

?
poYBAGNR4o-AAz-eAADXeMkIQ1Q976.png
?

現在你創建了你的設備。

接下來,您應該在復制設備 ID 和設備令牌之前將您的愛迪生板與 Artik 云連接。為此,單擊設備名稱附近的小齒輪(設置)圖標,將出現一個彈出窗口。單擊生成設備令牌,您將獲得一個令牌。復制設備 ID 和設備令牌以供以后使用。

?
poYBAGNR4pKATrQGAACft_SWrGU945.png
?

編碼和組裝英特爾 Edison

如果您在hackster.io中有許多聲明項目之前從未使用過英特爾愛迪生隨意查看:英特爾愛迪生入門項目

該項目使用 Node.js 語言和 Intel XDK 作為 IDE。這個項目不會太深入,現在您可以使用 XDK,但您將獲得使用的基礎知識

  • 獲取英特爾愛迪生的驅動程序和設置工具即可find here

下載設置工具后,您可以通過安裝驅動程序、刷新固件、設置 wifi 連接來設置(如果已經完成,則無需再次設置)。現在下載安裝 Intel XDK 并將愛迪生連接到計算機或任何其他電源。通過轉到路由器設置或通過 USB 將 edsion 連接到 pc 并從 Edison 設置工具獲取 IP,找到 Edison 的本地 IP 地址。

接線板如下:

?
pYYBAGNR4pWAT4ndAADkBAXfe5k618.png
?

這里 12 和 8 個引腳連接到 2 個按鈕,按鈕的另一端連接到 5v。

?
pYYBAGNR4pyAO1utAA1sRedkk60180.jpg
?

打開 Intel XDK 并在 IDE 底部單擊名為 IOT devices 的 dope down 菜單,然后單擊 Add manual connection:

?
poYBAGNR4p-AJD39AABJHKcosMs858.png
?

然后在彈出窗口輸入edison的本地IP,用戶名和密碼相同。在我的情況下,IP 地址是192.168.1.4然后點擊連接:

?
poYBAGNR4qGAdey6AABWRmqksaM357.png
?

它將顯示已連接的消息。

現在單擊左上箭頭,然后單擊新建項目。單擊模板并選擇空白模板。

?
pYYBAGNR4qSAeuZiAAGWtTmBk7g774.png
?

之后單擊繼續并為其命名。在那里使用以下代碼:

var mraa = require('mraa'); // require mraa
var request = require("request"); //req 
var auth = "Bearer xxxxx"; // Device token 
var dev = "xxx"; //device ID 
var count = 0; // Setting the inital value of count as 0 
var pinIn = new mraa.Gpio(12); // Pin for in 
var pinOut = new mraa.Gpio(8); // pin for OUt 
pinIn.dir(mraa.DIR_IN); // setting pin IN as INPUT mode 
pinOut.dir(mraa.DIR_IN); // setting pin OUT as INPUT mode 
// Setting default value as LOW 
pinIn.write(0); 
pinOut.write(0); 
//Function which listen for the the push buttons and make it act as a switch 
function check() { 
   var ch = 0; // help to use pushbutton as switch ( one can hold the push button as much they need but only one request is considered) 
   var inner = pinIn.read(); 
   if (inner == 1) { 
       while (pinIn.read() == 1) {} 
       count++; 
       ch = 1; 
   } 
   var outer = pinOut.read(); 
   if (outer == 1) { 
       while (pinOut.read() == 1) {} 
       count--; 
       ch = 1; 
   } 
   if (ch == 1) { 
       console.log(count) // printing the current count 
       post(count); 
       ch = 0; 
   } 
   setTimeout(check, 300); 
} 
console.log("Running"); // Print running when program starts 
post(0); //uploading 0 to artik when starts 
check(); // starting the fucntion check() to listen pushbuttons 
// Function which upload to artik 
function post(c) { 
   // seting the properties to upload 
   var options = { 
       method: 'POST', // reqest type 
       url: 'https://api.artik.cloud/v1.1/messages', // api request url 
       headers: { 
           'Content-Type': 'application/json', // setting conect type as json 
           'cache-control': 'no-cache', // don't store any cache' 
           'authorization': auth // passing the token as the header 
       }, 
       //passing data as json though body of the post request 
       body: '{\r\n\t"sdid": "' + dev + '",\r\n\t"type": "message",\r\n\t"data": {\r\n\t\t\t"count": "' + c + '"\r\n\t\t}\r\n}' 
   }; 
   //seting the the request with the properties above mentioned 
   request(options, function(error, response, body) { 
       if (error) throw new Error(error); 
       console.log(body); // printing the response 
   }); 
} 

這里替換:

var auth = "Bearer xxxxx";

xxxxx 與您的設備令牌

var dev = "xxxxx"; //device ID 

帶有設備ID的 xxxxxc

代碼可以在Github找到現在點擊底部的上傳按鈕:

?
pYYBAGNR4qaAUFAqAAAV_GC97No099.png
?

然后顯示上傳完成后點擊運行按鈕:

?
pYYBAGNR4qmAborVAAAYiKvSBgw298.png
?

它會顯示正在運行。

如果在任何情況下都顯示未找到請求,則轉到底部的 SSH 終端選項卡并填寫服務器詳細信息,例如 ip、用戶名、密碼和連接。然后輸入

npm install request

它將解決問題。

現在嘗試按下按鈕,您可以看到一個 JSON 以 ID 響應。它表明它正在工作。為了確認它轉到artik.cloud并登錄。然后My Artik Cloud 中選擇圖表。

然后點擊左上角的+/- CHARTS并勾選選項計數:

?
poYBAGNR4quARCa2AAA3DMtOsL4956.png
?

現在你可以看到一個圖表:

?
pYYBAGNR4q2AIFXRAABxpeQvFKs408.png
?

創建網頁和應用程序

對于 web 應用程序,我使用 azure 和 dream-spark 訂閱。如果您愿意使用任何其他主機,請隨意使用(主機應該支持node.js ,因為在這個項目中我使用 node js 作為服務器端語言)。

首先,您應該在您的計算機中為該 goto 安裝 Node js:nodejs.org并將其下載并安裝到您的系統中。之后打開評論提示(windows)或終端(Mac、Linux)并輸入:

npm install -g express-generator

然后,當安裝完成后,在您要創建項目的任何目錄中打開注釋提示并鍵入以下注釋:

express <projectname>

這里 是您希望的項目名稱。現在打開自動創建的文件夾并打開app.js文件并將其替換為以下代碼:

var express = require('express');
var path = require('path'); 
var favicon = require('serve-favicon'); 
var logger = require('morgan'); 
var cookieParser = require('cookie-parser'); 
var bodyParser = require('body-parser'); 
var routes = require('./routes/index'); 
var app = express(); 
// view engine setup 
app.set('views', path.join(__dirname, 'views')); 
app.set('view engine', 'jade'); 
// uncomment after placing your favicon in /public 
//app.use(favicon(path.join(__dirname, 'public', 'faviscon.ico'))); 
app.use(logger('dev')); 
app.use(bodyParser.json()); 
app.use(bodyParser.urlencoded({ extended: false })); 
app.use(cookieParser()); 
app.use(express.static(path.join(__dirname, 'public'))); 
app.use('/', routes); 
// catch 404 and forward to error handler 
app.use(function(req, res, next) { 
   var err = new Error('Not Found'); 
   err.status = 404; 
   next(err); 
}); 
// error handlers 
// development error handler 
// will print stacktrace 
if (app.get('env') === 'development') { 
   app.use(function(err, req, res, next) { 
       res.status(err.status || 500); 
       res.render('error', { 
           message: err.message, 
           error: err 
       }); 
   }); 
} 
// production error handler 
// no stacktraces leaked to user 
app.use(function(err, req, res, next) { 
   res.status(err.status || 500); 
   res.render('error', { 
       message: err.message, 
       error: {} 
   }); 
}); 
module.exports = app;

然后使用以下路由/index.js

var express = require('express');
var router = express.Router(); 
var request = require("request"); 
var sdids = "xxxxx"; //replace with device id 
var token = "xxxxx"; //replace with device token 
/* GET home page. */ 
router.get('/', function(req, res, next) { 
   res.render('index'); 
}); 
router.get('/count', function(req, res, next) { 
   var options = { 
       method: 'GET', 
       url: 'https://api.artik.cloud/v1.1/messages/last', 
       qs: { sdids: sdids, count: '1' }, 
       headers: { 
           'cache-control': 'no-cache', 
           'authorization': 'Bearer ' + token 
       } 
   }; 
   var data, k = 0; 
   request(options, function(error, response, body) { 
       if (error) throw new Error(error); 
       data = JSON.parse(body).data[0].data; 
       res.send(data); 
   }); 
}); 
module.exports = router; 

在這里編輯以下內容:

var sdids = "xxxxx"; //replace with device id 
var token = "xxxxx"; //replace with device token

替換views/index.jade:

extends layout 
block content 
 #container 
   #data 
   script. 
     function getData(){ 
     $.ajax({url:'/count', dataType: "json", success:function(result){ 
     console.log(result); 
     // Get the result and show it 
     var message = result.count; 
     document.getElementById("data").innerHTML = JSON.stringify(message); 
     }}); 
     } 
     $( document ).ready(function() { 
     document.getElementById("data").innerHTML = "0" 
     window.setInterval(getData, 2000); 
     }); 

替換views/layout.jade:

doctype html 
html 
 head 
   title= title 
   link(rel='stylesheet', href='/stylesheets/style.css') 
   script(src='/javascripts/jquery.js') 
 body 
   block content 

并替換public/stylesheets/style.css:

body{   
   margin: 0; 
   padding: 0; 
   background: #eee; 
} 
#container { 
   display: table; 
   width: 100%; 
   height: 100vh; 
} 
#data { 
   font-size: 20em; 
   color: #202020; 
   display: table-cell; 
   vertical-align: middle; 
   text-align: center; 
} 

public/javascripts中創建一個名為jquery.js的文件。代碼將來自:https ://code.jquery.com/jquery-3.1.1.js

或者你可以在Github上找到完整的代碼現在使用git / Github desktop將這個項目上傳到 Github,甚至可以直接上傳。

?
poYBAGNR4rCALMhGAAEKVtGGWV0246.png
?

接下來我們需要在 azure 中托管這個項目。對于該 goto:portal.azure.com 并創建一個帳戶(如果您還沒有)。

  • 單擊側欄中的新建
  • 從中選擇 Web App
  • 根據需要給它一個名稱和資源組
?
pYYBAGNR4rOABvJuAAFEjzH8EHc290.png
?

現在從儀表板打開該應用程序(如果您將其固定到儀表板)或從所有資源中選擇它。

  • 在左側你可以看到部署選項點擊它
  • 然后點擊選擇資源設置
  • 并選擇Github (如果是第一次會要求認證)
?
poYBAGNR4raACfawAAE_N1DNz7k736.png
?
  • 現在單擊選擇的項目,然后選擇您的項目
  • 并單擊確定
?
pYYBAGNR4rmAKFhvAAEwtvgwkyQ439.png
?

等待一段時間,直到獲取所有數據并安裝包

?
poYBAGNR4ruAWCacAAAXZpjqlcY728.png
?

獲取完成后,您可以通過 url 訪問您的 azure web 應用程序。如果您不知道,您可以在儀表板中找到它。

?
poYBAGNR4r2ANRkPAADOiPXnXkc715.png
?

打開它,你可以找到乘客的數量。當您按下按鈕時,它也會上傳。它幾乎是即時更新(大約 3 - 5 秒)。

?
pYYBAGNR4sCAd04sAAAYQfK_JuE768.png
?

您可以通過轉到 appsgeyser 并創建一個帳戶來輕松地創建一個移動應用程序(如果您已經擁有,請登錄)

  • 輸入您的天藍色網址,然后單擊下一步
  • 給它一個名字,然后點擊下一步
  • 給它一個描述,然后單擊下一步
  • 并使用默認圖標或上傳一個
  • 最后點擊創建
?
poYBAGNR4sOAO1S0AAB-2g-wSJc535.png
?
  • 接下來點擊下載按鈕
?
pYYBAGNR4sWAYY7bAAB7XaPevgk334.png
?
  • 當它顯示一個彈出窗口時,只需單擊或測試您的應用程序
  • 然后點擊下載按鈕
  • 它將開始下載
?
poYBAGNR4siARXSaAAALN3m8pXg204.png
?
  • 將其安裝在您的手機中。

現在您剛剛還創建了您的移動應用程序。就像使用與物聯網集成的咖啡機制作咖啡一樣簡單:p

演示視頻

?

?


下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數據手冊
  2. 1.06 MB  |  532次下載  |  免費
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費
  5. 3TC358743XBG評估板參考手冊
  6. 1.36 MB  |  330次下載  |  免費
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費
  9. 5元宇宙深度解析—未來的未來-風口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費
  11. 6迪文DGUS開發指南
  12. 31.67 MB  |  194次下載  |  免費
  13. 7元宇宙底層硬件系列報告
  14. 13.42 MB  |  182次下載  |  免費
  15. 8FP5207XR-G1中文應用手冊
  16. 1.09 MB  |  178次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關電源設計實例指南
  8. 未知  |  21549次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數字電路基礎pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅動電路設計》 溫德爾著
  16. 0.00 MB  |  6656次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉中文版)
  4. 78.1 MB  |  537798次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191187次下載  |  免費
  13. 7十天學會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183279次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費
主站蜘蛛池模板: 伦理电影2499伦理片| 国产AV一区二区三区日韩| 亚洲精品无夜久久久久久久久| 欧美xxbb| 麻豆免费观看高清完整视频| 精品性影院一区二区三区内射| 国产精品九九久久| 草比比过程图| G国产精品无马| 91免费精品国自产拍在线可以看| 亚洲色图在线观看视频| 亚洲高清国产拍精品5g| 无人区乱码1区2区3区网站| 十分钟免费观看高清视频大全| 热久久伊大人香蕉网老师| 欧美日韩午夜群交多人轮换| 暖暖在线观看播放视频| 绝色娇嫩美人妻老师| 久青草影院| 麻豆精品一区二正一三区| 老鸭窝毛片| 男女XX00上下抽搐动态图| 米奇在线8888在线精品视频| 老湿司午夜爽爽影院榴莲视频| 两性午夜刺激爽爽视频| 免费成人小视频| 女人夜夜春| 秋霞在线看片无码免费| 肉小说高h| 侮辱丰满美丽的人妻| 亚洲欧美精品无码一区二在线 | 精品久久免费观看| 果冻传媒独家原创在线观看| 精品蜜臀AV在线天堂| 久久免费国产视频| 老师破女学生特级毛片| 欧美 亚洲 日韩 中文2019| 日本xxxxx按摩19| 吻嘴胸全身好爽床大全| 亚洲精品色播一区二区| 中文字幕无码一区二区免费 |