这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » DIY与开源设计 » 电子DIY » (LCD)emusic ARM DIY进程帖

共31条 3/4 1 2 3 4 跳转至
助工
2012-04-30 11:46:33     打赏
21楼

定时器查询实验:
    本实验以LED控制实验为基础,使用TIM2查询方式作为延时实现走马灯效果。本实验使用的是8MHz的晶振。使用官方3.5.0的库。
    TIM2的CK_INT时钟是APB1的倍频,除非APB1的时钟分频数设置为1.本实验APB1的时钟是HCLK/2 = 36Mhz,所以CK_INT的时钟频率为72Mhz。
TIM2初始化代码:
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
TIM_InitTypeDef.TIM_Prescaler = 7200;     //预分频 72Mhz/7200 = 10Khz  T = 0.1ms 
TIM_InitTypeDef.TIM_CounterMode = TIM_CounterMode_Up; //向上计数
TIM_InitTypeDef.TIM_Period = 5000;                     //自动重装载值 这里定时为  500ms
TIM_InitTypeDef.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_InitTypeDef.TIM_RepetitionCounter = 0;    //TIM1和TIM8使用
TIM_TimeBaseInit(TIM2, &TIM_InitTypeDef);
TIM_ClearFlag(TIM2, TIM_FLAG_Update);

使用方式:
 while(1)
 {
     GPIO_SetBits(GPIO_LED,DS1_PIN|DS2_PIN|DS3_PIN|DS4_PIN);
     Turn_On_LED(i);
     i++;
     if(i>3)
    {
        i = 0;
    }
    TIM_Cmd(TIM2, ENABLE);
    while(TIM_GetFlagStatus(TIM2, TIM_FLAG_Update)==RESET);
   TIM_ClearFlag(TIM2, TIM_FLAG_Update);
   TIM_Cmd(TIM2, DISABLE);
 }


助工
2012-04-30 11:54:06     打赏
22楼

定时器中断方式:
      基于定时器查询方式实验上,实现走马灯效果。
在TIM2初始化代码:
RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM2, ENABLE);
TIM_InitTypeDef.TIM_Prescaler = 7200;     
TIM_InitTypeDef.TIM_CounterMode = TIM_CounterMode_Up;
TIM_InitTypeDef.TIM_Period = 5000;                    
TIM_InitTypeDef.TIM_ClockDivision = TIM_CKD_DIV1;
TIM_InitTypeDef.TIM_RepetitionCounter = 0;    
TIM_TimeBaseInit(TIM2, &TIM_InitTypeDef);
TIM_ITConfig(TIM2, TIM_IT_Update, ENABLE);        //打开更新中断
TIM_ClearFlag(TIM2, TIM_FLAG_Update);
TIM_Cmd(TIM2, ENABLE);

中断控制器初始化:
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
NVIC_InitStructure.NVIC_IRQChannel = TIM2_IRQn; //中断通道
NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;//强占优先级
NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0; //次优先级
NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //通道中断使能
NVIC_Init(&NVIC_InitStructure);       //初始化中断


高工
2012-04-30 11:58:20     打赏
23楼
1ms太长了,那个18b20要求1us。我预分频设置成了71。你的7200也不对,应该是7199,只是时间长你看不出来

助工
2012-04-30 12:06:37     打赏
24楼
谢谢提醒。至于1ms嘛,是对这个实验做的不是针对18B20

助工
2012-04-30 12:12:48     打赏
25楼
上图

助工
2012-05-02 21:36:12     打赏
26楼

24C02读写实验:
      向24C02的00H到13H地址写入0x0~0x13,然后读出,通过串口输出到终端。
初始化代码:
 RCC_APB1PeriphClockCmd(RCC_APB1Periph_I2C1, ENABLE);
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
 GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_6; 
 GPIO_InitStructure.GPIO_Mode  = GPIO_Mode_AF_OD;     //复用开漏输出
 GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
 GPIO_Init(GPIOB, &GPIO_InitStructure);

 GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_7; 
 GPIO_InitStructure.GPIO_Mode  = GPIO_Mode_AF_OD;     //复用开漏输出
 GPIO_Init(GPIOB, &GPIO_InitStructure);

 GPIO_InitStructure.GPIO_Pin   = GPIO_Pin_5; 
 GPIO_InitStructure.GPIO_Mode  = GPIO_Mode_Out_PP;     //复用开漏输出
 GPIO_Init(GPIOB, &GPIO_InitStructure);
 GPIO_ResetBits(GPIOB,GPIO_Pin_5);
 I2C_DeInit(I2C1);
 I2C1_InitStruct.I2C_Mode = I2C_Mode_I2C;
 I2C1_InitStruct.I2C_DutyCycle = I2C_DutyCycle_2;
 I2C1_InitStruct.I2C_OwnAddress1 = 0x30;
 I2C1_InitStruct.I2C_Ack = I2C_Ack_Enable;
 I2C1_InitStruct.I2C_AcknowledgedAddress = I2C_AcknowledgedAddress_7bit;
 I2C1_InitStruct.I2C_ClockSpeed = 200000;
 I2C_Cmd(I2C1,ENABLE);
 I2C_Init(I2C1, &I2C1_InitStruct);
 I2C_AcknowledgeConfig(I2C1,ENABLE); 


高工
2012-05-02 23:15:54     打赏
27楼
LCD跟IIC有冲突??
把LCD初始化代码卡IIC掉就好了

助工
2012-05-03 00:46:43     打赏
28楼
这个我没有试,明天试试

高工
2012-05-03 00:55:58     打赏
29楼
PB7/I2C1_SDA/FSMC_NADV/TIM4_CH2

这是个是一个脚,FSMC_NADV估计在初始化FSMC的时候动了。
IIC初始化放到LCD初始化之前就没事了。

不过现在还有问题。IIC真麻烦

菜鸟
2012-05-13 10:59:57     打赏
30楼

学习


共31条 3/4 1 2 3 4 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]