主頁 >  其他 > 畢業設計 - 基于單片機的室內環境溫濕度檢測系統 - AB32VG1 物聯網 嵌入式

畢業設計 - 基于單片機的室內環境溫濕度檢測系統 - AB32VG1 物聯網 嵌入式

2022-01-03 07:10:46 其他

文章目錄

  • 0 簡介
  • 1 專案介紹
  • 2 硬體說明
    • 2.1 AB32VG1單片機
    • 2.2 DHT22數字溫濕度傳感器
  • 3 代碼實作
  • 4 實作效果


0 簡介

Hi,大家好,這里是丹成學長,今天向大家介紹一個 單片機專案

基于單片機的室內環境溫濕度檢測系統

大家可用于 課程設計 或 畢業設計

技術解答、畢設幫助、開題指導
print("Q 746876041") 

1 專案介紹

本設計基于中科藍訊的AB32VG1開發板, 通過DHT22檢測室內環境,當溫度或濕度高于設定值或低于設定值,就會發出警報,通過螢屏顯示出當前室內的溫度值,

只作為畢設開發的一個小功能,一般不能作為一個畢業設計

2 硬體說明

2.1 AB32VG1單片機

AB32VG1主頻 120M ,片上集成 RAM 192K, Flash 4Mbit,ADC,PWM,USB,UART,IIC 等資源,提供SDK,驅動齊全,支持RT-Thread Studio 開發應用,圖形化配置系統,一鍵開啟外設,一鍵使用軟體包,強大的自動代碼編輯輔助,

2.2 DHT22數字溫濕度傳感器

DHT22數字溫濕度傳感器是一款含有已校準數字信號輸出的溫濕度復合傳感器,它應用專用的數字模塊采集技術和溫濕度傳感技術,確保產品具有極高的可靠性和卓越的長期穩定性,DHT11是一款溫濕度傳感器, 其測量精度為:濕度±5%RH, 溫度±2℃,量程為:濕度20-90%RH, 溫度0~50℃,采樣周期大于等于1秒/次,傳感器包括一個電阻式感濕元件和一個NTC測溫元件,并連接一個高性能8位單片機相,DHT11的優點有:品質高、回應快、抗干擾能力強、性價比極高、體積小、功耗低等,

3 代碼實作

#include <board.h>

#include "dhtxx.h"



#define DBG_TAG                  "sensor.asair.dhtxx"

#ifdef PKG_USING_DHTXX_DEBUG

#define DBG_LVL                  DBG_LOG

#else

#define DBG_LVL                  DBG_ERROR

#endif

#include <rtdbg.h>



/* timing */

#define DHT1x_BEGIN_TIME         20  /* ms */

#define DHT2x_BEGIN_TIME         1   /* ms */

#define DHTxx_PULL_TIME          30  /* us */

#define DHTxx_REPLY_TIME         100 /* us */

#define MEASURE_TIME             40  /* us */



/**

 * This function will split a number into two part according to times.

 *

 * @param num      the number will be split

 * @param integer  the integer part

 * @param decimal  the decimal part

 * @param times    how many times of the real number (you should use 10 in this case)

 *

 * @return 0 if num is positive, 1 if num is negative

 */

int split_int(const int num, int *integer, int *decimal, const rt_uint32_t times)

{

    int flag = 0;

    if (num < 0) flag = 1;



    int anum = num<0 ? -num : num;

    *integer = anum / times;

    *decimal = anum % times;



    return flag;

}



/**

 * This function will convert temperature in degree Celsius to Kelvin.

 *

 * @param c  the temperature indicated by degree Celsius

 *

 * @return the result

 */

float convert_c2k(float c)

{

    return c + 273.15;

}



/**

 * This function will convert temperature in degree Celsius to Fahrenheit.

 *

 * @param c  the temperature indicated by degree Celsius

 *

 * @return the result

 */

float convert_c2f(float c)

{

    return c * 1.8 + 32;

}



/**

 * This function will convert temperature in degree Fahrenheit to Celsius.

 *

 * @param f  the temperature indicated by degree Fahrenheit

 *

 * @return the result

 */

float convert_f2c(float f)

{

    return (f - 32) * 0.55555;

}



/**

 * This function will read a bit from sensor.

 *

 * @param pin  the pin of Dout

 *

 * @return the bit value

 */

static uint8_t dht_read_bit(const rt_base_t pin)

{

    uint8_t retry = 0;



    while(rt_pin_read(pin) && retry < DHTxx_REPLY_TIME)

    {

        retry++;

        rt_hw_us_delay(1);

    }



    retry = 0;

    while(!rt_pin_read(pin) && retry < DHTxx_REPLY_TIME)

    {

        retry++;

        rt_hw_us_delay(1);

    }



    rt_hw_us_delay(MEASURE_TIME);

    

    return rt_pin_read(pin);

}



/**

 * This function will read a byte from sensor.

 *

 * @param pin  the pin of Dout

 *

 * @return the byte

 */

static uint8_t dht_read_byte(const rt_base_t pin)

{

    uint8_t i, byte = 0;



    for(i=0; i<8; i++)

    {

        byte <<= 1;

        byte |= dht_read_bit(pin);

    }



    return byte;

}



/**

 * This function will read and update data array.

 *

 * @param dev  the device to be operated

 *

 * @return RT_TRUE if read successfully, otherwise return RT_FALSE.

 */

rt_bool_t dht_read(dht_device_t dev)

{

    RT_ASSERT(dev);



    uint8_t i, retry = 0, sum = 0;



#ifdef PKG_USING_DHTXX_INTERRUPT_DISABLE

    rt_base_t level;

#endif



    /* Reset data buffer */

    rt_memset(dev->data, 0, DHT_DATA_SIZE);



    /* MCU request sampling */

    rt_pin_mode(dev->pin, PIN_MODE_OUTPUT);

    rt_pin_write(dev->pin, PIN_LOW);



    if (dev->type == DHT11 || dev->type == DHT12) {

        rt_thread_mdelay(DHT1x_BEGIN_TIME);        /* Tbe */

    } else {

        rt_thread_mdelay(DHT2x_BEGIN_TIME);

    }



#ifdef PKG_USING_DHTXX_INTERRUPT_DISABLE

    level = rt_hw_interrupt_disable();

#endif



    rt_pin_mode(dev->pin, PIN_MODE_INPUT_PULLUP);

    rt_hw_us_delay(DHTxx_PULL_TIME);               /* Tgo */



    /* Waiting for sensor reply */

    while (rt_pin_read(dev->pin) && retry < DHTxx_REPLY_TIME)

    {

        retry++;

        rt_hw_us_delay(1);                         /* Trel */

    }

    if(retry >= DHTxx_REPLY_TIME) return RT_FALSE;



    retry = 0;

    while (!rt_pin_read(dev->pin) && retry < DHTxx_REPLY_TIME)

    {

        retry++;

        rt_hw_us_delay(1);                         /* Treh */

    };

    if(retry >= DHTxx_REPLY_TIME) return RT_FALSE;



    /* Read data */

    for(i=0; i<DHT_DATA_SIZE; i++)

    {

        dev->data[i] = dht_read_byte(dev->pin);

    }



#ifdef PKG_USING_DHTXX_INTERRUPT_DISABLE

    rt_hw_interrupt_enable(level);

#endif



    /* Checksum */

    for(i=0; i<DHT_DATA_SIZE-1; i++)

    {

        sum += dev->data[i];

    }

    if(sum != dev->data[4]) return RT_FALSE;



    return RT_TRUE;

}



/**

 * This function will get the humidity from dhtxx sensor.

 *

 * @param dev  the device to be operated

 *

 * @return the humidity value

 */

rt_int32_t dht_get_humidity(dht_device_t const dev)

{

    RT_ASSERT(dev);



    rt_int32_t humi = 0;



    switch(dev->type)

    {

    case DHT11:

    case DHT12:

        humi = dev->data[0] * 10 + dev->data[1];

        break;

    case DHT21:

    case DHT22:

        humi = (dev->data[0] << 8) + dev->data[1];

        break;

    default:

        break;

    }



    return humi;

}



/**

 * This function will get the temperature from dhtxx sensor.

 *

 * @param dev  the device to be operated

 *

 * @return the temperature value

 */

rt_int32_t dht_get_temperature(dht_device_t const dev)

{

    RT_ASSERT(dev);



    rt_int32_t temp = 0;



    switch(dev->type)

    {

    case DHT11:

    case DHT12:

        temp = dev->data[2] * 10 + (dev->data[3] & 0x7f);

        if(dev->data[3] & 0x80) {

            temp = -temp;

        }

        break;

    case DHT21:

    case DHT22:

        temp = ((dev->data[2] & 0x7f) << 8) + dev->data[3];

        if(dev->data[2] & 0x80) {

            temp = -temp;

        }

        break;

    default:

        break;

    }



    return temp;

}



/**

 * This function will init dhtxx sensor device.

 *

 * @param dev  the device to init

 * @param pin  the pin of Dout

 *

 * @return the device handler

 */

rt_err_t dht_init(struct dht_device *dev, const rt_base_t pin)

{

    if(dev == NULL)

        return -RT_ERROR;



    dev->type = DHT_TYPE;

    dev->pin  = pin;



    rt_memset(dev->data, 0, DHT_DATA_SIZE);

    rt_pin_mode(dev->pin, PIN_MODE_INPUT_PULLUP);

    

    return RT_EOK;

}



dht_device_t dht_create(const rt_base_t pin)

{

    dht_device_t dev;



    dev = rt_calloc(1, sizeof(struct dht_device));

    if (dev == RT_NULL)

    {

        LOG_E("Can't allocate memory for dhtxx device");

        return RT_NULL;

    }



    dev->type = DHT_TYPE;

    dev->pin  = pin;



    rt_memset(dev->data, 0, DHT_DATA_SIZE);

    rt_pin_mode(dev->pin, PIN_MODE_INPUT_PULLUP);



    return dev;

}



void dht_delete(dht_device_t dev)

{

    if (dev)

        rt_free(dev);

}



#include <rtthread.h>

#include <rtdevice.h>

#include <board.h>

#include "dhtxx.h"



#define DATA_PIN                 PKG_USING_DHTXX_SAMPLE_PIN



/* cat_dhtxx sensor data by dynamic */

static void cat_dhtxx(void)

{

    dht_device_t sensor = dht_create(DATA_PIN);



    if(dht_read(sensor)) {



        rt_int32_t temp = dht_get_temperature(sensor);

        rt_int32_t humi = dht_get_humidity(sensor);



        rt_kprintf("Temp: %d, Humi: %d\n", temp, humi);

    }

    else {

        rt_kprintf("Read dht sensor failed.\n");

    }



    dht_delete(sensor);

}



#ifdef FINSH_USING_MSH

MSH_CMD_EXPORT(cat_dhtxx, read dhtxx humidity and temperature);

#endif





#ifndef __DHTXX_H__

#define __DHTXX_H__



#include <rtthread.h>

#include <rtdevice.h>

#include <sensor.h>



#define DHTLIB_VERSION                       "0.9.0"

#define DHT_DATA_SIZE                        5



/* sensor model type */

#define DHT11                                0

#define DHT12                                1

#define DHT21                                2

#define DHT22                                3

#define AM2301                               DHT21

#define AM2302                               DHT22

#define AM2320                               DHT22



#if defined(PKG_USING_DHTXX_TYPE_DHT11)

#define DHT_TYPE                             DHT11

#elif defined(PKG_USING_DHTXX_TYPE_DHT12)

#define DHT_TYPE                             DHT12

#elif defined(PKG_USING_DHTXX_TYPE_DHT21)

#define DHT_TYPE                             DHT21

#elif defined(PKG_USING_DHTXX_TYPE_DHT22)

#define DHT_TYPE                             DHT22

#endif





struct dht_device

{

    rt_base_t   pin;

    rt_uint8_t  type;

    rt_uint8_t  data[DHT_DATA_SIZE];

    rt_mutex_t  lock;

};

typedef struct dht_device *dht_device_t;



dht_device_t dht_create(const rt_base_t pin);

void dht_delete(dht_device_t dev);



rt_err_t   dht_init(struct dht_device *dev, const rt_base_t pin);

rt_bool_t  dht_read(dht_device_t dev);

rt_int32_t dht_get_humidity(dht_device_t dev);

rt_int32_t dht_get_temperature(dht_device_t dev);



float convert_c2k(float c);

float convert_c2f(float c);

float convert_f2c(float f);



rt_int32_t split_int(const rt_int32_t num, rt_int32_t *integer, 

                     rt_int32_t *decimal, const rt_uint32_t times);



rt_err_t rt_hw_dht_init(const char *name, struct rt_sensor_config *cfg);



#endif /* __DHTXX_H__ */

#include "oled.h"

#include "oledfont.h"



u8 OLED_GRAM[144][8];



struct OLED_sss

{

  uint8_t OLED_SCLK;

  uint8_t OLED_SDIN;

  uint8_t OLED_RST;

  uint8_t OLED_DC;

  uint8_t OLED_CS;

};

struct OLED_sss oled_ccc;



//反顯函式

void OLED_ColorTurn(u8 i)

{

  if(i==0)

    {

      OLED_WR_Byte(0xA6,OLED_CMD);//正常顯示

    }

  if(i==1)

    {

      OLED_WR_Byte(0xA7,OLED_CMD);//反色顯示

    }

}



//螢屏旋轉180度

void OLED_DisplayTurn(u8 i)

{

  if(i==0)

    {

      OLED_WR_Byte(0xC8,OLED_CMD);//正常顯示

      OLED_WR_Byte(0xA1,OLED_CMD);

    }

  if(i==1)

    {

      OLED_WR_Byte(0xC0,OLED_CMD);//反轉顯示

      OLED_WR_Byte(0xA0,OLED_CMD);

    }

}



void OLED_WR_Byte(u8 dat,u8 cmd)

{

  u8 i;

  if(cmd)

    OLED_DC_Set();

  else

    OLED_DC_Clr();

  OLED_CS_Clr();

  for(i=0;i<8;i++)

  {

    OLED_SCLK_Clr();

    if(dat&0x80)

       OLED_SDIN_Set();

    else

       OLED_SDIN_Clr();

    OLED_SCLK_Set();

    dat<<=1;

  }

  OLED_CS_Set();

  OLED_DC_Set();

}



//開啟OLED顯示

void OLED_DisPlay_On(void)

{

  OLED_WR_Byte(0x8D,OLED_CMD);//電荷泵使能

  OLED_WR_Byte(0x14,OLED_CMD);//開啟電荷泵

  OLED_WR_Byte(0xAF,OLED_CMD);//點亮螢屏

}



//關閉OLED顯示

void OLED_DisPlay_Off(void)

{

  OLED_WR_Byte(0x8D,OLED_CMD);//電荷泵使能

  OLED_WR_Byte(0x10,OLED_CMD);//關閉電荷泵

  OLED_WR_Byte(0xAF,OLED_CMD);//關閉螢屏

}



//更新顯存到OLED

void OLED_Refresh(void)

{

  u8 i,n;

  for(i=0;i<8;i++)

  {

     OLED_WR_Byte(0xb0+i,OLED_CMD); //設定行起始地址

     OLED_WR_Byte(0x00,OLED_CMD);   //設定低列起始地址

     OLED_WR_Byte(0x10,OLED_CMD);   //設定高列起始地址

     for(n=0;n<128;n++)

     OLED_WR_Byte(OLED_GRAM[n][i],OLED_DATA);

  }

}

//清屏函式

void OLED_Clear(void)

{

  u8 i,n;

  for(i=0;i<8;i++)

  {

     for(n=0;n<128;n++)

      {

       OLED_GRAM[n][i]=0;//清除所有資料

      }

  }

  OLED_Refresh();//更新顯示

}



//畫點

//x:0~127

//y:0~63

void OLED_DrawPoint(u8 x,u8 y)

{

  u8 i,m,n;

  i=y/8;

  m=y%8;

  n=1<<m;

  OLED_GRAM[x][i]|=n;

}



//清除一個點

//x:0~127

//y:0~63

void OLED_ClearPoint(u8 x,u8 y)

{

  u8 i,m,n;

  i=y/8;

  m=y%8;

  n=1<<m;

  OLED_GRAM[x][i]=~OLED_GRAM[x][i];

  OLED_GRAM[x][i]|=n;

  OLED_GRAM[x][i]=~OLED_GRAM[x][i];

}





//畫線

//x:0~128

//y:0~64

void OLED_DrawLine(u8 x1,u8 y1,u8 x2,u8 y2)

{

  u8 i,k,k1,k2,y0;

  if((x1<0)||(x2>128)||(y1<0)||(y2>64)||(x1>x2)||(y1>y2))return;

  if(x1==x2)    //畫豎線

  {

      for(i=0;i<(y2-y1);i++)

      {

        OLED_DrawPoint(x1,y1+i);

      }

  }

  else if(y1==y2)   //畫橫線

  {

      for(i=0;i<(x2-x1);i++)

      {

        OLED_DrawPoint(x1+i,y1);

      }

  }

  else      //畫斜線

  {

    k1=y2-y1;

    k2=x2-x1;

    k=k1*10/k2;

    for(i=0;i<(x2-x1);i++)

      {

        OLED_DrawPoint(x1+i,y1+i*k/10);

      }

  }

}

//x,y:圓心坐標

//r:圓的半徑

void OLED_DrawCircle(u8 x,u8 y,u8 r)

{

  int a, b,num;

    a = 0;

    b = r;

    while(2 * b * b >= r * r)

    {

        OLED_DrawPoint(x + a, y - b);

        OLED_DrawPoint(x - a, y - b);

        OLED_DrawPoint(x - a, y + b);

        OLED_DrawPoint(x + a, y + b);



        OLED_DrawPoint(x + b, y + a);

        OLED_DrawPoint(x + b, y - a);

        OLED_DrawPoint(x - b, y - a);

        OLED_DrawPoint(x - b, y + a);



        a++;

        num = (a * a + b * b) - r*r;//計算畫的點離圓心的距離

        if(num > 0)

        {

            b--;

            a--;

        }

    }

}



//在指定位置顯示一個字符,包括部分字符

//x:0~127

//y:0~63

//size:選擇字體 12/16/24

//取模方式 逐列式

void OLED_ShowChar(u8 x,u8 y,u8 chr,u8 size1)

{

  u8 i,m,temp,size2,chr1;

  u8 y0=y;

  size2=(size1/8+((size1%8)?1:0))*(size1/2);  //得到字體一個字符對應點陣集所占的位元組數

  chr1=chr-' ';  //計算偏移后的值

  for(i=0;i<size2;i++)

  {

    if(size1==12)

        {temp=asc2_1206[chr1][i];} //呼叫1206字體

    else if(size1==16)

        {temp=asc2_1608[chr1][i];} //呼叫1608字體

    else if(size1==24)

        {temp=asc2_2412[chr1][i];} //呼叫2412字體

    else return;

        for(m=0;m<8;m++)           //寫入資料

        {

          if(temp&0x80)OLED_DrawPoint(x,y);

          else OLED_ClearPoint(x,y);

          temp<<=1;

          y++;

          if((y-y0)==size1)

          {

            y=y0;

            x++;

            break;

          }

        }

  }

}





//顯示字串

//x,y:起點坐標

//size1:字體大小

//*chr:字串起始地址

void OLED_ShowString(u8 x,u8 y,u8 *chr,u8 size1)

{

  while((*chr>=' ')&&(*chr<='~'))//判斷是不是非法字符!

  {

    OLED_ShowChar(x,y,*chr,size1);

    x+=size1/2;

    if(x>128-size1)  //換行

    {

      x=0;

      y+=2;

    }

    chr++;

  }

}



//m^n

u32 OLED_Pow(u8 m,u8 n)

{

  u32 result=1;

  while(n--)

  {

    result*=m;

  }

  return result;

}



顯示2個數字

x,y :起點坐標

len :數字的位數

size:字體大小

void OLED_ShowNum(u8 x,u8 y,u32 num,u8 len,u8 size1)

{

  u8 t,temp;

  for(t=0;t<len;t++)

  {

    temp=(num/OLED_Pow(10,len-t-1))%10;

      if(temp==0)

      {

        OLED_ShowChar(x+(size1/2)*t,y,'0',size1);

      }

      else

      {

        OLED_ShowChar(x+(size1/2)*t,y,temp+'0',size1);

      }

  }

}



//顯示漢字

//x,y:起點坐標

//num:漢字對應的序號

//取模方式 列行式

void OLED_ShowChinese(u8 x,u8 y,u8 num,u8 size1)

{

  u8 i,m,n=0,temp,chr1;

  u8 x0=x,y0=y;

  u8 size3=size1/8;

  while(size3--)

  {

    chr1=num*size1/8+n;

    n++;

      for(i=0;i<size1;i++)

      {

        if(size1==16)

            {temp=Hzk1[chr1][i];}//呼叫16*16字體

        else if(size1==24)

            {temp=Hzk2[chr1][i];}//呼叫24*24字體

        else if(size1==32)

            {temp=Hzk3[chr1][i];}//呼叫32*32字體

        else if(size1==64)

            {temp=Hzk4[chr1][i];}//呼叫64*64字體

        else return;



            for(m=0;m<8;m++)

              {

                if(temp&0x01)OLED_DrawPoint(x,y);

                else OLED_ClearPoint(x,y);

                temp>>=1;

                y++;

              }

              x++;

              if((x-x0)==size1)

              {x=x0;y0=y0+8;}

              y=y0;

       }

  }

}



//num 顯示漢字的個數

//space 每一遍顯示的間隔

void OLED_ScrollDisplay(u8 num,u8 space)

{

  u8 i,n,t=0,m=0,r;

  while(1)

  {

    if(m==0)

    {

      OLED_ShowChinese(128,24,t,16); //寫入一個漢字保存在OLED_GRAM[][]陣列中

      t++;

    }

    if(t==num)

      {

        for(r=0;r<16*space;r++)      //顯示間隔

         {

          for(i=0;i<144;i++)

            {

              for(n=0;n<8;n++)

              {

                OLED_GRAM[i-1][n]=OLED_GRAM[i][n];

              }

            }

           OLED_Refresh();

         }

        t=0;

      }

    m++;

    if(m==16){m=0;}

    for(i=0;i<144;i++)   //實作左移

    {

      for(n=0;n<8;n++)

      {

        OLED_GRAM[i-1][n]=OLED_GRAM[i][n];

      }

    }

    OLED_Refresh();

  }

}



//配置寫入資料的起始位置

void OLED_WR_BP(u8 x,u8 y)

{

  OLED_WR_Byte(0xb0+y,OLED_CMD);//設定行起始地址

  OLED_WR_Byte(((x&0xf0)>>4)|0x10,OLED_CMD);

  OLED_WR_Byte((x&0x0f),OLED_CMD);

}



//x0,y0:起點坐標

//x1,y1:終點坐標

//BMP[]:要寫入的圖片陣列

void OLED_ShowPicture(u8 x0,u8 y0,u8 x1,u8 y1,u8 BMP[])

{

  u32 j=0;

  u8 x=0,y=0;

  if(y%8==0)y=0;

  else y+=1;

  for(y=y0;y<y1;y++)

   {

     OLED_WR_BP(x0,y);

     for(x=x0;x<x1;x++)

     {

       OLED_WR_Byte(BMP[j],OLED_DATA);

       j++;

     }

   }

}



//OLED的初始化

void OLED_Init(void)

{

  oled_ccc.OLED_SCLK = rt_pin_get("PA.3");

  oled_ccc.OLED_SDIN = rt_pin_get("PA.4");

  oled_ccc.OLED_RST = rt_pin_get("PF.1");

  oled_ccc.OLED_DC = rt_pin_get("PB.0");

  oled_ccc.OLED_CS = rt_pin_get("PA.5");



  rt_pin_mode(oled_ccc.OLED_SCLK, PIN_MODE_OUTPUT);

  rt_pin_mode(oled_ccc.OLED_SDIN, PIN_MODE_OUTPUT);

  rt_pin_mode(oled_ccc.OLED_RST, PIN_MODE_OUTPUT);

  rt_pin_mode(oled_ccc.OLED_DC, PIN_MODE_OUTPUT);

  rt_pin_mode(oled_ccc.OLED_CS, PIN_MODE_OUTPUT);



  rt_pin_write(oled_ccc.OLED_SCLK, PIN_HIGH);

  rt_pin_write(oled_ccc.OLED_SDIN, PIN_HIGH);

  rt_pin_write(oled_ccc.OLED_RST, PIN_HIGH);

  rt_pin_write(oled_ccc.OLED_DC, PIN_HIGH);

  rt_pin_write(oled_ccc.OLED_CS, PIN_HIGH);



  OLED_RST_Clr();//復位

  rt_thread_mdelay(200);

  OLED_RST_Set();



  OLED_WR_Byte(0xAE,OLED_CMD);//--turn off oled panel

  OLED_WR_Byte(0x00,OLED_CMD);//---set low column address

  OLED_WR_Byte(0x10,OLED_CMD);//---set high column address

  OLED_WR_Byte(0x40,OLED_CMD);//--set start line address  Set Mapping RAM Display Start Line (0x00~0x3F)

  OLED_WR_Byte(0x81,OLED_CMD);//--set contrast control register

  OLED_WR_Byte(0xCF,OLED_CMD);// Set SEG Output Current Brightness

  OLED_WR_Byte(0xA1,OLED_CMD);//--Set SEG/Column Mapping     0xa0左右反置 0xa1正常

  OLED_WR_Byte(0xC8,OLED_CMD);//Set COM/Row Scan Direction   0xc0上下反置 0xc8正常

  OLED_WR_Byte(0xA6,OLED_CMD);//--set normal display

  OLED_WR_Byte(0xA8,OLED_CMD);//--set multiplex ratio(1 to 64)

  OLED_WR_Byte(0x3f,OLED_CMD);//--1/64 duty

  OLED_WR_Byte(0xD3,OLED_CMD);//-set display offset Shift Mapping RAM Counter (0x00~0x3F)

  OLED_WR_Byte(0x00,OLED_CMD);//-not offset

  OLED_WR_Byte(0xd5,OLED_CMD);//--set display clock divide ratio/oscillator frequency

  OLED_WR_Byte(0x80,OLED_CMD);//--set divide ratio, Set Clock as 100 Frames/Sec

  OLED_WR_Byte(0xD9,OLED_CMD);//--set pre-charge period

  OLED_WR_Byte(0xF1,OLED_CMD);//Set Pre-Charge as 15 Clocks & Discharge as 1 Clock

  OLED_WR_Byte(0xDA,OLED_CMD);//--set com pins hardware configuration

  OLED_WR_Byte(0x12,OLED_CMD);

  OLED_WR_Byte(0xDB,OLED_CMD);//--set vcomh

  OLED_WR_Byte(0x40,OLED_CMD);//Set VCOM Deselect Level

  OLED_WR_Byte(0x20,OLED_CMD);//-Set Page Addressing Mode (0x00/0x01/0x02)

  OLED_WR_Byte(0x02,OLED_CMD);//

  OLED_WR_Byte(0x8D,OLED_CMD);//--set Charge Pump enable/disable

  OLED_WR_Byte(0x14,OLED_CMD);//--set(0x10) disable

  OLED_WR_Byte(0xA4,OLED_CMD);// Disable Entire Display On (0xa4/0xa5)

  OLED_WR_Byte(0xA6,OLED_CMD);// Disable Inverse Display On (0xa6/a7)

  OLED_WR_Byte(0xAF,OLED_CMD);

  OLED_Clear();

}


4 實作效果

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/401466.html

標籤:其他

上一篇:Arduino與FreeRTOS-中斷管理

下一篇:2021。

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 2023年最新微信小程式抓包教程

    01 開門見山 隔一個月發一篇文章,不過分。 首先回顧一下《微信系結手機號資料庫被脫庫事件》,我也是第一時間得知了這個訊息,然后跟蹤了整件事情的經過。下面是這起事件的相關截圖以及近日流出的一萬條資料樣本: 個人認為這件事也沒什么,還不如關注一下之前45億快遞資料查詢渠道疑似在近日復活的訊息。 訊息是 ......

    uj5u.com 2023-04-20 08:48:24 more
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:47:46 more
  • vulnhub_Earth

    前言 靶機地址->>>vulnhub_Earth 攻擊機ip:192.168.20.121 靶機ip:192.168.20.122 參考文章 https://www.cnblogs.com/Jing-X/archive/2022/04/03/16097695.html https://www.cnb ......

    uj5u.com 2023-04-20 07:46:20 more
  • 從4k到42k,軟體測驗工程師的漲薪史,給我看哭了

    清明節一過,盲猜大家已經無心上班,在數著日子準備過五一,但一想到銀行卡里的余額……瞬間心情就不美麗了。最近,2023年高校畢業生就業調查顯示,本科畢業月平均起薪為5825元。調查一出,便有很多同學表示自己又被平均了。看著這一資料,不免讓人想到前不久中國青年報的一項調查:近六成大學生認為畢業10年內會 ......

    uj5u.com 2023-04-20 07:44:00 more
  • 最新版本 Stable Diffusion 開源 AI 繪畫工具之中文自動提詞篇

    🎈 標簽生成器 由于輸入正向提示詞 prompt 和反向提示詞 negative prompt 都是使用英文,所以對學習母語的我們非常不友好 使用網址:https://tinygeeker.github.io/p/ai-prompt-generator 這個網址是為了讓大家在使用 AI 繪畫的時候 ......

    uj5u.com 2023-04-20 07:43:36 more
  • 漫談前端自動化測驗演進之路及測驗工具分析

    隨著前端技術的不斷發展和應用程式的日益復雜,前端自動化測驗也在不斷演進。隨著 Web 應用程式變得越來越復雜,自動化測驗的需求也越來越高。如今,自動化測驗已經成為 Web 應用程式開發程序中不可或缺的一部分,它們可以幫助開發人員更快地發現和修復錯誤,提高應用程式的性能和可靠性。 ......

    uj5u.com 2023-04-20 07:43:16 more
  • CANN開發實踐:4個DVPP記憶體問題的典型案例解讀

    摘要:由于DVPP媒體資料處理功能對存放輸入、輸出資料的記憶體有更高的要求(例如,記憶體首地址128位元組對齊),因此需呼叫專用的記憶體申請介面,那么本期就分享幾個關于DVPP記憶體問題的典型案例,并給出原因分析及解決方法。 本文分享自華為云社區《FAQ_DVPP記憶體問題案例》,作者:昇騰CANN。 DVPP ......

    uj5u.com 2023-04-20 07:43:03 more
  • msf學習

    msf學習 以kali自帶的msf為例 一、msf核心模塊與功能 msf模塊都放在/usr/share/metasploit-framework/modules目錄下 1、auxiliary 輔助模塊,輔助滲透(埠掃描、登錄密碼爆破、漏洞驗證等) 2、encoders 編碼器模塊,主要包含各種編碼 ......

    uj5u.com 2023-04-20 07:42:59 more
  • Halcon軟體安裝與界面簡介

    1. 下載Halcon17版本到到本地 2. 雙擊安裝包后 3. 步驟如下 1.2 Halcon軟體安裝 界面分為四大塊 1. Halcon的五個助手 1) 影像采集助手:與相機連接,設定相機引數,采集影像 2) 標定助手:九點標定或是其它的標定,生成標定檔案及內參外參,可以將像素單位轉換為長度單位 ......

    uj5u.com 2023-04-20 07:42:17 more
  • 在MacOS下使用Unity3D開發游戲

    第一次發博客,先發一下我的游戲開發環境吧。 去年2月份買了一臺MacBookPro2021 M1pro(以下簡稱mbp),這一年來一直在用mbp開發游戲。我大致分享一下我的開發工具以及使用體驗。 1、Unity 官網鏈接: https://unity.cn/releases 我一般使用的Apple ......

    uj5u.com 2023-04-20 07:40:19 more