亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? variance.c

?? 觸摸屏校準的思想及源代碼
?? C
字號:
/*
 *  tslib/plugins/variance.c
 *
 *  Copyright (C) 2001 Russell King.
 *
 * This file is placed under the LGPL.  Please see the file
 * COPYING for more details.
 *
 * $Id: variance.c,v 1.3 2002/11/08 23:28:55 dlowder Exp $
 *
 * Variance filter for touchscreen values
 */
#include <errno.h>
#include <stdlib.h>
#include <string.h>
#include <limits.h>

#include <stdio.h>

#include "tslib.h"
#include "tslib-filter.h"

#define NR_LAST	4

struct tslib_variance {
	struct tslib_module_info	module;
	int				nr;
	unsigned int			pthreshold;
	unsigned int			xlimit;
	unsigned int			ylimit;
	struct ts_sample		last[NR_LAST];
};

/*
 * We have 4 complete samples.  Calculate the variance between each,
 * treating X and Y values separately.  Then pick the two with the
 * least variance, and average them.
 */
static int
variance_calculate(struct tslib_variance *var, struct ts_sample *samp,
		   struct ts_sample *s)
{
	int i, j;
	int diff_x, min_x, i_x, j_x;
	int diff_y, min_y, i_y, j_y;
	int diff_p, min_p, i_p, j_p;

	min_x = INT_MAX;
	min_y = INT_MAX;
	min_p = INT_MAX;

	for (i = 0; i < var->nr - 1; i++) {
		for (j = i + 1; j < var->nr; j++) {
			/*
			 * Calculate the variance between sample 'i'
			 * and sample 'j'.  X and Y values are treated
			 * separately.
			 */
			diff_x = var->last[i].x - var->last[j].x;
			if (diff_x < 0)
				diff_x = -diff_x;

			diff_y = var->last[i].y - var->last[j].y;
			if (diff_y < 0)
				diff_y = -diff_y;

			diff_p = var->last[i].pressure - var->last[j].pressure;
			if (diff_p < 0)
				diff_p = -diff_p;

			/*
			 * Is the variance between any two samples too large?
			 */
			if (diff_x > var->xlimit || diff_y > var->ylimit)
				return 0;

			/*
			 * Find the minimum X variance.
			 */
			if (min_x > diff_x) {
				min_x = diff_x;
				i_x = i;
				j_x = j;
			}

			/*
			 * Find the minimum Y variance.
			 */
			if (min_y > diff_y) {
				min_y = diff_y;
				i_y = i;
				j_y = j;
			}

			if (min_p > diff_p) {
				min_p = diff_p;
				i_p = i;
				j_p = j;
			}
		}
	}

	samp->x		 = (var->last[i_x].x + var->last[j_x].x) / 2;
	samp->y		 = (var->last[i_y].y + var->last[j_y].y) / 2;
	samp->pressure   = (var->last[i_p].pressure + var->last[j_p].pressure) / 2;
	samp->tv.tv_sec  = s->tv.tv_sec;
	samp->tv.tv_usec = s->tv.tv_usec;

	return 1;
}

static int variance_read(struct tslib_module_info *info, struct ts_sample *samp, int nr)
{
	struct tslib_variance *var = (struct tslib_variance *)info;
	struct ts_sample *s;
	int ret;

	ret = info->next->ops->read(info->next, samp, nr);
	if (ret >= 0) {
		int nr = 0;

		for (s = samp; s < samp + ret; s++) {
			if (s->pressure < var->pthreshold) {
				/*
				 * Pen was released.  Reset our state and
				 * pass up the release information.
				 */
//				samp[nr].x = 0;
//				samp[nr].y = 0;
				samp[nr].pressure = s->pressure;
				samp[nr].tv.tv_sec = s->tv.tv_sec;
				samp[nr].tv.tv_usec = s->tv.tv_usec;

				nr++;

				var->nr = 0;
				continue;
			} else if (var->nr == -1) {
				/*
				 * Pen was pressed.  Inform upper layers
				 * immediately.
				 */
				samp[nr] = *s;
				nr++;
			}

			if (var->nr >= 0) {
				var->last[var->nr].x = s->x;
				var->last[var->nr].y = s->y;
				var->last[var->nr].pressure = s->pressure;
			}

			var->nr++;

			if (var->nr == NR_LAST) {
				if (variance_calculate(var, samp + nr, s))
					nr++;
				var->nr = 0;
			}
		}

		ret = nr;
	}
	return ret;
}

static int variance_fini(struct tslib_module_info *info)
{
	free(info);
}

static const struct tslib_ops variance_ops =
{
	read:	variance_read,
	fini:	variance_fini,
};

static int variance_limit(struct tslib_module_info *inf, char *str, void *data)
{
	struct tslib_variance *var = (struct tslib_variance *)inf;
	unsigned long v;
	int err = errno;

	v = strtoul(str, NULL, 0);

	if (v == ULONG_MAX && errno == ERANGE)
		return -1;

	errno = err;
	switch ((int)data) {
	case 1:
		var->xlimit = v;
		break;

	case 2:
		var->ylimit = v;
		break;

	case 3:
		var->pthreshold = v;
		break;

	default:
		return -1;
	}
	return 0;
}

static const struct tslib_vars variance_vars[] =
{
	{ "xlimit",	(void *)1, variance_limit },
	{ "ylimit",	(void *)2, variance_limit },
	{ "pthreshold",	(void *)3, variance_limit }
};

#define NR_VARS (sizeof(variance_vars) / sizeof(variance_vars[0]))

struct tslib_module_info *mod_init(struct tsdev *dev, const char *params)
{
	struct tslib_variance *var;

	var = malloc(sizeof(struct tslib_variance));
	if (var == NULL)
		return NULL;

	var->module.ops = &variance_ops;

	var->nr = -1;
	var->xlimit = 160;
	var->ylimit = 160;
	var->pthreshold = 100;

	if (tslib_parse_vars(&var->module, variance_vars, NR_VARS, params)) {
		free(var);
		return NULL;
	}

	return &var->module;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
奇米一区二区三区| 亚洲福利国产精品| 国产成人午夜精品影院观看视频| 欧美激情一区在线观看| 欧美午夜精品久久久久久超碰| 石原莉奈在线亚洲二区| 成人欧美一区二区三区在线播放| 日韩一二三四区| 欧美亚洲一区三区| 色综合久久久久网| 综合分类小说区另类春色亚洲小说欧美 | 最新日韩av在线| 欧美成人艳星乳罩| 视频一区中文字幕| 亚洲自拍偷拍综合| 亚洲图片你懂的| 国产精品另类一区| 国产日韩欧美电影| 久久综合久久久久88| 日韩精品一区在线观看| 69av一区二区三区| 日韩一二三四区| 日韩欧美国产不卡| 精品捆绑美女sm三区| 日韩欧美中文字幕一区| 日韩欧美一级特黄在线播放| 欧美一区日本一区韩国一区| 精品乱码亚洲一区二区不卡| 精品国产免费一区二区三区香蕉| 欧美成人aa大片| 欧美精品一区二区三区高清aⅴ| 欧美va亚洲va国产综合| 26uuu亚洲综合色| 国产精品久久久久久亚洲伦| 亚洲丝袜制服诱惑| 无码av免费一区二区三区试看| 日本欧美加勒比视频| 精品综合久久久久久8888| 另类专区欧美蜜桃臀第一页| 国产高清成人在线| 91丨porny丨首页| 日韩美女视频在线| 日韩美女视频一区| 天使萌一区二区三区免费观看| 国产麻豆91精品| 欧美视频一区二区在线观看| 欧美大片在线观看| 亚洲免费av高清| 国产一区二区三区四| 欧美亚洲动漫精品| 国产亚洲成av人在线观看导航| 亚洲免费资源在线播放| 国产一区二区按摩在线观看| 色先锋资源久久综合| 久久久亚洲精品一区二区三区| 亚洲福利电影网| 一本高清dvd不卡在线观看| 日韩欧美一卡二卡| 亚洲一级在线观看| 99久久er热在这里只有精品15 | 国产精品久久免费看| 久久精品国产亚洲一区二区三区| 91网页版在线| 国产精品丝袜在线| 亚洲国产精品自拍| 国产剧情一区二区| 欧美精品一区二区三区蜜桃视频| 亚洲最大的成人av| 91精品办公室少妇高潮对白| 18涩涩午夜精品.www| 国产91清纯白嫩初高中在线观看| 久久影院电视剧免费观看| 免费久久精品视频| 精品国产百合女同互慰| 国产又粗又猛又爽又黄91精品| 欧美日韩成人综合| 日精品一区二区三区| 91精品国产综合久久蜜臀| 日韩1区2区3区| 久久午夜羞羞影院免费观看| 国模少妇一区二区三区| 国产欧美精品日韩区二区麻豆天美| 国产一区欧美二区| 日本一区二区三区四区| 色婷婷久久一区二区三区麻豆| 一区二区三区四区激情| 欧美一区二区三区在线看| 久久精品国产久精国产| 中文字幕乱码久久午夜不卡| 91成人免费网站| 丝袜美腿高跟呻吟高潮一区| 精品久久久久99| 91麻豆精品一区二区三区| 午夜婷婷国产麻豆精品| 亚洲精品在线网站| 91无套直看片红桃| 麻豆视频一区二区| 国产精品理论在线观看| 制服.丝袜.亚洲.另类.中文| 国产成人精品亚洲日本在线桃色 | 久久久亚洲高清| 日本精品一区二区三区高清| 美国十次综合导航| 亚洲国产视频一区二区| 久久先锋影音av鲁色资源| 欧洲激情一区二区| 春色校园综合激情亚洲| 蜜臀久久99精品久久久久久9| 国产精品久久三| 久久久久久久久久看片| 欧美日韩一区成人| 色域天天综合网| 国产成人在线视频网站| 韩国三级在线一区| 日本不卡免费在线视频| 亚洲一区二区三区不卡国产欧美| 国产色91在线| 91麻豆精品91久久久久久清纯 | 毛片不卡一区二区| 天使萌一区二区三区免费观看| 亚洲视频中文字幕| 国产欧美视频一区二区| 国产日韩欧美激情| 国产欧美日韩三级| 中文欧美字幕免费| 国产精品日韩成人| 亚洲色图一区二区| 亚洲一区二区三区爽爽爽爽爽| 国产精品久久毛片a| 亚洲精品ww久久久久久p站| 亚洲欧洲日产国产综合网| 亚洲免费在线播放| 亚洲综合在线观看视频| 三级久久三级久久| 久久99国产精品免费| 成人av午夜电影| 91久久精品一区二区| 日韩视频一区二区在线观看| 欧美激情资源网| 国产亚洲欧美一级| 欧美区在线观看| 欧美特级限制片免费在线观看| 99热精品一区二区| 看国产成人h片视频| 日日骚欧美日韩| 麻豆91免费观看| 麻豆精品久久精品色综合| 亚洲精品成人精品456| 一区二区三区四区不卡视频| 亚洲国产精品久久艾草纯爱| 国产一区不卡视频| 欧美日韩一卡二卡| 国产精品污污网站在线观看| 日韩高清一区在线| 国产成人精品免费看| 欧美日韩国产系列| 国产精品乱人伦中文| 一区二区三区日韩精品| 久久黄色级2电影| 色综合久久综合网| 国产欧美日韩麻豆91| 久久99久久99精品免视看婷婷 | 欧美三级三级三级| 国产精品每日更新在线播放网址| 亚洲一区二区不卡免费| 国内精品伊人久久久久影院对白| 欧美午夜精品久久久久久超碰| 国产精品卡一卡二卡三| 国产精品夜夜嗨| 欧美精品电影在线播放| 亚欧色一区w666天堂| 日本精品一区二区三区高清| 中文字幕中文在线不卡住| 精品一区二区久久| 91麻豆精品国产91久久久更新时间| 亚洲成人一区二区在线观看| 色欧美乱欧美15图片| 国产精品丝袜一区| 972aa.com艺术欧美| 亚洲午夜精品一区二区三区他趣| 美脚の诱脚舐め脚责91 | 欧美高清激情brazzers| 91网站在线播放| 亚洲欧美另类小说| 懂色一区二区三区免费观看| 日韩手机在线导航| eeuss鲁片一区二区三区在线观看| 日本伦理一区二区| 欧美一级片在线看| 国产精品无圣光一区二区| 亚洲美女在线国产| 理论片日本一区| 欧美日本高清视频在线观看| 日韩限制级电影在线观看| 717成人午夜免费福利电影| 婷婷中文字幕综合| 日韩成人精品在线| 精品国产凹凸成av人导航| 日本中文字幕一区| 国产亚洲女人久久久久毛片|