OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 3353|回复: 6

关于电容触摸按键的问题

[复制链接]

8

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
85
金钱
85
注册时间
2016-7-14
在线时间
12 小时
发表于 2016-7-22 12:02:30 | 显示全部楼层 |阅读模式
1金钱
大神们好
根据STM32精英版的电路图,电容触摸时的电路应该是如图所示。
所以,输入捕获应该是捕获下降沿,但为什么官方例程中是捕获上升沿呢?
谢谢

电路图

电路图

最佳答案

查看完整内容[请看2#楼]

就是捕获充电这段时间来的。。。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2016-7-22 12:02:31 | 显示全部楼层
就是捕获充电这段时间来的。。。
回复

使用道具 举报

8

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
85
金钱
85
注册时间
2016-7-14
在线时间
12 小时
 楼主| 发表于 2016-7-22 12:05:40 | 显示全部楼层
.......
无标题.png
回复

使用道具 举报

8

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
85
金钱
85
注册时间
2016-7-14
在线时间
12 小时
 楼主| 发表于 2016-7-22 12:06:45 | 显示全部楼层
本帖最后由 dream顺 于 2016-7-22 12:08 编辑

[mw_shl_code=c,true]#include "tpad.h"
#include "delay.h"                    
#include "usart.h"

#define TPAD_ARR_MAX_VAL         0XFFFF        //最大的ARR值
vu16 tpad_default_val=0;//空载的时候(没有手按下),计数器需要的时间


//初始化触摸按键
//获得空载的时候触摸按键的取值.
//返回值:0,初始化成功;1,初始化失败
u8 TPAD_Init(u8 psc)
{
        u16 buf[10];
        u16 temp;
        u8 j,i;
        TIM5_CH2_Cap_Init(TPAD_ARR_MAX_VAL,psc-1);//以1Mhz的频率计数
        for(i=0;i<10;i++)//连续读取10次
        {                                 
                buf=TPAD_Get_Val();
                delay_ms(10);            
        }                                    
        for(i=0;i<9;i++)//排序
        {
                for(j=i+1;j<10;j++)
                {
                        if(buf>buf[j])//升序排列
                        {
                                temp=buf;
                                buf=buf[j];
                                buf[j]=temp;
                        }
                }
        }
        temp=0;
        for(i=2;i<8;i++)temp+=buf;//取中间的6个数据进行平均
        tpad_default_val=temp/6;
        printf("tpad_default_val:%d\r\n",tpad_default_val);       
        if(tpad_default_val>TPAD_ARR_MAX_VAL/2)return 1;//初始化遇到超过TPAD_ARR_MAX_VAL/2的数值,不正常!
        return 0;                                                                           
}
//复位一次
void TPAD_Reset(void)
{
          GPIO_InitTypeDef  GPIO_InitStructure;
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);         //使能PA端口时钟
       
        //设置GPIOA.1为推挽使出
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;                                 //PA1 端口配置
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                  //推挽输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_InitStructure);
        GPIO_ResetBits(GPIOA,GPIO_Pin_1);                                                 //PA.1输出0,放电

        delay_ms(5);

        TIM_SetCounter(TIM5,0);                //归0
        TIM_ClearITPendingBit(TIM5, TIM_IT_CC2|TIM_IT_Update); //清除中断标志
        //设置GPIOA.1为浮空输入
        GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;         //浮空输入
        GPIO_Init(GPIOA, &GPIO_InitStructure);

   
}
//得到定时器捕获值
//如果超时,则直接返回定时器的计数值.
u16 TPAD_Get_Val(void)
{                                  
        TPAD_Reset();
        while(TIM_GetFlagStatus(TIM5, TIM_IT_CC2) == RESET)//等待捕获上升沿
        {
                if(TIM_GetCounter(TIM5)>TPAD_ARR_MAX_VAL-500)return TIM_GetCounter(TIM5);//超时了,直接返回CNT的值
        };       
        return TIM_GetCapture2(TIM5);          
}          
//读取n次,取最大值
//n:连续获取的次数
//返回值:n次读数里面读到的最大读数值
u16 TPAD_Get_MaxVal(u8 n)
{
        u16 temp=0;
        u16 res=0;
        while(n--)
        {
                temp=TPAD_Get_Val();//得到一次值
                if(temp>res)res=temp;
        };
        return res;
}  
//扫描触摸按键
//mode:0,不支持连续触发(按下一次必须松开才能按下一次);1,支持连续触发(可以一直按下)
//返回值:0,没有按下;1,有按下;                                                                                  
#define TPAD_GATE_VAL         100        //触摸的门限值,也就是必须大于tpad_default_val+TPAD_GATE_VAL,才认为是有效触摸.
u8 TPAD_Scan(u8 mode)
{
        static u8 keyen=0;        //0,可以开始检测;>0,还不能开始检测         
        u8 res=0;
        u8 sample=3;                //默认采样次数为3次         
        u16 rval;
        if(mode)
        {
                sample=6;                //支持连按的时候,设置采样次数为6次
                keyen=0;                //支持连按          
        }
        rval=TPAD_Get_MaxVal(sample);
        if(rval>(tpad_default_val+TPAD_GATE_VAL))//大于tpad_default_val+TPAD_GATE_VAL,有效
        {                                                         
                if(keyen==0)res=1;                //keyen==0,有效
                //printf("r:%d\r\n",rval);                                                                           
                keyen=3;                                //至少要再过3次之后才能按键有效   
        }
        if(keyen)keyen--;                                                                                                                                                         
        return res;
}       
//定时器2通道2输入捕获配置
void TIM5_CH2_Cap_Init(u16 arr,u16 psc)
{
        GPIO_InitTypeDef  GPIO_InitStructure;
           TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
        TIM_ICInitTypeDef  TIM5_ICInitStructure;

        RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM5, ENABLE);         //使能TIM5时钟
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);         //使能PA端口时钟
        //设置GPIOA.1为浮空输入
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_1;                                 //PA1 端口配置
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;        //速度50MHz
           GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING;         //浮空输入
        GPIO_Init(GPIOA, &GPIO_InitStructure);         //设置为浮空输入

           //初始化TIM5  
        TIM_TimeBaseStructure.TIM_Period = arr; //设定计数器自动重装值   
        TIM_TimeBaseStructure.TIM_Prescaler =psc;         //预分频器           
        TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割:TDTS = Tck_tim
        TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIM向上计数模式
        TIM_TimeBaseInit(TIM5, &TIM_TimeBaseStructure); //根据TIM_TimeBaseInitStruct中指定的参数初始化TIMx的时间基数单位
        //初始化通道2
          TIM5_ICInitStructure.TIM_Channel = TIM_Channel_2; //CC1S=01         选择输入端 IC2映射到TI5上
          TIM5_ICInitStructure.TIM_ICPolarity = TIM_ICPolarity_Rising;        //上升沿捕获
          TIM5_ICInitStructure.TIM_ICSelection = TIM_ICSelection_DirectTI;
          TIM5_ICInitStructure.TIM_ICPrescaler = TIM_ICPSC_DIV1;         //配置输入分频,不分频
          TIM5_ICInitStructure.TIM_ICFilter = 0x03;//IC2F=0011 配置输入滤波器 8个定时器时钟周期滤波
          TIM_ICInit(TIM5, &TIM5_ICInitStructure);//初始化I5 IC2

    TIM_Cmd(TIM5,ENABLE );         //使能定时器5
}












[/mw_shl_code]
回复

使用道具 举报

8

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
85
金钱
85
注册时间
2016-7-14
在线时间
12 小时
 楼主| 发表于 2016-7-22 12:17:29 | 显示全部楼层
貌似是电路理解有点错误,但不知道错在哪里
回复

使用道具 举报

8

主题

24

帖子

0

精华

初级会员

Rank: 2

积分
85
金钱
85
注册时间
2016-7-14
在线时间
12 小时
 楼主| 发表于 2016-7-22 18:37:34 | 显示全部楼层
顶一下
回复

使用道具 举报

6

主题

104

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
436
金钱
436
注册时间
2015-12-11
在线时间
53 小时
发表于 2016-8-5 21:03:30 | 显示全部楼层
这段代码是哪个实验里面的?我的V3战舰电容触摸屏代码里面好像没有这个函数啊,求指点
Try again and there is nothing left to say.
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-1 20:44

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表