این سند نحوه استفاده از API سریال برای خواندن و نوشتن از دستگاه های سریال را شرح می دهد. برنامههای Chrome همچنین میتوانند به دستگاههای USB و بلوتوث متصل شوند.
نیاز آشکار
شما باید مجوز سریال را به فایل مانیفست اضافه کنید:
"permissions": [
"serial"
]
لیست پورت های سریال موجود
برای دریافت لیستی از مسیرهای مرتبط با پورت های سریال موجود، از روش serial.getDevices
استفاده کنید. توجه: همه پورت های سریال در دسترس نیستند. API از روشهای اکتشافی استفاده میکند تا فقط دستگاههای سریالی را نشان دهد که انتظار میرود ایمن باشند.
var onGetDevices = function(ports) {
for (var i=0; i<ports.length; i++) {
console.log(ports[i].path);
}
}
chrome.serial.getDevices(onGetDevices);
اتصال به دستگاه سریال
اگر مسیر مرتبط با پورت سریال را می دانید، می توانید با استفاده از روش serial.connect
به آن متصل شوید:
chrome.serial.connect(path, options, callback)
پارامتر | توضیحات |
---|---|
مسیر (رشته) | اگر مسیر مرتبط با پورت دستگاه شما ناشناخته است، می توانید از روش serial.getDevices استفاده کنید. |
گزینه ها (شیء) | شی پارامتر با چندین مقدار پیکربندی. جزئیات را در serial.ConnectionOptions ببینید |
پاسخ به تماس | هنگامی که پورت با موفقیت باز شد فراخوانی می شود. فراخوانی با یک پارامتر، connectionInfo ، فراخوانی میشود که چندین مقدار مهم دارد. جزئیات را در serial.ConnectionInfo ببینید. |
یک مثال ساده:
var onConnect = function(connectionInfo) {
// The serial port has been opened. Save its id to use later.
_this.connectionId = connectionInfo.connectionId;
// Do whatever you need to do with the opened port.
}
// Connect to the serial port /dev/ttyS01
chrome.serial.connect("/dev/ttyS01", {bitrate: 115200}, onConnect);
از پورت سریال جدا شوید
هنگامی که یک برنامه خاتمه می یابد، اتصالات به پورت های سریال که دائمی نیستند به طور خودکار توسط پلت فرم بسته می شوند. با این حال، اگر میخواهید در حالی که برنامه شما هنوز در حال اجرا است، اتصال را قطع کنید، میتوانید از روش serial.disconnect استفاده کنید:
var onDisconnect = function(result) {
if (result) {
console.log("Disconnected from the serial port");
} else {
console.log("Disconnect failed");
}
}
chrome.serial.disconnect(connectionId, onDisconnect);
خواندن از پورت سریال
API سریال از پورت سریال خوانده می شود و بایت های خوانده شده را به عنوان یک ArrayBuffer به شنوندگان رویداد تحویل می دهد. هر پورتی که برنامه شما به آن متصل است رویدادهای خواندنی را برای همه شنوندگان اضافه شده از طریق chrome.serial.onReceive.addListener(onReceiveCallback)
ایجاد می کند. اگر همزمان به بیش از یک پورت متصل هستید، ممکن است connectionId
مربوطه یک رویداد خوانده شده ورودی را در پارامتر پاسخ به تماس serial.onReceive بیابید.
مثال زیر میتواند بایتهای خواندهشده را تا زمانی که یک خط جدید خوانده شود جمعآوری کند، ArrayBuffer دریافتشده را به رشته تبدیل کند و زمانی که یک خط جدید به عنوان آخرین کاراکتر دریافتشده یافت میشود، متدی را فراخوانی میکند:
var stringReceived = '';
var onReceiveCallback = function(info) {
if (info.connectionId == expectedConnectionId && info.data) {
var str = convertArrayBufferToString(info.data);
if (str.charAt(str.length-1) === '\n') {
stringReceived += str.substring(0, str.length-1);
onLineReceived(stringReceived);
stringReceived = '';
} else {
stringReceived += str;
}
}
};
chrome.serial.onReceive.addListener(onReceiveCallback);
// [...] not shown here: connect to the serial port
ارسال اطلاعات به پورت سریال
ارسال داده ساده تر از خواندن است. تنها نکته این است که اگر پروتکل داده شما مبتنی بر رشته باشد، باید رشته خروجی خود را به یک ArrayBuffer
تبدیل کنید. نمونه کد زیر را ببینید:
var writeSerial=function(str) {
chrome.serial.send(connectionId, convertStringToArrayBuffer(str), onSend);
}
// Convert string to ArrayBuffer
var convertStringToArrayBuffer=function(str) {
var buf=new ArrayBuffer(str.length);
var bufView=new Uint8Array(buf);
for (var i=0; i<str.length; i++) {
bufView[i]=str.charCodeAt(i);
}
return buf;
}
شستشوی بافر پورت سریال
شما می توانید بافر پورت سریال خود را با صدور دستور flush شستشو دهید:
chrome.serial.flush(connectionId, onFlush);
بیشتر
Serial API چندین ویژگی دیگر نیز دارد. برای مثال، میتوانید یک اتصال را روی دائمی تنظیم کنید، بنابراین میتواند دادهها را حتی زمانی که برنامه شما اجرا نمیشود، دریافت کند، یا میتوانید پارامترهای اتصال مانند نرخ بیت، زمانبندی، سیگنالهای کنترلی و بسیاری موارد دیگر را با سریال بهروزرسانی کنید. روش به روز رسانی برای اطلاعات بیشتر به مرجع کامل سریال API مراجعه کنید.