91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何實現溫度傳感器和OLED

發布時間:2021-10-21 13:43:00 來源:億速云 閱讀:176 作者:iii 欄目:web開發

本篇內容主要講解“如何實現溫度傳感器和OLED”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“如何實現溫度傳感器和OLED”吧!

1. OLED驅動

2. 溫濕度傳感器AHT20驅動

3. 畫表盤

由于表盤是半個圓,而且一般是從9點鐘方向開始,順指針旋轉,與實際的溫度值相對應,9點鐘對應最小值,3點鐘對應最大值,

因此我們畫表盤的時候最好從9點鐘對應的角度為0, 12點鐘對應的角度90度,3點鐘對應的角度為180度。

畫表盤就是設置好圓心(x,y)和半徑r,然后計算圓周上的兩個點,將相鄰的兩個點調用畫直線函數連接起來。

/*DrawArc.畫一個半圓  * start_angle in degree  * sweep in degree  * x,y是圓心的位置  * radius是半徑  * start_angle 起始角度,9點鐘作為0角度  * sweep 掃描角度  * 從9點鐘開始作為0角度,順時針旋轉  */  void ssd1306_DrawArc_from9(uint8_t x, uint8_t y, uint8_t radius, uint16_t start_angle, uint16_t sweep, SSD1306_COLOR color) {  float approx_degree;  uint32_t approx_segments;  uint8_t xp1,xp2;  uint8_t yp1,yp2;  uint32_t count = 0;  uint32_t loc_sweep = 0;  float rad;  loc_sweep = ssd1306_NormalizeTo0_360(sweep);  count = (ssd1306_NormalizeTo0_360(start_angle));  approx_segments = loc_sweep;  approx_degree = 1;  while(count < approx_segments)  {  rad = ssd1306_DegToRad(count*approx_degree);  xp1 = x - (int8_t)(cos(rad)*radius);  yp1 = y - (int8_t)(sin(rad)*radius);  count++;  if(count != approx_segments)  {  rad = ssd1306_DegToRad(count*approx_degree);  }  else  {  rad = ssd1306_DegToRad(loc_sweep);  }  xp2 = x - (int8_t)(cos(rad)*radius);  yp2 = y - (int8_t)(sin(rad)*radius);  ssd1306_DrawLine(xp1,yp1,xp2,yp2,color);  }  return;  }

4.畫指針

畫指針比較簡單,就是在圓周上找一個點,將這個點和圓心連接,就變成了一個指針,改變半徑的大小,就可以實現指針的長短。

難點是如何將指針的角度和實際的溫度值對應起來。假設溫度的范圍為-15攝氏度到45攝氏度,共60攝氏度,則每一個角度對應的溫度值為60/180;

如果當前溫度是20度,則對應的角度為20*60/180度。

/*  畫一條圓心到圓周的直線,實現指針  */  void ssd1306_draw_line_of_arc(uint8_t x, uint8_t y, uint8_t radius, uint16_t angle,SSD1306_COLOR color)  {  float approx_degree;  uint8_t xp1;  uint8_t yp1;  uint32_t count = 0;  float rad;  count = (ssd1306_NormalizeTo0_360(angle));  approx_degree = 1;  rad = ssd1306_DegToRad(count*approx_degree);  xp1 = x - (int8_t)(cos(rad)*radius);  yp1 = y - (int8_t)(sin(rad)*radius);  ssd1306_DrawLine(x, y, xp1, yp1, color);  }

5. 畫刻度

畫刻度的方法,可以參考上面畫指針的方法,從同一個角度畫出的直線,與兩個同圓心不同半徑的圓的交點,將這兩個交點連接起來就是刻度

/*  畫一條刻度線  */  void ssd1306_draw_line_of_kedu(uint8_t x, uint8_t y, uint8_t radius, uint16_t angle,SSD1306_COLOR color)  {  float approx_degree;  uint8_t xp1,xp2;  uint8_t yp1,yp2;  uint32_t count = 0;  float rad;  count = (ssd1306_NormalizeTo0_360(angle));  approx_degree = 1;  rad = ssd1306_DegToRad(count*approx_degree);  xp1 = x - (int8_t)(cos(rad)*radius);  yp1 = y - (int8_t)(sin(rad)*radius);  xp2 = x - (int8_t)(cos(rad)*(radius-4));//刻度線的長度為4  yp2 = y - (int8_t)(sin(rad)*(radius-4));  ssd1306_DrawLine(xp1, yp1, xp2, yp2, color);  }

6. 使用上面幾個函數,畫出我們設計的溫度表

//更新溫度和濕度  void ssd1306_update_temper(float temp, float humi)  {  int angle = 0;  char buf[100] = {0};  ssd1306_Fill(Black);  uint8_t x,y,r;  //溫度表盤,半圓形  x=30;  y=28;  r=28;  ssd1306_DrawCircle(x,y,2,White);  ssd1306_SetCursor(x-r, y);  ssd1306_DrawString("-15", Font_6x8, White);  ssd1306_SetCursor(x+r-6, y);  ssd1306_DrawString("45", Font_6x8, White);  ssd1306_SetCursor(x-6, y-r+6);  ssd1306_DrawString("15", Font_6x8, White);  ssd1306_DrawArc_from9(x, y, r, 0, 180, White);  //ssd1306_DrawArc_from9(x, y, r-1, 0, 180, White);  ssd1306_draw_line_of_kedu(x,y,r,45,White);  ssd1306_draw_line_of_kedu(x,y,r,90,White);  ssd1306_draw_line_of_kedu(x,y,r,135,White);  angle = (int)((temp + 15 )*180/60);  ssd1306_draw_line_of_arc(x, y, r-2,angle, White);  ssd1306_SetCursor(x+r+6, y-r/2);  sprintf(buf, "%.1fC", temp);  ssd1306_DrawString(buf, Font_7x10, White);  //濕度表盤,半圓形  x=30;  y=55;  r=22;  ssd1306_DrawCircle(x,y,2,White);  ssd1306_SetCursor(x-r-4, y);  ssd1306_DrawString("20", Font_6x8, White);  ssd1306_SetCursor(x+r-6, y);  ssd1306_DrawString("100", Font_6x8, White);  ssd1306_SetCursor(x-6, y-r+6);  ssd1306_DrawString("60", Font_6x8, White);  ssd1306_DrawArc_from9(x, y, r, 0, 180, White);  //ssd1306_DrawArc_from9(x, y, r-1, 0, 180, White);  ssd1306_draw_line_of_kedu(x,y,r,45,White);  ssd1306_draw_line_of_kedu(x,y,r,90,White);  ssd1306_draw_line_of_kedu(x,y,r,135,White);  angle = (int)((humi - 20 )*180/80);  ssd1306_draw_line_of_arc(x, y, r-2,angle, White);  ssd1306_SetCursor(x+r+6, y-r/2);  sprintf(buf, "%%%.1f", humi);  ssd1306_DrawString(buf, Font_7x10, White);  //ssd1306_TestArc();  ssd1306_UpdateScreen();  }

7. I2C管腳的初始化和任務初始化

void Ssd1306TestTask(void* arg)  {  (void) arg;  uint32_t retval = 0;  GpioInit();  IoSetFunc(WIFI_IOT_IO_NAME_GPIO_13, WIFI_IOT_IO_FUNC_GPIO_13_I2C0_SDA);  IoSetFunc(WIFI_IOT_IO_NAME_GPIO_14, WIFI_IOT_IO_FUNC_GPIO_14_I2C0_SCL);  I2cInit(WIFI_IOT_I2C_IDX_0, OLED_I2C_BAUDRATE);  WatchDogDisable();  usleep(20*1000);  ssd1306_Init();  ssd1306_Fill(Black);  ssd1306_SetCursor(0, 0);  ssd1306_DrawString("Hello HarmonyOS!", Font_7x10, White);  uint32_t start = HAL_GetTick();  ssd1306_UpdateScreen();  uint32_t end = HAL_GetTick();  printf("ssd1306_UpdateScreen time cost: %d ms.\r\n", end - start);  //  retval = AHT20_Calibrate();  printf("AHT20_Calibrate: %d\r\n", retval);  TestGetTick();  while (1) {  float temp = 0.0, humi = 0.0;  //retval = AHT20_StartMeasure();  //printf("AHT20_StartMeasure: %d\r\n", retval);  retval = AHT20_GetTemperHumi(&temp, &humi);  printf("AHT20_GetMeasureResult: %d, temp = %.2f, humi = %.2f\r\n", retval, temp, humi);  ssd1306_update_temper(temp, humi);  sleep(1);  //ssd1306_TestAll();  }  }

到此,相信大家對“如何實現溫度傳感器和OLED”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

湖南省| 侯马市| 平罗县| 澄江县| 保靖县| 龙泉市| 澄城县| 古田县| 陇南市| 吉林市| 宁乡县| 马龙县| 广河县| 固阳县| 石楼县| 锦州市| 织金县| 延川县| 彝良县| 布尔津县| 梨树县| 芜湖县| 塔河县| 太和县| 杭州市| 苗栗市| 环江| 岳阳县| 桦南县| 邮箱| 大渡口区| 壤塘县| 齐齐哈尔市| 彰武县| 获嘉县| 久治县| 宁都县| 雷波县| 苗栗市| 平阳县| 确山县|