西門子6ES7492-1CL00-0AA0前連接器 西門子6ES7492-1CL00-0AA0前連接器
人機界面設計是指通過一定的手段對用戶界面有目標和計劃的一種創作活動。大部分為商業性質、少部分為藝術性質。人機界面(Human Computer Interface,簡稱HCI)通常也稱為用戶界面
人機界面設計主要包括三個方面:
設計軟件構件之間的接口
設計模塊和其他非人的信息生產者和消費者的界面
設計人(如用戶)和計算機間的界面
人機界面是計算機科學和認知心理學兩大學科相結合的產物,同時也吸收了語言學、人機工程學和社會學等學科的研究成果。經過40余年的發展,已經成為一門以研究用戶及其與計算機的關系為特征的主流學科之一。近年來,人機界面的設計理論已經更廣泛地發展和應用到人一機一環境系統工程等領域,使工程技術設計與使用者的身心行為特點相適應,從而使人能夠高效、舒適地工作與生活。
中文名人機界面設計
人機界面設計思想
編輯
計算機按照機器的特性去行為,人按照自己的方式去思維和行為。要把人的思維和行為轉換成機器可以接受的方式,把機器的行為方式轉換成人可以接受的方式,這個轉換就是人機界面。使計算機在人機界面上適應人的思維特性和行動特性,這就是“以人為本”的人機界面設計思想。
一個友好美觀的界面會給人帶來舒適的視覺享受,拉近人與電腦的距離,為商家創造賣點。界面設計不是單純的美術繪畫,他需要定位使用者、使用環境、使用方式并且為zui終用戶而設計,是純粹的科學性的藝術設計。檢驗一個界面的標準既不是某個項目開發組的意見也不是項目成員投票的結果,而是zui終用戶的感受。所以界面設計要和用戶研究緊密結合,是一個不斷為zui終用戶設計滿意視覺效果的過程。
軟件的未來其實在很大程度上要指望軟件接口的前景如何。計算機世界里的接口這兩個字具有兩種*的含義:其一是指軟件本身的狹義“接口”,比如各種軟件開發API等。其二則指的是人與軟件之間的交互界面。我們把這種人-軟件之間的接口稱作“用戶界面”,也就是“UI”。
UI設計則是指對軟件的人機交互、操作邏輯、界面美觀的整體設計。好的UI設計不僅是讓軟件變得有個性有品味,還要讓軟件的操作變得舒適、簡單、自由,充分體現軟件的定位和特點。
隨著近幾十年來科學技術的飛速發展,人機界面技術的地位越來越重要。這本《人機界面設計》由劉偉、莊達民和柳忠起編著,介紹和分析了人機界面技術中交互信息的輸入、處理、輸出三大過程的特性和關系,闡述了相應的基本理論模型和方法。主要內容包括人機界面技術的形成和發展、人機界面中人的感覺特性(人機界面信息輸入階段)、認知特性與分析、人機界面中情境認知特性(人機界面信息處理階段)、人機界面中人的控制特性(人機界面信息輸出階段)、網絡用戶行為信息分析、信息產品中人機交互研究案例(視盲現象與界面設計研究案例、Web信息架構設計對網絡用戶視覺搜索能力的影響、即時游戲中玩家流體驗的研究)等,章末附有思考題與習題,便于讀者掌握所學內容。
繪芯人機界面與單片機通訊
單片機與繪芯人機界面通信有兩個方案:一是用modbus—rtu協議,二是自由通訊協議;
本實例采用武漢繪芯科技有限公司的人機界面作為參考,因為公司提供一系列的和公布單片機源代碼,開發工程方便有效。
公司:http://www.ebnar。。com
方案比較:
方案一 modbus—rtu協議:
優點:工業標準通訊協議,具有通用性,,傳輸數據量大
缺點:需要時間去了解協議的格式和以及按照規定編寫通訊程序(我們提供MODBUS-RTU源代碼,客戶直接移植就可以,不必費心)
方案二 自由協議:
優點:數據格式客戶自己定義,靈活多變,定制性強,可以模擬任何已知報文的通訊協議
缺點:傳輸數據量不大,通用性不強,移植不方便
客戶可以根據以上兩種通訊協議的優缺點來選擇理想的方案;
實現方法:
方案一:
1. 工程屬性選用MODBUS-RTU協議;
2. 先了解MODBUS-RTU協議,基本的01 03 05 06 16 的功能碼需要了解,其他可以不去深究;提供相關的資料
3. 使用我們提供的MODBUS-RTU協議(C語言)開發源代碼,把主要的01 03 05 06 16 函數移植到單片機通訊上,大大節省了開發時間;
方案二:
1. 工程屬性選用FreeProtocol協議;
2.
3. 打開控制令編輯器(設定—>宏指令—>宏指令編輯器)或者直接按F8;
4. 新增宏指令,在宏指令里面使用到Output()、Input()、SetWordData()、GetWordData()這四個函數;注:可以參考附一
5. Output()函數,把設定好的字符串發送到相應的串口輸出;Input()函數,從設定好的串口讀取需要的字符串;
6. 采集顯示:
SetWordData()函數,把Input()函數接收回來的數據,發送給HIM用戶自定義寄存器里,然后在顯示控件里填上已經有數據的HIM寄存器,即可顯示單片機采集上來的數據;
7. 改寫發送:
在顯示控件了把需要改寫的數據綁定HIM寄存器,使用GetWordData()獲得修改后的數據,通過output()發送把數據發送到單片機;
附一:
Output();
【描述】
*個參數channel表示通道,如果通道為com1,則channel=1;如果通道為com2,則channel=2,數據類型為int。
第二個參數pString表示從通道輸出的字符串的地址,數據類型為unsigned char *。
第三個參數count表示字符串中的字符個數,數據類型為int。
第四個參數result表示Output函數運行后返回的結果,如果result大于0,則表示讀寫有效,數據類型為int。
注意:此函數只能用在freeprotocol(自由協議通道)中。
【用法】
Output(channel,pString,count,result);
【舉例】
char srt[9];
int result;
Output(1,str[0],9,result);
Input();
【描述】
*個參數channel表示通道,如果通道為com1,則channel=1;如果通道為com2,則channel=2,數據類型為int。
第二個參數pString表示寫入通道的字符串的地址,數據類型為unsigned char *。
第三個參數count表示字符串中的字符個數,數據類型為int。
第四個參數result表示Output函數運行后返回的結果,如果result大于0,則表示讀寫有效,數據類型為int。
注意:此函數只能用在freeprotocol(自由協議通道)中。
【用法】
Input(channel,pString,count,result);
【舉例】
char srt[9];
int result;
Input(1,str[0],9,result);
GetWordData();
【描述】
函數功能:從通道中讀取Word數據。
*個參數channel表示通道,數據類型為unsigned char。
第二個參數slaveID表示從機號,數據類型為unsigned char。
第三個參數address表示系統通道地址,數據類型為unsigned short。
第四個參數count表示要讀出的字的個數,數據類型為unsigned short。
第五個參數表示命令號,數據類型為unsigned char。
第六個參數pValue用來保存從系統通道讀出的count個字,數據類型為unsigned short *。
【用法】
GetWordData(channel,slaveID,address,count,cmd,pValue);
【舉例】
unsigned short wordData[10];
GetWordData(0, 1,8000, 10, 0,wordData);
從系統通道 8000地址中讀取10個數據到wordData
SetWordData();
【描述】
函數功能:從通道中寫入一個Word數據。
*個參數channel表示通道,數據類型為unsigned char。
第二個參數slaveID表示從機號,數據類型為unsigned char。
第三個參數address表示系統通道地址,數據類型為unsigned short。
第四個參數cmd表示命令號,數據類型為unsigned char。
第五個參數pValue用來保存寫入系統通道的字,數據類型為unsigned short。
【用法】
SetWordData(channel,slaveID,address,cmd,source);
【舉例】
unsigned short wordData = 1;
SetWordData(0, 1,1000,0,wordData);
把wordData中的Word數據寫到系統通道 1000地址處
附錄二:
使用自由協議來模擬modbus-RTU
//COM1:freeprotocol
//COM2:modbus-RTU
/*自由協議通道采集數據存放在系統通道,在界面顯示
modbus通道采集到的數據,處理后,發送到自由協議的設備上*/
unsigned char command[32];
unsigned char response[32];
unsigned char temp1,temp2;
unsigned short address, checksum;
unsigned short read_no, return_value1, return_value2,return_value3,read_data[2], i;
unsigned short com2_data;
/****************以上是新建需要使用的變量***********/
Fill(command, 0, 32);// initialize command[0]~command[31] to 0
Fill(response, 0, 32); //把command 和response 初始化
command[0] = 0x1;// 設置發送字符竄的*個數據 station number
command[1] = 0x3;// 設置發送字符竄的第二個數據 read holding registers (function code is 0x3)
address = 0;// starting address (4x_1) is 0
HiByte(address, command[2]);//設置發送字符竄的第三個數據
LoByte(address, command[3]);//設置發送字符竄的第四個數據
read_no = 2;// the total words of reading is 2 words
HiByte(read_no, command[4]);//設置發送字符竄的第五個數據
LoByte(read_no, command[5]);//設置發送字符竄的第六個數據
CRC(command, 6,checksum);// calculate 16-bit CRC
LoByte(checksum, command[6]); //設置發送字符竄的第七個數據
HiByte(checksum, command[7]); //設置發送字符竄的第八個數據
Output(1,command,8, return_value1); //把設置好的8個數據,從通訊口1發送出去,具體參數設置參考Output()使用
Input(1,response,9,return_value2); //從通訊口1等待接收9個字符數據,并且放在response[0]~response[8],具體參數設置參考Intput()使用
CRC(response, 7,checksum); //對采集上來的9個數據中前7個進行了CRC-16校驗,校驗結果存放在checksum
LoByte(checksum, temp1); //把checksum的低8位放在temp1
HiByte(checksum, temp2); //把checksum的高8位放在temp1
if(temp1==response[7]&&temp2==response[8]) //CRC校驗碼進行對比判別時候接收正確
{
//CRC檢驗正確后,把采集來的數據中需要的數據放在read_data[]
read_data[0] = response[4] + (response[3] << 8);
read_data[1] = response[6] + (response[5] << 8);
SetWordData(0 ,1 ,0 ,2,0 , read_data); // 通過SetWordData()函數,把read_data送到系統寄存器中,具體使用需要參考SetWordData()函數使用
}
GetWordData( 2, 1, 2, 2, 3, &com2_data); // 通訊口2,使用的是modbus-RTU協議,
command[0] = 0x1;// station number
command[1] = 0x6;// wirte holding registers (function code is 0x6)
address=10;
checksum=0;
HiByte(address, command[2]);
LoByte(address, command[3]);
HiByte(com2_data, command[4]);
LoByte(com2_data, command[5]);
CRC(command, 6,checksum);// calculate 16-bit CRC
LoByte(checksum, command[6]);
HiByte(checksum, command[7]);
Output(1,command,8, return_value3); //發出定義好8個字符串