OLED_ShowString(1, 1, "Speed:");这个函数在OLED屏幕上不能显示汉字吗
时间: 2023-06-10 19:08:41 浏览: 130
这个函数是用于在 OLED 屏幕上显示字符串的函数,可以显示 ASCII 字符集中的所有字符,包括英文字母、数字、特殊符号等等。但是,它并不支持直接显示汉字。
如果你想在 OLED 屏幕上显示汉字,需要使用专门的汉字库,或者自己编写汉字显示函数。一般来说,汉字库可以分为两种:点阵汉字库和矢量汉字库。
点阵汉字库是将每个汉字转化为一个点阵图形,可以直接在 OLED 屏幕上显示。但是,点阵汉字库的显示效果受到分辨率和字体大小的限制,显示出来的汉字可能会比较模糊。
矢量汉字库是将每个汉字转化为一组矢量图形,可以在任意分辨率的屏幕上显示,并且可以随意调整字体大小。但是,矢量汉字库的处理复杂度比较高,需要较强的处理能力和较大的存储空间。
如果你使用的是点阵汉字库,可以编写一个函数来将汉字转化为点阵图形,并调用 OLED_ShowString 函数将其显示在 OLED 屏幕上。如果你使用的是矢量汉字库,可以编写一个函数来将汉字转化为矢量图形,并调用 OLED_DrawLine 函数将其显示在 OLED 屏幕上。
相关问题
#include "stm32f10x.h" // Device header #include "Delay.h" #include "OLED.h" #include "Key.h" #include "Motor.h" uint8_t KeyNum; int8_t Speed; int main(void) { OLED_Init(); Motor_Init(); Key_Init(); //Motor_SetSpeed(1); OLED_ShowString(1,1,"Speed:"); while(1) { KeyNum = Key_GetNum(); if(KeyNum == 1) { Speed += 50; if(Speed > 100) { Speed = -100; } } Motor_SetSpeed(Speed); OLED_ShowSignedNum(1,7,Speed,3); } }
根据你提供的代码,我看到你使用了一个名为Motor_SetSpeed()的函数来设置电机的速度。你还使用OLED显示屏来显示速度值。
在主循环中,你先调用Key_GetNum()函数获取按键值,然后判断如果按键值为1(可能是你定义的某个按键),则将Speed增加50。如果Speed超过了100,将其设置为-100。
接下来,你调用Motor_SetSpeed(Speed)函数来设置电机的速度,传入的参数是Speed变量的值。最后,使用OLED_ShowSignedNum()函数在OLED显示屏上显示Speed的数值。
根据这段代码,当按下按键1时,Speed的值会逐步增加50,并且在达到100后循环重置为-100。Motor_SetSpeed()函数会根据Speed的值来控制电机的速度。请确保Motor_Init()函数正确初始化了电机和相关引脚。
需要注意的是,这段代码只实现了速度的控制,并没有具体实现转向功能。要实现转向,你可能需要使用两个电机分别控制左右轮,并根据需要控制它们的旋转方向和速度来实现不同的转向动作。具体实现细节可能需要根据你使用的硬件和电路配置进行调整。
float speed; int main(void) { Breath_Init (); KEY_InitU(); OLED_Init(); Motor_init(); OLED_ShowString(1,1,"Rspeed:"); while (1) { Motor_derection(20); } } #include "stm32f10x.h" // Device header void Breath_Init () { RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE); RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2,ENABLE); GPIO_InitTypeDef GPIO_Initstucture; GPIO_Initstucture.GPIO_Mode=GPIO_Mode_AF_PP;//复用推挽 GPIO_Initstucture.GPIO_Pin=GPIO_Pin_0; GPIO_Initstucture.GPIO_Speed=GPIO_Speed_50MHz; GPIO_Init(GPIOA,&GPIO_Initstucture); TIM_InternalClockConfig(TIM2); TIM_TimeBaseInitTypeDef TIM_TimeBaseInitstucture; TIM_TimeBaseInitstucture.TIM_ClockDivision=TIM_CKD_DIV1; TIM_TimeBaseInitstucture.TIM_CounterMode=TIM_CounterMode_Up; TIM_TimeBaseInitstucture.TIM_Period=100-1;//72M/TIM_Period为频率也是ARR TIM_TimeBaseInitstucture.TIM_Prescaler=72-1;//分频也是PSC TIM_TimeBaseInitstucture.TIM_RepetitionCounter=0;//周期数 TIM_TimeBaseInit(TIM2,&TIM_TimeBaseInitstucture); TIM_OCInitTypeDef TIM_OCInitstructure; TIM_OCStructInit(&TIM_OCInitstructure); TIM_OCInitstructure.TIM_OCMode=TIM_OCMode_PWM1; TIM_OCInitstructure.TIM_OCPolarity=TIM_OCPolarity_High; TIM_OCInitstructure.TIM_OutputState=TIM_OutputState_Enable; TIM_OCInitstructure.TIM_Pulse=0;//CCR TIM_OC1Init(TIM2,&TIM_OCInitstructure); TIM_Cmd(TIM2,ENABLE); } void TIM_Compare(uint16_t compare) { TIM_SetCompare1(TIM2,compare); } void KEY_InitD (void)//下拉 { //GPIOB初始化 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE); GPIO_InitTypeDef GPIO_Initstructure; GPIO_Initstructure.GPIO_Mode =GPIO_Mode_IPD ; GPIO_Initstructure.GPIO_Pin = GPIO_Pin_0|GPIO_Pin_1; GPIO_Initstructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOB,&GPIO_Initstructure); } void KEY_InitU (void)//上拉 { //GPIOB初始化 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB,ENABLE); GPIO_InitTypeDef GPIO_Initstructure; GPIO_Initstructure.GPIO_Mode =GPIO_Mode_IPU ; GPIO_Initstructure.GPIO_Pin = GPIO_Pin_1; GPIO_Initstructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_Init(GPIOB,&GPIO_Initstructure); } uint16_t Key_GetNum () { uint8_t KeyNum = 0; if (GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_1) == 0) { Delay_ms(20); while (GPIO_ReadInputDataBit(GPIOB, GPIO_Pin_1) == 0); Delay_ms(20); KeyNum = 1; } } void Motor_init () { RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE); GPIO_InitTypeDef GPIO_InitStructure; GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4|GPIO_Pin_5; GPIO_Init(GPIOA, &GPIO_InitStructure); } void Motor_derection (float speed) { if(speed>0) { GPIO_SetBits(GPIOA,GPIO_Pin_4);//in1 GPIO_ResetBits(GPIOA,GPIO_Pin_5);//in2 TIM_Compare(speed); } else GPIO_ResetBits(GPIOA,GPIO_Pin_4);//in1 GPIO_SetBits(GPIOA,GPIO_Pin_5);//in2 TIM_Compare(-speed); } 为什么直流电机不转
根据给出的代码,直流电机不转的可能原因有以下几点:
1. 未正确初始化引脚:在`Motor_init()`函数中,需要将GPIOA的引脚4和5初始化为输入上拉模式。但是,在给出的代码中,并没有调用`Motor_init()`函数进行引脚的初始化。因此,需要在`main()`函数中添加`Motor_init()`函数的调用。
2. 未设置合适的方向和速度:在`Motor_derection()`函数中,根据`speed`的正负来设置电机的方向以及使用`TIM_Compare()`函数设置PWM的占空比。需要确保`speed`的值是正确设置且适合驱动电机的范围。
3. 未启动定时器:在`Breath_Init()`函数中,需要使用`TIM_Cmd(TIM2,ENABLE);`启动定时器2。但是,在给出的代码中,并没有调用该函数来启动定时器。因此,需要在`main()`函数中添加该函数的调用。
如果以上问题都已解决,并且硬件连接正确,但直流电机仍然不转动,则可能是其他硬件或电路问题。需要仔细检查硬件连接、电源供应等方面的问题。
阅读全文