设计电路的时候犯了一个错,然后换了一种方式控制数码管

原创 面包板社区 2023-04-28 20:09

近期搞了个单板,客户定制的,核心ST的MCU。熟悉又陌生的东西啊,依稀记得那时候自己还是个年轻小伙。功能简单,花了一天的时间把原理图和PCB搞完就投产了。等待几天PCB回来了,在等待几天PCBA也回来了。准备调试。


嗯。调那个呢?功能要求有数码管,要不先搞点东西显示下。


找到以前的DEMO,改改引脚,应该很快。这样想着。结果上天不做美啊。DEMO上数码管段选脚是放在同一GPIO的,而我的,七零八落的,哎。这可咋办?


思索良久之后,是不是可以通过将段码值通过移位赋值的方式直接将相应值直接给GPIO呢


共阳极段码表是这个


unsigned char LEDSEG[] ={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0xFF};

如果可以像这样给段码赋值就好了


SMG_A=((LEDSEG[要显示的数字]>>0)&0x01);SMG_B=((LEDSEG[要显示的数字]>>1)&0x01);SMG_C=((LEDSEG[要显示的数字]>>2)&0x01);SMG_D=((LEDSEG[要显示的数字]>>3)&0x01);SMG_E=((LEDSEG[要显示的数字]>>4)&0x01);SMG_F=((LEDSEG[要显示的数字]>>5)&0x01);SMG_G=((LEDSEG[要显示的数字]>>6)&0x01);


思路有了,接下来就是看看ST库里面有木有像51单片机那样可以直接给个引脚赋值就能控制高低电平的源码了,搜索良久,发现并没有,要不只能通过GPIO_SetBits或者GPIO_ResetBits控制单个GPIO,要不WRITE_DATA控制一组引脚。


哎,我又沉思了,后来网上找一遍,结果还真找到了


#define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))#define MEM_ADDR(addr) *((volatile unsigned long *)(addr))#define BIT_ADDR(addr, bitnum) MEM_ADDR( BITBAND(addr, bitnum) )#define GPIOA_ODR_Addr (GPIOA_BASE+12) //0x4001080C#define GPIOB_ODR_Addr (GPIOB_BASE+12) //0x40010C0C#define GPIOC_ODR_Addr (GPIOC_BASE+12) //0x4001100C#define GPIOD_ODR_Addr (GPIOD_BASE+12) //0x4001140C#define GPIOE_ODR_Addr (GPIOE_BASE+12) //0x4001180C#define GPIOA_IDR_Addr (GPIOA_BASE+8) //0x40010808#define GPIOB_IDR_Addr (GPIOB_BASE+8) //0x40010C08#define GPIOC_IDR_Addr (GPIOC_BASE+8) //0x40011008#define GPIOD_IDR_Addr (GPIOD_BASE+8) //0x40011408#define GPIOE_IDR_Addr (GPIOE_BASE+8) //0x40011808//-----------------------------------------------------#define PA0 BIT_ADDR(GPIOA_ODR_Addr, 0) //输出#define PA1 BIT_ADDR(GPIOA_ODR_Addr, 1) //输出#define PA2 BIT_ADDR(GPIOA_ODR_Addr, 2) //输出#define PA3 BIT_ADDR(GPIOA_ODR_Addr, 3) //输出#define PA4 BIT_ADDR(GPIOA_ODR_Addr, 4) //输出#define PA5 BIT_ADDR(GPIOA_ODR_Addr, 5) //输出#define PA6 BIT_ADDR(GPIOA_ODR_Addr, 6) //输出#define PA7 BIT_ADDR(GPIOA_ODR_Addr, 7) //输出#define PA8 BIT_ADDR(GPIOA_ODR_Addr, 8) //输出#define PA9 BIT_ADDR(GPIOA_ODR_Addr, 9) //输出#define PA10 BIT_ADDR(GPIOA_ODR_Addr, 10) //输出#define PA11 BIT_ADDR(GPIOA_ODR_Addr, 11) //输出#define PA12 BIT_ADDR(GPIOA_ODR_Addr, 12) //输出#define PA13 BIT_ADDR(GPIOA_ODR_Addr, 13) //输出#define PA14 BIT_ADDR(GPIOA_ODR_Addr, 14) //输出#define PA15 BIT_ADDR(GPIOA_ODR_Addr, 15) //输出#define PA0in BIT_ADDR(GPIOA_IDR_Addr, 0) //??#define PA1in BIT_ADDR(GPIOA_IDR_Addr, 1) //??#define PA2in BIT_ADDR(GPIOA_IDR_Addr, 2) //??#define PA3in BIT_ADDR(GPIOA_IDR_Addr, 3) //??#define PA4in BIT_ADDR(GPIOA_IDR_Addr, 4) //??#define PA5in BIT_ADDR(GPIOA_IDR_Addr, 5) //??#define PA6in BIT_ADDR(GPIOA_IDR_Addr, 6) //??#define PA7in BIT_ADDR(GPIOA_IDR_Addr, 7) //??#define PA8in BIT_ADDR(GPIOA_IDR_Addr, 8) //??#define PA9in BIT_ADDR(GPIOA_IDR_Addr, 9) //??#define PA10in BIT_ADDR(GPIOA_IDR_Addr, 10) //??#define PA11in BIT_ADDR(GPIOA_IDR_Addr, 11) //??#define PA12in BIT_ADDR(GPIOA_IDR_Addr, 12) //??#define PA13in BIT_ADDR(GPIOA_IDR_Addr, 13) //??#define PA14in BIT_ADDR(GPIOA_IDR_Addr, 14) //??#define PA15in BIT_ADDR(GPIOA_IDR_Addr, 15) //??//-----------------------------------------------------#define PB0 BIT_ADDR(GPIOB_ODR_Addr, 0) //输出#define PB1 BIT_ADDR(GPIOB_ODR_Addr, 1) //输出#define PB2 BIT_ADDR(GPIOB_ODR_Addr, 2) //输出#define PB3 BIT_ADDR(GPIOB_ODR_Addr, 3) //输出#define PB4 BIT_ADDR(GPIOB_ODR_Addr, 4) //输出#define PB5 BIT_ADDR(GPIOB_ODR_Addr, 5) //输出#define PB6 BIT_ADDR(GPIOB_ODR_Addr, 6) //输出#define PB7 BIT_ADDR(GPIOB_ODR_Addr, 7) //输出#define PB8 BIT_ADDR(GPIOB_ODR_Addr, 8) //输出#define PB9 BIT_ADDR(GPIOB_ODR_Addr, 9) //输出#define PB10 BIT_ADDR(GPIOB_ODR_Addr, 10) //输出#define PB11 BIT_ADDR(GPIOB_ODR_Addr, 11) //输出#define PB12 BIT_ADDR(GPIOB_ODR_Addr, 12) //输出#define PB13 BIT_ADDR(GPIOB_ODR_Addr, 13) //输出#define PB14 BIT_ADDR(GPIOB_ODR_Addr, 14) //输出#define PB15 BIT_ADDR(GPIOB_ODR_Addr, 15) //输出#define PB0in BIT_ADDR(GPIOB_IDR_Addr, 0) //??#define PB1in BIT_ADDR(GPIOB_IDR_Addr, 1) //??#define PB2in BIT_ADDR(GPIOB_IDR_Addr, 2) //??#define PB3in BIT_ADDR(GPIOB_IDR_Addr, 3) //??#define PB4in BIT_ADDR(GPIOB_IDR_Addr, 4) //??#define PB5in BIT_ADDR(GPIOB_IDR_Addr, 5) //??#define PB6in BIT_ADDR(GPIOB_IDR_Addr, 6) //??#define PB7in BIT_ADDR(GPIOB_IDR_Addr, 7) //??#define PB8in BIT_ADDR(GPIOB_IDR_Addr, 8) //??#define PB9in BIT_ADDR(GPIOB_IDR_Addr, 9) //??#define PB10in BIT_ADDR(GPIOB_IDR_Addr, 10) //??#define PB11in BIT_ADDR(GPIOB_IDR_Addr, 11) //??#define PB12in BIT_ADDR(GPIOB_IDR_Addr, 12) //??#define PB13in BIT_ADDR(GPIOB_IDR_Addr, 13) //??#define PB14in BIT_ADDR(GPIOB_IDR_Addr, 14) //??#define PB15in BIT_ADDR(GPIOB_IDR_Addr, 15) //??//----------------------------------------------------#define PC0 BIT_ADDR(GPIOC_ODR_Addr, 0) //输出#define PC1 BIT_ADDR(GPIOC_ODR_Addr, 1) //输出#define PC2 BIT_ADDR(GPIOC_ODR_Addr, 2) //输出#define PC3 BIT_ADDR(GPIOC_ODR_Addr, 3) //输出#define PC4 BIT_ADDR(GPIOC_ODR_Addr, 4) //输出#define PC5 BIT_ADDR(GPIOC_ODR_Addr, 5) //输出#define PC6 BIT_ADDR(GPIOC_ODR_Addr, 6) //输出#define PC7 BIT_ADDR(GPIOC_ODR_Addr, 7) //输出#define PC8 BIT_ADDR(GPIOC_ODR_Addr, 8) //输出#define PC9 BIT_ADDR(GPIOC_ODR_Addr, 9) //输出#define PC10 BIT_ADDR(GPIOC_ODR_Addr, 10) //输出#define PC11 BIT_ADDR(GPIOC_ODR_Addr, 11) //输出#define PC12 BIT_ADDR(GPIOC_ODR_Addr, 12) //输出#define PC13 BIT_ADDR(GPIOC_ODR_Addr, 13) //输出#define PC14 BIT_ADDR(GPIOC_ODR_Addr, 14) //输出#define PC15 BIT_ADDR(GPIOC_ODR_Addr, 15) //输出#define PC0in BIT_ADDR(GPIOC_IDR_Addr, 0) //??#define PC1in BIT_ADDR(GPIOC_IDR_Addr, 1) //??#define PC2in BIT_ADDR(GPIOC_IDR_Addr, 2) //??#define PC3in BIT_ADDR(GPIOC_IDR_Addr, 3) //??#define PC4in BIT_ADDR(GPIOC_IDR_Addr, 4) //??#define PC5in BIT_ADDR(GPIOC_IDR_Addr, 5) //??#define PC6in BIT_ADDR(GPIOC_IDR_Addr, 6) //??#define PC7in BIT_ADDR(GPIOC_IDR_Addr, 7) //??#define PC8in BIT_ADDR(GPIOC_IDR_Addr, 8) //??#define PC9in BIT_ADDR(GPIOC_IDR_Addr, 9) //??#define PC10in BIT_ADDR(GPIOC_IDR_Addr, 10) //??#define PC11in BIT_ADDR(GPIOC_IDR_Addr, 11) //??#define PC12in BIT_ADDR(GPIOC_IDR_Addr, 12) //??#define PC13in BIT_ADDR(GPIOC_IDR_Addr, 13) //??#define PC14in BIT_ADDR(GPIOC_IDR_Addr, 14) //??#define PC15in BIT_ADDR(GPIOC_IDR_Addr, 15) //??//----------------------------------------------------#define PD0 BIT_ADDR(GPIOD_ODR_Addr, 0) //输出#define PD1 BIT_ADDR(GPIOD_ODR_Addr, 1) //输出#define PD2 BIT_ADDR(GPIOD_ODR_Addr, 2) //输出#define PD3 BIT_ADDR(GPIOD_ODR_Addr, 3) //输出#define PD4 BIT_ADDR(GPIOD_ODR_Addr, 4) //输出#define PD5 BIT_ADDR(GPIOD_ODR_Addr, 5) //输出#define PD6 BIT_ADDR(GPIOD_ODR_Addr, 6) //输出#define PD7 BIT_ADDR(GPIOD_ODR_Addr, 7) //输出#define PD8 BIT_ADDR(GPIOD_ODR_Addr, 8) //输出#define PD9 BIT_ADDR(GPIOD_ODR_Addr, 9) //输出#define PD10 BIT_ADDR(GPIOD_ODR_Addr, 10) //输出#define PD11 BIT_ADDR(GPIOD_ODR_Addr, 11) //输出#define PD12 BIT_ADDR(GPIOD_ODR_Addr, 12) //输出#define PD13 BIT_ADDR(GPIOD_ODR_Addr, 13) //输出#define PD14 BIT_ADDR(GPIOD_ODR_Addr, 14) //输出#define PD15 BIT_ADDR(GPIOD_ODR_Addr, 15) //输出#define PD0in BIT_ADDR(GPIOD_IDR_Addr, 0) //??#define PD1in BIT_ADDR(GPIOD_IDR_Addr, 1) //??#define PD2in BIT_ADDR(GPIOD_IDR_Addr, 2) //??#define PD3in BIT_ADDR(GPIOD_IDR_Addr, 3) //??#define PD4in BIT_ADDR(GPIOD_IDR_Addr, 4) //??#define PD5in BIT_ADDR(GPIOD_IDR_Addr, 5) //??#define PD6in BIT_ADDR(GPIOD_IDR_Addr, 6) //??#define PD7in BIT_ADDR(GPIOD_IDR_Addr, 7) //??#define PD8in BIT_ADDR(GPIOD_IDR_Addr, 8) //??#define PD9in BIT_ADDR(GPIOD_IDR_Addr, 9) //??#define PD10in BIT_ADDR(GPIOD_IDR_Addr, 10) //??#define PD11in BIT_ADDR(GPIOD_IDR_Addr, 11) //??#define PD12in BIT_ADDR(GPIOD_IDR_Addr, 12) //??#define PD13in BIT_ADDR(GPIOD_IDR_Addr, 13) //??#define PD14in BIT_ADDR(GPIOD_IDR_Addr, 14) //??#define PD15in BIT_ADDR(GPIOD_IDR_Addr, 15) //??//----------------------------------------------------#define PE0 BIT_ADDR(GPIOE_ODR_Addr, 0) //??#define PE1 BIT_ADDR(GPIOE_ODR_Addr, 1) //??#define PE2 BIT_ADDR(GPIOE_ODR_Addr, 2) //??#define PE3 BIT_ADDR(GPIOE_ODR_Addr, 3) //??#define PE4 BIT_ADDR(GPIOE_ODR_Addr, 4) //??#define PE5 BIT_ADDR(GPIOE_ODR_Addr, 5) //??#define PE6 BIT_ADDR(GPIOE_ODR_Addr, 6) //??#define PE7 BIT_ADDR(GPIOE_ODR_Addr, 7) //??#define PE8 BIT_ADDR(GPIOE_ODR_Addr, 8) //??#define PE9 BIT_ADDR(GPIOE_ODR_Addr, 9) //??#define PE10 BIT_ADDR(GPIOE_ODR_Addr, 10) //??#define PE11 BIT_ADDR(GPIOE_ODR_Addr, 11) //??#define PE12 BIT_ADDR(GPIOE_ODR_Addr, 12) //??#define PE13 BIT_ADDR(GPIOE_ODR_Addr, 13) //??#define PE14 BIT_ADDR(GPIOE_ODR_Addr, 14) //??#define PE15 BIT_ADDR(GPIOE_ODR_Addr, 15) //??#define PE0in BIT_ADDR(GPIOE_IDR_Addr, 0) //??#define PE1in BIT_ADDR(GPIOE_IDR_Addr, 1) //??#define PE2in BIT_ADDR(GPIOE_IDR_Addr, 2) //??#define PE3in BIT_ADDR(GPIOE_IDR_Addr, 3) //??#define PE4in BIT_ADDR(GPIOE_IDR_Addr, 4) //??#define PE5in BIT_ADDR(GPIOE_IDR_Addr, 5) //??#define PE6in BIT_ADDR(GPIOE_IDR_Addr, 6) //??#define PE7in BIT_ADDR(GPIOE_IDR_Addr, 7) //??#define PE8in BIT_ADDR(GPIOE_IDR_Addr, 8) //??#define PE9in BIT_ADDR(GPIOE_IDR_Addr, 9) //??#define PE10in BIT_ADDR(GPIOE_IDR_Addr, 10) //??#define PE11in BIT_ADDR(GPIOE_IDR_Addr, 11) //??#define PE12in BIT_ADDR(GPIOE_IDR_Addr, 12) //??#define PE13in BIT_ADDR(GPIOE_IDR_Addr, 13) //??#define PE14in BIT_ADDR(GPIOE_IDR_Addr, 14) //??#define PE15in BIT_ADDR(GPIOE_IDR_Addr, 15) //??

有木有一种豁然开朗的感觉,这时候才意识到自己基础知识得有多差了。


接下来数码管就可以好好玩了,不管硬件电路控制数码管的引脚是一组的还是乱七八糟的,我们都有一战之力了。


看了上面的源码,有些人就会有个疑问,只定义了此GPIO的输入输出,并没有指出输出的类型,如果是输入,也有很多属性没有赋值。其实不用考虑那么多,直接使用库函数啊


GPIO_InitTypeDef GPIO_InitStructure;p>RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB|RCC_APB2Periph_AFIO, ENABLE);GPIO_PinRemapConfig(GPIO_Remap_SWJ_JTAGDisable,ENABLE);GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4|GPIO_Pin_5|GPIO_Pin_12|GPIO_Pin_13|GPIO_Pin_14|GPIO_Pin_15|GPIO_Pin_0;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOB, &GPIO_InitStructure);RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_AFIO, ENABLE);GPIO_InitStructure.GPIO_Pin = GPIO_Pin_8|GPIO_Pin_9|GPIO_Pin_10;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &GPIO_InitStructure);


接下来就跟之前控制方式一样了,这里粘贴部分代码







作者:二月半
https://mbb.eet-china.com/blog/1862109-442215.html
本文为面包板社区原创文章,点击阅读原文,发表原创文章,获得丰厚奖励!





您可以分享的内容:

1. 设计过程中,遇到的PCB问题和解决思路

2. 与PCB相关的任何学习笔记、经验心得整理

3. 拆解或DIY过程中获得的PCB设计技巧

4. 日常收集的PCB相关技术文档,也可以的分享到这里!



活动奖品:

一等奖(两名):100元 现金打赏

二等奖(若干):50元 现金打赏

优秀奖(若干):20元 现金打赏

参与即得50E币奖励!

点击阅读原文,参加活动!

面包板社区 面包板社区——中国第一电子人社交平台 面包板社区是Aspencore旗下媒体,整合了电子工程专辑、电子技术设计、国际电子商情丰富资源。社区包括论坛、博客、问答,拥有超过250万注册用户,加入面包板社区,从菜鸟变大神,打造您的电子人脉社交圈!
评论
  • 戴上XR眼镜去“追龙”是种什么体验?2024年11月30日,由上海自然博物馆(上海科技馆分馆)与三湘印象联合出品、三湘印象旗下观印象艺术发展有限公司(下简称“观印象”)承制的《又见恐龙》XR嘉年华在上海自然博物馆重磅开幕。该体验项目将于12月1日正式对公众开放,持续至2025年3月30日。双向奔赴,恐龙IP撞上元宇宙不久前,上海市经济和信息化委员会等部门联合印发了《上海市超高清视听产业发展行动方案》,特别提到“支持博物馆、主题乐园等场所推动超高清视听技术应用,丰富线下文旅消费体验”。作为上海自然
    电子与消费 2024-11-30 22:03 86浏览
  • 光伏逆变器是一种高效的能量转换设备,它能够将光伏太阳能板(PV)产生的不稳定的直流电压转换成与市电频率同步的交流电。这种转换后的电能不仅可以回馈至商用输电网络,还能供独立电网系统使用。光伏逆变器在商业光伏储能电站和家庭独立储能系统等应用领域中得到了广泛的应用。光耦合器,以其高速信号传输、出色的共模抑制比以及单向信号传输和光电隔离的特性,在光伏逆变器中扮演着至关重要的角色。它确保了系统的安全隔离、干扰的有效隔离以及通信信号的精准传输。光耦合器的使用不仅提高了系统的稳定性和安全性,而且由于其低功耗的
    晶台光耦 2024-12-02 10:40 102浏览
  •         温度传感器的精度受哪些因素影响,要先看所用的温度传感器输出哪种信号,不同信号输出的温度传感器影响精度的因素也不同。        现在常用的温度传感器输出信号有以下几种:电阻信号、电流信号、电压信号、数字信号等。以输出电阻信号的温度传感器为例,还细分为正温度系数温度传感器和负温度系数温度传感器,常用的铂电阻PT100/1000温度传感器就是正温度系数,就是说随着温度的升高,输出的电阻值会增大。对于输出
    锦正茂科技 2024-12-03 11:50 66浏览
  • 概述 说明(三)探讨的是比较器一般带有滞回(Hysteresis)功能,为了解决输入信号转换速率不够的问题。前文还提到,即便使能滞回(Hysteresis)功能,还是无法解决SiPM读出测试系统需要解决的问题。本文在说明(三)的基础上,继续探讨为SiPM读出测试系统寻求合适的模拟脉冲检出方案。前四代SiPM使用的高速比较器指标缺陷 由于前端模拟信号属于典型的指数脉冲,所以下降沿转换速率(Slew Rate)过慢,导致比较器检出出现不必要的问题。尽管比较器可以使能滞回(Hysteresis)模块功
    coyoo 2024-12-03 12:20 70浏览
  • 遇到部分串口工具不支持1500000波特率,这时候就需要进行修改,本文以触觉智能RK3562开发板修改系统波特率为115200为例,介绍瑞芯微方案主板Linux修改系统串口波特率教程。温馨提示:瑞芯微方案主板/开发板串口波特率只支持115200或1500000。修改Loader打印波特率查看对应芯片的MINIALL.ini确定要修改的bin文件#查看对应芯片的MINIALL.ini cat rkbin/RKBOOT/RK3562MINIALL.ini修改uart baudrate参数修改以下目
    Industio_触觉智能 2024-12-03 11:28 41浏览
  • 当前,智能汽车产业迎来重大变局,随着人工智能、5G、大数据等新一代信息技术的迅猛发展,智能网联汽车正呈现强劲发展势头。11月26日,在2024紫光展锐全球合作伙伴大会汽车电子生态论坛上,紫光展锐与上汽海外出行联合发布搭载紫光展锐A7870的上汽海外MG量产车型,并发布A7710系列UWB数字钥匙解决方案平台,可应用于数字钥匙、活体检测、脚踢雷达、自动泊车等多种智能汽车场景。 联合发布量产车型,推动汽车智能化出海紫光展锐与上汽海外出行达成战略合作,联合发布搭载紫光展锐A7870的量产车型
    紫光展锐 2024-12-03 11:38 65浏览
  • RDDI-DAP错误通常与调试接口相关,特别是在使用CMSIS-DAP协议进行嵌入式系统开发时。以下是一些可能的原因和解决方法: 1. 硬件连接问题:     检查调试器(如ST-Link)与目标板之间的连接是否牢固。     确保所有必要的引脚都已正确连接,没有松动或短路。 2. 电源问题:     确保目标板和调试器都有足够的电源供应。     检查电源电压是否符合目标板的规格要求。 3. 固件问题: &n
    丙丁先生 2024-12-01 17:37 83浏览
  • 作为优秀工程师的你,已身经百战、阅板无数!请先醒醒,新的项目来了,这是一个既要、又要、还要的产品需求,ARM核心板中一个处理器怎么能实现这么丰富的外围接口?踌躇之际,你偶阅此文。于是,“潘多拉”的魔盒打开了!没错,USB资源就是你打开新世界得钥匙,它能做哪些扩展呢?1.1  USB扩网口通用ARM处理器大多带两路网口,如果项目中有多路网路接口的需求,一般会选择在主板外部加交换机/路由器。当然,出于成本考虑,也可以将Switch芯片集成到ARM核心板或底板上,如KSZ9897、
    万象奥科 2024-12-03 10:24 37浏览
  • 最近几年,新能源汽车愈发受到消费者的青睐,其销量也是一路走高。据中汽协公布的数据显示,2024年10月,新能源汽车产销分别完成146.3万辆和143万辆,同比分别增长48%和49.6%。而结合各家新能源车企所公布的销量数据来看,比亚迪再度夺得了销冠宝座,其10月新能源汽车销量达到了502657辆,同比增长66.53%。众所周知,比亚迪是新能源汽车领域的重要参与者,其一举一动向来为外界所关注。日前,比亚迪汽车旗下品牌方程豹汽车推出了新车方程豹豹8,该款车型一上市就迅速吸引了消费者的目光,成为SUV
    刘旷 2024-12-02 09:32 98浏览
  • 11-29学习笔记11-29学习笔记习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习笔记&记录学习习笔记&记学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&记录学习学习笔记&学习学习笔记&记录学习学习笔记&记录学习学习笔记&记
    youyeye 2024-12-02 23:58 51浏览
我要评论
0
点击右上角,分享到朋友圈 我知道啦
请使用浏览器分享功能 我知道啦