#if (CTSU_TARGET_VALUE_CONFIG_SUPPORT == 1) .tuning_self_target_value = 15360, .tuning_mutual_target_value = 10240,
时间: 2024-05-26 19:16:35 浏览: 79
根据代码,这段是在设置CTSU的目标值配置。其中,tuning_self_target_value是自电容的目标值,tuning_mutual_target_value是互电容的目标值。它们的单位为电容计数值,是根据硬件设计和实际测试得出的最佳值。一般情况下,自电容的目标值应该比互电容的目标值高一些,这是因为自电容的信号强度比互电容的强。
相关问题
仔细分析这一段 /* initialize touch number and corrdinate */ *(p_instance_ctrl->pinfo.p_num_touch) = 0; *(p_instance_ctrl->pinfo.p_rx_coordinate) = TOUCH_OFF_VALUE; *(p_instance_ctrl->pinfo.p_tx_coordinate) = TOUCH_OFF_VALUE; /* Get local variable (TS number & data pinch) */ num_x = p_instance_ctrl->p_touch_cfg->p_ctsu_instance->p_cfg->num_rx; TOUCH_ERROR_RETURN(0 != num_x, FSP_ERR_ASSERTION); num_y = p_instance_ctrl->p_touch_cfg->p_ctsu_instance->p_cfg->num_tx; TOUCH_ERROR_RETURN(0 != num_y, FSP_ERR_ASSERTION); element_num = (uint16_t) (num_x * num_y); /* Data get */ err = p_instance_ctrl->p_ctsu_instance->p_api->dataGet(p_instance_ctrl->p_ctsu_instance->p_ctrl, g_touch_pad_buf); FSP_ERROR_RETURN(FSP_ERR_CTSU_SCANNING != err, FSP_ERR_CTSU_SCANNING); /* check for max touch */ if (*(p_instance_ctrl->pinfo.p_max_touch) > TOUCH_PAD_MONITOR_TOUCH_NUM_MAX) { max_touch = TOUCH_PAD_MONITOR_TOUCH_NUM_MAX; } else { max_touch = *(p_instance_ctrl->pinfo.p_max_touch); } /* make difference value = secondary - primary */ for (i = 0; i < element_num; i++) { /* save to buffer in the first half */ g_touch_pad_buf[i] = (uint16_t) (g_touch_pad_buf[(i * 2) + 1] - g_touch_pad_buf[i * 2]); }
这段代码是在初始化触摸板相关的变量和获取触摸数据。首先,它将触摸数和坐标值初始化为0和TOUCH_OFF_VALUE。然后,它从触摸板配置结构体中获取接收和发送通道的数量,并计算出元素数量。接下来,它调用dataGet函数来获取触摸数据,并将数据存储在g_touch_pad_buf数组中。如果获取数据时发现触摸板正在扫描,则返回FSP_ERR_CTSU_SCANNING错误。然后,它检查最大触摸数是否超过了最大值,如果超过了,则将最大触摸数设置为最大值,否则将最大触摸数设置为p_max_touch指针所指向的值。最后,它对每个元素进行处理,将其次级值减去主级值,并将结果保存在g_touch_pad_buf数组的前一半中。这个程序的目的是为了监控触摸板上的触摸情况,并将数据处理成差分形式方便后续使用。
解释以下代码 /* Data get */ err = p_instance_ctrl->p_ctsu_instance->p_api->dataGet(p_instance_ctrl->p_ctsu_instance->p_ctrl, g_touch_pad_buf); FSP_ERROR_RETURN(FSP_ERR_CTSU_SCANNING != err, FSP_ERR_CTSU_SCANNING); /* check for max touch */ if (*(p_instance_ctrl->pinfo.p_max_touch) > TOUCH_PAD_MONITOR_TOUCH_NUM_MAX) { max_touch = TOUCH_PAD_MONITOR_TOUCH_NUM_MAX; } else { max_touch = *(p_instance_ctrl->pinfo.p_max_touch); } /* make difference value = secondary - primary */ for (i = 0; i < element_num; i++) { /* save to buffer in the first half */ g_touch_pad_buf[i] = (uint16_t) (g_touch_pad_buf[(i * 2) + 1] - g_touch_pad_buf[i * 2]); } /* Data get section */ if (!g_touch_base_set_falg) { /* format base value , changing the order */ for (j = 0; j < num_x; j++) { for (i = 0; i < num_y; i++) { *(p_instance_ctrl->pinfo.p_base_buf + j + (i * num_x)) = (g_touch_pad_buf[*(p_instance_ctrl->p_touch_cfg->p_pad->p_elem_index_rx + j) + (*(p_instance_ctrl->p_touch_cfg->p_pad->p_elem_index_tx + i) * num_x)]); } } g_touch_base_set_falg = 1; }
这段代码是一个触摸板监测程序的一部分,主要用于获取触摸板的数据并进行处理。首先,使用 p_api->dataGet() 函数从触摸板获取数据,并检查是否正在进行扫描。然后,检查触摸板上触摸的最大数量,并将其与 TOUCH_PAD_MONITOR_TOUCH_NUM_MAX 进行比较,以确保不超过最大值。接着,使用从触摸板获取的数据计算出每个元素的差值,并将其存储在缓冲区的前半部分。如果触摸板的基准值未设置,则使用获取的数据设置基准值。最后,将基准值设置标志设置为 1。
阅读全文