STM32CubeMX FreeRTOS u8g2图片菜单制作

一、制作图片数组

找显示的图标,下面的网站里面是只有黑白的图 

Svg Vector Icons & PNG / PSD / EPS / PNM / Free Downloads - OnlineWebFonts.COM

先添加白板背景,在设置图片尺寸 在线添加图片背景

oled显示分辨率为128*64 图片尺寸不能大于这个

制作好的图片 

 

然后就是取模了Arduino中文社区

 修改下数组名字,数组放在用户头文件下面自定义代码区间

// width: 48, height: 48
const unsigned char startp[]= { 0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0xe0,0x07,0x00,0x00,0x00,0x00,0xfc,0x3f,0x00,0x00,0x00,0x00,0x0f,0xf0,
0x00,0x00,0x00,0x80,0x03,0xc0,0x01,0x00,0x00,0xc0,0x00,0x00,0x03,0x00,0x00,0x60,0xf8,
0x0f,0x06,0x00,0x00,0x30,0x3c,0x3c,0x0c,0x00,0x00,0x30,0x07,0xe0,0x0c,0x00,0x00,0x98,
0x0f,0xc0,0x19,0x00,0x00,0x98,0x3f,0xfc,0x19,0x00,0x00,0xd8,0x66,0x6e,0x1b,0x00,0x00,
0xd8,0x7c,0x36,0x1b,0x00,0x00,0x30,0x78,0x1e,0x0c,0x00,0x00,0x60,0x00,0x00,0x06,0x00,
0x00,0xc0,0x03,0xc0,0x03,0x00,0x00,0xe0,0xff,0xff,0x07,0x00,0x00,0xe0,0xff,0xff,0x07,
0x00,0x00,0x30,0xff,0xff,0x0c,0x00,0x00,0x38,0xf8,0x1f,0x1c,0x00,0x00,0x38,0x00,0x00,
0x1c,0x00,0x00,0x38,0x00,0x00,0x1c,0x00,0x00,0x38,0x00,0x00,0x1c,0x00,0x00,0x3c,0x00,
0x00,0x3c,0x00,0x00,0x3c,0x00,0x00,0x3c,0x00,0x00,0x3c,0x00,0x00,0x34,0x00,0x00,0x2c,
0x00,0x00,0x34,0x00,0x00,0x2c,0x00,0x00,0x34,0x00,0x00,0x6c,0x00,0x00,0x36,0x00,0x00,
0x6c,0x00,0x00,0x36,0x00,0x00,0x6c,0x00,0x00,0x36,0x00,0x00,0x4c,0x00,0x00,0x32,0x00,
0x00,0xcc,0x00,0x00,0x33,0x00,0x00,0xcc,0x00,0x00,0x33,0x00,0x00,0x8c,0x00,0x00,0x31,
0x00,0x00,0x8c,0x01,0x80,0x31,0x00,0x00,0xc8,0x01,0x80,0x13,0x00,0x00,0xd8,0x03,0xc0,
0x1b,0x00,0x00,0x58,0x06,0x60,0x1a,0x00,0x00,0x70,0x0c,0x30,0x0e,0x00,0x00,0x20,0x18,
0x18,0x04,0x00,0x00,0x00,0xf0,0x0f,0x00,0x00,0x00,0x00,0xc0,0x03,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00 };

 这样一个图片数组就取模成功了

直接主函数调用显示

		u8g2_ClearBuffer(&u8g2);//清空缓存
		u8g2_DrawXBMP(&u8g2,40,0,48,48,startp);//显示图片数组
		u8g2_SendBuffer(&u8g2);//发送缓存到oled

整个任务代码,包含显示进度条,i加的值可以调节进度条的速度

void StartTask(void const * argument)
{
  /* USER CODE BEGIN StartTask */
  /* Infinite loop */
  char percentageText[20];
  u8g2Init(&u8g2);//just use once in one task

  for(;;)
  { 
    vTaskSuspend(menuTaskHandle);//挂起菜单任务句柄
        //显示图片
		u8g2_ClearBuffer(&u8g2);
		u8g2_DrawXBMP(&u8g2,40,0,48,48,startp);
		u8g2_SendBuffer(&u8g2);
		
		// Simulate loading process, increasing by 1% each time
		for (int i = 10; i <= 100; i += 1) {        //i from 10 start cover actual rounded
				// Draw percentage text
				u8g2_SetFont(&u8g2, u8g2_font_ncenB08_tr);
				snprintf(percentageText, sizeof(percentageText), "%d%%", i);
				u8g2_DrawStr(&u8g2, 95, 59, percentageText);

				// Draw rounded progress bar background
				u8g2_DrawRFrame(&u8g2, 10, 50, 80, 10, 3);

				// Calculate actual progress bar length
				uint8_t progressBarLength = (i*80)/ 100;

				// Draw actual rounded progress bar
				u8g2_DrawRBox(&u8g2, 10, 50,progressBarLength, 10, 3);
				u8g2_SendBuffer(&u8g2);
				osDelay(20);
		}

		// clear data update screen 立即关闭显示
		u8g2_ClearBuffer(&u8g2);
		u8g2_SendBuffer(&u8g2);
		u8g2_UpdateDisplay(&u8g2);     

		vTaskResume(menuTaskHandle);//恢复菜单任务
		vTaskDelete(startTaskHandle);//删除自己

  }
  /* USER CODE END StartTask */
}

  freertos.c中初始化任务

/* USER CODE BEGIN PTD */

u8g2_t u8g2; // a structure which will contain all the data for one display


int fputc(int ch,FILE *f)
{
		HAL_UART_Transmit(&huart1,(uint8_t*)&ch,1,0xFFFF);
		return ch;
}
          
void ui_show(uint8_t x,uint8_t y){
	
		u8g2_DrawXBMP(&u8g2,1,1,30,30,clockp);
		u8g2_DrawXBMP(&u8g2,33,1,30,30,wifip);
		u8g2_DrawXBMP(&u8g2,65,1,30,30,tempp);
		u8g2_DrawXBMP(&u8g2,97,1,30,30,humip);
		u8g2_DrawXBMP(&u8g2,1,33,30,30,misicp);
		u8g2_DrawXBMP(&u8g2,33,33,30,30,smockp);
		u8g2_DrawXBMP(&u8g2,65,33,30,30,lightp);
		u8g2_DrawXBMP(&u8g2,97,33,30,30,waterp);
		u8g2_DrawRFrame(&u8g2, x, y, 32, 32, 2);
		u8g2_SendBuffer(&u8g2);
}

 int run_str(int *now,int *trag,const int speed,const int c_speed)
{
	int temp = 0;
	if (*now > *trag)
	{
		temp = ((*now - *trag) > c_speed) ? speed : c_speed;
		*now -= temp;
	}
	else if (*now < *trag)
	{
		temp = ((*trag - *now) > c_speed) ? speed : c_speed;
		*now += temp;
	}
	else 
	{
		return 1;
	}
	return 0;
}
/* USER CODE END PTD */

菜单任务

void MenuTask(void const * argument)
{
  /* USER CODE BEGIN MenuTask */
  /* Infinite loop */
		char tempText[20];
		char humiText[20];
		char displayText[10]; 
		int x=0,x_t=0,y=0,flag=0;
		int sedmu=0;
		uint8_t temp=55,humi=55;
		//MyMessage receivemessage;
  for(;;)
  {	osDelay(20);	
		// 接收消息从消息队列
//	 if (xQueueReceive(xQueue, &receivemessage, portMAX_DELAY) == pdPASS&&sedmu==0) {
		// receivedMessage 包含了发送的消息数据
//		u8g2_ClearBuffer(&u8g2);
//主页菜单		
//		// Show humi and temp
//		u8g2_SetFont(&u8g2, u8g2_font_ncenB08_tr);
//		snprintf(tempText, sizeof(tempText), "Smock: %d",temp);
//		u8g2_DrawStr(&u8g2, 4, 10, tempText);
//		snprintf(humiText, sizeof(humiText), "Power: %d",humi);
//		u8g2_DrawStr(&u8g2, 68, 10, humiText);
//		snprintf(tempText, sizeof(tempText), "Light: %d",temp);
//		u8g2_DrawStr(&u8g2, 8, 61, tempText);
//		snprintf(humiText, sizeof(humiText), "Water: %d",humi);
//		u8g2_DrawStr(&u8g2, 70, 61, humiText);
//		 
//		u8g2_DrawFrame(&u8g2, 0, 0, 128, 64); 
//		 // 绘制线条
//		u8g2_DrawLine(&u8g2, 0, 13, 128, 13);
//		u8g2_DrawLine(&u8g2, 64, 0, 64, 13);
//		 // 绘制线条
//		u8g2_DrawLine(&u8g2, 0, 51, 128, 51);
//		u8g2_DrawLine(&u8g2, 64, 64, 64, 51);	 
//		 
//		u8g2_DrawXBMP(&u8g2,16,18,30,30,humip);	 
//		u8g2_SetFont(&u8g2, u8g2_font_10x20_mf);		 
//		snprintf(humiText, sizeof(humiText), "%d%%", humi);
//		u8g2_DrawStr(&u8g2, 54, 40, humiText);
//		u8g2_SendBuffer(&u8g2);
//	 }

//列表菜单
			if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_3)==0){
				osDelay(20);
				if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_3)==0){
					flag ++;
					if(flag>3)
					{flag=0;}
				}
			}
			if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_4)==0){
				osDelay(20);
				if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_4)==0){
					flag--;
					if(flag<0)
					{flag=3;}
				
				}
			}
		
		switch(flag){
				case 1:x=0,x_t=13;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,1,0);break;
				case 2:x=13,x_t=26;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,1,0);break;
				case 3:x=26,x_t=0;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,1,0);break;
				
				default: break;
	  }
		u8g2_SetFont(&u8g2, u8g2_font_ncenB08_tr);
		u8g2_DrawStr(&u8g2, 10, 12, "Clock");
		u8g2_DrawStr(&u8g2,10,24, "Hour");
		u8g2_DrawStr(&u8g2,10,36, "Min");
		u8g2_DrawRFrame(&u8g2, 0, x, 128, 14,3);		
		u8g2_SendBuffer(&u8g2);

//图形菜单
//		if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_3)==0){
//			osDelay(18);
//			if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_3)==0){
//				sedmu=1;
//			}
//		}
//		if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_3)==0){
//			osDelay(200);
//			if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_3)==0){
//				sedmu=0;
//			}
//		}

//			u8g2_ClearBuffer(&u8g2);
//			int i=1,j=3;
//			if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_3)==0){
//				osDelay(20);
//				if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_3)==0){
//					flag ++;
//					if(flag>8)
//					{flag=0;}
//				}
//			}
//			if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_4)==0){
//				osDelay(20);
//				if(HAL_GPIO_ReadPin(GPIOA,GPIO_PIN_4)==0){
//					flag--;
//					if(flag<0)
//					{flag=8;}
//				
//				}
//			}
//			switch(flag){
//				case 1:x=0,x_t=32;y=0;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,i,j);break;
//				case 2:x=32,x_t=64;y=0;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,i,j);break;
//				case 3:x=64,x_t=96;y=0;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,i,j);break;
//				case 4:x=96,x_t=0;y=0;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,i,j);break;
//				case 5:x=0,x_t=32;y=32;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,i,j);break;
//				case 6:x=32,x_t=64;y=32;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,i,j);break;
//				case 7:x=64,x_t=96;y=32;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,i,j);break;
//				case 8:x=96,x_t=0;y=32;u8g2_ClearBuffer(&u8g2);run_str(&x,&x_t,i,j);break;
//				default: break;
//			}
//			ui_show(x,y);




  }
  /* USER CODE END MenuTask */
}

主页菜单

图形菜单

列表菜单

  • 10
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: STM32CubeMX是ST公司提供的一款STM32微控制器的配置工具,可以帮助用户快速配置STM32的外设和中断。FreeRTOS是一个免费的嵌入式实时操作系统。 在STM32CubeMX中使用FreeRTOS需要先在STM32CubeMX中配置好外设并生成代码,然后将FreeRTOS的文件加入工程中,最后在生成的代码中添加FreeRTOS相关的代码即可。 教程步骤: 1. 下载并安装STM32CubeMX 2. 下载FreeRTOS源代码 3. 在STM32CubeMX中配置好外设并生成代码 4. 将FreeRTOS的文件加入工程中 5. 在STM32CubeMX生成的代码中添加FreeRTOS相关的代码 6. 编译并下载程序到STM32微控制器中 具体的实现方法可以参考ST官方提供的教程或者网上的相关资料。 ### 回答2: STM32CubeMX是STMicroelectronics公司开发的一个可视化的嵌入式软件配置工具。它支持多种STM32系列微控制器,可以方便地进行Pinout、时钟、电源、GPIO、外设配置,并生成代码框架。这些框架可以方便地集成在任意IDE中,如IAR、KEIL和Atollic TrueSTUDIO等,以便进行开发和调试。 FreeRTOS是一款基于MIT许可证的实时操作系统(RTOS)。它是免费、开源的,具有许多实用的功能,如任务管理、调度、同步、信号量、消息队列等。FreeRTOS支持多种微控制器,如ARM Cortex-M系列、MSP430、PIC32等。 在STM32CubeMX中,可以方便地选择FreeRTOS作为操作系统,在初始化时生成FreeRTOS的代码框架。这些框架包含了FreeRTOS的全部功能,并且集成了STM32的底层驱动程序和HAL库。 生成的FreeRTOS代码框架中包含了三个任务(task):任务A、任务B和任务C。每个任务的优先级从高到低分别为1、2和3。在main函数中,首先进行HAL库的初始化,然后创建三个任务,并启动调度程序。 任务A和任务B分别使用vTaskDelay函数实现1s的间隔,任务C则不停地输出信息。在任务A和任务B等待的过程中,FreeRTOS会让出CPU资源,把执行权交给其他任务。 在代码框架中还包含了一个定时器(Timer)和一个队列(Queue)。这些功能可以在任务之间进行通信和同步。例如,在任务A中使用Queue发送消息,在任务B中使用Queue接收消息。在任务C中使用定时器来定时输出信息。 总之,STM32CubeMXFreeRTOS的结合提供了一种方便、快速、高效的嵌入式软件开发方式。它可以帮助开发人员更好地了解STM32微控制器和FreeRTOS操作系统的功能和特性,提高开发效率和代码质量。 ### 回答3: STM32CubeMXSTM32系列芯片的一款图形化配置工具,可以快速生成基于HAL库的项目代码。而FreeRTOS是一款实时操作系统,在嵌入式系统应用中得到广泛应用。本文主要围绕STM32CubeMXFreeRTOS的组合应用教程进行阐述。 在使用STM32CubeMX生成工程时,可以在中间的软件栏中勾选FreeRTOS。此时,代码将自动生成FreeRTOS的头文件和源文件以及部分配置文件。需要注意的是,FreeRTOS的版本也可以在中间的软件栏中进行选择。选择完成后,可以对FreeRTOS进行进一步的配置,包括任务数量、栈空间大小、时间片轮询优先级等。这些配置都可以在头文件中手动修改,但使用STM32CubeMX可以大大节省时间。 在生成工程后,需要在主函数中添加创建FreeRTOS任务的代码,这部分的代码可以在头文件中找到。上手难度较低,基本相当于“复制粘贴”。通过FreeRTOS,可以很方便地创建多个任务,并对它们进行优先级调度,达到开发设计需求。 需要注意的是,FreeRTOS的使用需要一定的操作系统知识,例如任务调度、信号量等概念。建议在学习使用FreeRTOS前,先对操作系统有一定程度的了解。同时,FreeRTOS的使用还需要注意堆栈空间、资源抢占等问题。如果不妥善处理这些问题,会导致系统死锁、运行错误等问题。 总之,使用STM32CubeMXFreeRTOS,可以大大提高嵌入式系统应用的开发效率,是一款非常实用的工具和操作系统。但是,在使用前需要了解一些必要的操作系统知识,并正确处理堆栈空间、资源抢占等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

chem4111

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值