C - Arduino - 无法将 'uint8_t*' 转换为 'uint16_t*'
C - Arduino - cannot convert 'uint8_t*' to 'uint16_t*'
我对 C / Arduino 还很陌生
我正在努力简化我的代码,以便在编写循环时只需要一个函数。
该代码用于 SPI LCD 显示器,我有两个代码想合并为一个,第一个代码是将 32 个字符的 txt 写入屏幕,从数组中选取 32 个字符 - 这很完美
void writeLCD(char LcdText[33]){
unsigned char TextRow, CharacterRow, TextColumn, CharNum ;
unsigned int InPointerString ;
InPointerString = 1 ;
SPI.transfer(0x48) ;
SPI.transfer(0);SPI.transfer(0);SPI.transfer(0);
for(TextColumn = 8 ; TextColumn > 0 ; TextColumn--){
for(CharacterRow = 8 ; CharacterRow > 0 ; CharacterRow --){
for(TextRow = 0 ; TextRow < 4; TextRow++){
CharNum = LcdText[TextRow*8 + TextColumn-1] ;
if(CharNum > 0x7F){
SPI.transfer(Font8x8[(CharNum-0x80)*8 + CharacterRow - 1] & 0x0F ) ;
SPI.transfer(((Font8x8[(CharNum-0x80)*8 + CharacterRow - 1] & 0xF0) >> 4) & 0x0f ) ;
} else {
SPI.transfer(Font8x8[CharNum*8 + CharacterRow - 1] & 0x0F ) ;
SPI.transfer(((Font8x8[CharNum*8 + CharacterRow - 1] & 0xF0) >> 4) & 0x0f ) ;
}
}
}
}
SPI.transfer(0x43) ;
delay(1);
}
第二个代码是从数组中选取 512 个字节并将图像写入屏幕 - 这非常有效
// Data is a pointer to 512 bytes of image data to display
void BMP(uint16_t * data){
uint16_t i;
SPI.transfer(0x49); // Start Bitmap CMD
for (i=0; i<512; i++){
SPI.transfer(data[i]);
} // Send BMP Array
SPI.transfer(0x43); // End Bitmap CMD
delay(1); // wait 1ms
}
目前数组存储在单独的库中以使生活更轻松 BMPlibrary 和 TXTlibrary
只是为了向大家确认 - 两个代码都可以独立完美地工作
我想出了下面的代码将两者合二为一,使用 if 语句根据数组的大小决定如何处理数组,如果它小 = 写 txt,如果它大 = 写图像。
下面的代码适用于 BMP 但无法编译,因为
void LCD(char RGBXXX, uint16_t str[]){
RGB(RGBXXX);
if(sizeof(str) > 33){
char data[33];
memcpy(data,(uint8_t*)str,33);
writeLCD(data);
}
else {
BMP(str);
}
}
但是我现在遇到的问题是,在声明类型转换时,如果我将其设置为 uint8_t,那么代码的 txt 部分可以正常工作,但图像代码不会,
cannot convert 'uint8_t*' to 'uint16_t*' for argument '2' to 'void LCD(char, uint16_t*)'
如果我设置为 uint16_t 图像可以正常工作,但 txt 不行!
我不指望慈善机构只是提供一点帮助来找出我哪里出错了,我们将不胜感激!我花了几个小时来找出为什么图像一开始不起作用,直到我意识到它与字节大小有关,但现在我无法弄清楚如何将两者结合起来!
void* 将解决您的转换问题
指针的大小永远不会 > 33
所以试试这个:
void LCD(char RGBXXX, void *str, int is_data) {
RGB(RGBXXX);
if (is_data != 0) {
char data[33];
memcpy(data,(uint8_t*)str,33);
writeLCD(data);
}
else {
BMP((uint16_t *)str);
}
}
我对 C / Arduino 还很陌生
我正在努力简化我的代码,以便在编写循环时只需要一个函数。
该代码用于 SPI LCD 显示器,我有两个代码想合并为一个,第一个代码是将 32 个字符的 txt 写入屏幕,从数组中选取 32 个字符 - 这很完美
void writeLCD(char LcdText[33]){
unsigned char TextRow, CharacterRow, TextColumn, CharNum ;
unsigned int InPointerString ;
InPointerString = 1 ;
SPI.transfer(0x48) ;
SPI.transfer(0);SPI.transfer(0);SPI.transfer(0);
for(TextColumn = 8 ; TextColumn > 0 ; TextColumn--){
for(CharacterRow = 8 ; CharacterRow > 0 ; CharacterRow --){
for(TextRow = 0 ; TextRow < 4; TextRow++){
CharNum = LcdText[TextRow*8 + TextColumn-1] ;
if(CharNum > 0x7F){
SPI.transfer(Font8x8[(CharNum-0x80)*8 + CharacterRow - 1] & 0x0F ) ;
SPI.transfer(((Font8x8[(CharNum-0x80)*8 + CharacterRow - 1] & 0xF0) >> 4) & 0x0f ) ;
} else {
SPI.transfer(Font8x8[CharNum*8 + CharacterRow - 1] & 0x0F ) ;
SPI.transfer(((Font8x8[CharNum*8 + CharacterRow - 1] & 0xF0) >> 4) & 0x0f ) ;
}
}
}
}
SPI.transfer(0x43) ;
delay(1);
}
第二个代码是从数组中选取 512 个字节并将图像写入屏幕 - 这非常有效
// Data is a pointer to 512 bytes of image data to display
void BMP(uint16_t * data){
uint16_t i;
SPI.transfer(0x49); // Start Bitmap CMD
for (i=0; i<512; i++){
SPI.transfer(data[i]);
} // Send BMP Array
SPI.transfer(0x43); // End Bitmap CMD
delay(1); // wait 1ms
}
目前数组存储在单独的库中以使生活更轻松 BMPlibrary 和 TXTlibrary
只是为了向大家确认 - 两个代码都可以独立完美地工作
我想出了下面的代码将两者合二为一,使用 if 语句根据数组的大小决定如何处理数组,如果它小 = 写 txt,如果它大 = 写图像。 下面的代码适用于 BMP 但无法编译,因为
void LCD(char RGBXXX, uint16_t str[]){
RGB(RGBXXX);
if(sizeof(str) > 33){
char data[33];
memcpy(data,(uint8_t*)str,33);
writeLCD(data);
}
else {
BMP(str);
}
}
但是我现在遇到的问题是,在声明类型转换时,如果我将其设置为 uint8_t,那么代码的 txt 部分可以正常工作,但图像代码不会,
cannot convert 'uint8_t*' to 'uint16_t*' for argument '2' to 'void LCD(char, uint16_t*)'
如果我设置为 uint16_t 图像可以正常工作,但 txt 不行!
我不指望慈善机构只是提供一点帮助来找出我哪里出错了,我们将不胜感激!我花了几个小时来找出为什么图像一开始不起作用,直到我意识到它与字节大小有关,但现在我无法弄清楚如何将两者结合起来!
void* 将解决您的转换问题 指针的大小永远不会 > 33 所以试试这个:
void LCD(char RGBXXX, void *str, int is_data) {
RGB(RGBXXX);
if (is_data != 0) {
char data[33];
memcpy(data,(uint8_t*)str,33);
writeLCD(data);
}
else {
BMP((uint16_t *)str);
}
}