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

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

?? gamma.c

?? libminigui-1.3.0.tar.gz。 miniGUI的庫函數源代碼!
?? C
字號:
/***  $Id: gamma.c,v 1.4 2003/11/23 05:10:59 weiym Exp $**  **  Port to MiniGUI by Wei Yongming (2001/10/03).**  Copyright (C) 2001 ~ 2002 Wei Yongming.**  Copyright (C) 2003 Feynman Software.****  SDL - Simple DirectMedia Layer**  Copyright (C) 1997, 1998, 1999, 2000, 2001  Sam Lantinga*//*** This program is free software; you can redistribute it and/or modify** it under the terms of the GNU General Public License as published by** the Free Software Foundation; either version 2 of the License, or** (at your option) any later version.**** This program is distributed in the hope that it will be useful,** but WITHOUT ANY WARRANTY; without even the implied warranty of** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the** GNU General Public License for more details.**** You should have received a copy of the GNU General Public License** along with this program; if not, write to the Free Software** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA*//* Gamma correction support */#include <stdio.h>#include <stdlib.h>#include <string.h>#include "common.h"#ifdef HAVE_MATH_H#include <math.h>#endif#include "newgal.h"#include "sysvideo.h"#ifdef HAVE_MATH_Hstatic void CalculateGammaRamp(float gamma, Uint16 *ramp){	int i;	/* 0.0 gamma is all black */	if ( gamma <= 0.0 ) {		for ( i=0; i<256; ++i ) {			ramp[i] = 0;		}		return;	} else	/* 1.0 gamma is identity */	if ( gamma == 1.0 ) {		for ( i=0; i<256; ++i ) {			ramp[i] = (i << 8) | i;		}		return;	} else	/* Calculate a real gamma ramp */	{ int value;		gamma = 1.0f / gamma;		for ( i=0; i<256; ++i ) {			value = (int)(pow((double)i/256.0, gamma)*65535.0+0.5);			if ( value > 65535 ) {				value = 65535;			}			ramp[i] = (Uint16)value;		}	}}static void CalculateGammaFromRamp(float *gamma, Uint16 *ramp){	/* The following is adapted from a post by Garrett Bass on OpenGL	   Gamedev list, March 4, 2000.	 */	float sum = 0.0;	int i, count = 0;	*gamma = 1.0;	for ( i = 1; i < 256; ++i ) {	    if ( (ramp[i] != 0) && (ramp[i] != 65535) ) {	        double B = (double)i / 256.0;	        double A = ramp[i] / 65535.0;	        sum += (float) ( log(A) / log(B) );	        count++;	    }	}	if ( count && sum ) {		*gamma = 1.0f / (sum / count);	}}#endif /* HAVE_MATH_H */int GAL_SetGamma(float red, float green, float blue){	int succeeded;	GAL_VideoDevice *video = current_video;	GAL_VideoDevice *this  = current_video;		succeeded = -1;#ifdef HAVE_MATH_H	/* Prefer using SetGammaRamp(), as it's more flexible */	{		Uint16 ramp[3][256];		CalculateGammaRamp(red, ramp[0]);		CalculateGammaRamp(green, ramp[1]);		CalculateGammaRamp(blue, ramp[2]);		succeeded = GAL_SetGammaRamp(ramp[0], ramp[1], ramp[2]);	}#else	GAL_SetError("Gamma correction not supported");#endif	if ( (succeeded < 0) && video->SetGamma ) {		GAL_ClearError();		succeeded = video->SetGamma(this, red, green, blue);	}	return succeeded;}/* Calculating the gamma by integrating the gamma ramps isn't exact,   so this function isn't officially supported.*/int GAL_GetGamma(float *red, float *green, float *blue){	int succeeded;	GAL_VideoDevice *video = current_video;	GAL_VideoDevice *this  = current_video;		succeeded = -1;#ifdef HAVE_MATH_H	/* Prefer using GetGammaRamp(), as it's more flexible */	{		Uint16 ramp[3][256];		succeeded = GAL_GetGammaRamp(ramp[0], ramp[1], ramp[2]);		if ( succeeded >= 0 ) {			CalculateGammaFromRamp(red, ramp[0]);			CalculateGammaFromRamp(green, ramp[1]);			CalculateGammaFromRamp(blue, ramp[2]);		}	}#else	GAL_SetError("Gamma correction not supported");#endif	if ( (succeeded < 0) && video->GetGamma ) {		GAL_ClearError();		succeeded = video->GetGamma(this, red, green, blue);	}	return succeeded;}int GAL_SetGammaRamp(Uint16 *red, Uint16 *green, Uint16 *blue){	int succeeded;	GAL_VideoDevice *video = current_video;	GAL_VideoDevice *this  = current_video;		GAL_Surface *screen = GAL_PublicSurface;	/* Verify the screen parameter */	if ( !screen ) {		GAL_SetError("No video mode has been set");		return -1;	}	/* Lazily allocate the gamma tables */	if ( ! video->gamma ) {		GAL_GetGammaRamp(0, 0, 0);	}	/* Fill the gamma table with the new values */	if ( red ) {		memcpy(&video->gamma[0*256], red, 256*sizeof(*video->gamma));	}	if ( green ) {		memcpy(&video->gamma[1*256], green, 256*sizeof(*video->gamma));	}	if ( blue ) {		memcpy(&video->gamma[2*256], blue, 256*sizeof(*video->gamma));	}	/* Gamma correction always possible on split palettes */	if ( (screen->flags & GAL_HWPALETTE) == GAL_HWPALETTE ) {		GAL_Palette *pal = screen->format->palette;		/* If physical palette has been set independently, use it */		if(video->physpal)		        pal = video->physpal;		      		GAL_SetPalette(screen, GAL_PHYSPAL,			       pal->colors, 0, pal->ncolors);		return 0;	}	/* Try to set the gamma ramp in the driver */	succeeded = -1;	if ( video->SetGammaRamp ) {		succeeded = video->SetGammaRamp(this, video->gamma);	} else {		GAL_SetError("Gamma ramp manipulation not supported");	}	return succeeded;}int GAL_GetGammaRamp(Uint16 *red, Uint16 *green, Uint16 *blue){	GAL_VideoDevice *video = current_video;	GAL_VideoDevice *this  = current_video;		/* Lazily allocate the gamma table */	if ( ! video->gamma ) {		video->gamma = malloc(3*256*sizeof(*video->gamma));		if ( ! video->gamma ) {			GAL_OutOfMemory();			return -1;		}		if ( video->GetGammaRamp ) {			/* Get the real hardware gamma */			video->GetGammaRamp(this, video->gamma);		} else {			/* Assume an identity gamma */			int i;			for ( i=0; i<256; ++i ) {				video->gamma[0*256+i] = (i << 8) | i;				video->gamma[1*256+i] = (i << 8) | i;				video->gamma[2*256+i] = (i << 8) | i;			}		}	}	/* Just copy from our internal table */	if ( red ) {		memcpy(red, &video->gamma[0*256], 256*sizeof(*red));	}	if ( green ) {		memcpy(green, &video->gamma[1*256], 256*sizeof(*green));	}	if ( blue ) {		memcpy(blue, &video->gamma[2*256], 256*sizeof(*blue));	}	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
男男视频亚洲欧美| 欧美性感一类影片在线播放| 国产成人av电影免费在线观看| 99天天综合性| 欧美日韩国产在线观看| 日韩午夜在线观看视频| 国产亚洲欧美日韩俺去了| 国产精品免费aⅴ片在线观看| 亚洲伦理在线精品| 免费成人结看片| 欧美综合色免费| 56国语精品自产拍在线观看| 国产午夜亚洲精品羞羞网站| 亚洲资源中文字幕| 韩国一区二区视频| 欧美亚洲免费在线一区| 中文字幕免费不卡| 日韩成人精品在线观看| av爱爱亚洲一区| 2021国产精品久久精品| 一区二区三区中文免费| 国产91精品露脸国语对白| 欧美一级二级在线观看| 亚洲女子a中天字幕| 国产又黄又大久久| 欧美乱妇20p| 亚洲综合色网站| 日本高清免费不卡视频| 国产日产亚洲精品系列| 久久精品国产成人一区二区三区| 欧美亚洲丝袜传媒另类| 亚洲黄色小说网站| 91免费版在线| 亚洲欧洲成人自拍| 粉嫩13p一区二区三区| 精品福利在线导航| 久久国产精品无码网站| 精品国产99国产精品| 久久av老司机精品网站导航| 日韩亚洲欧美中文三级| 婷婷一区二区三区| 欧美日韩大陆在线| 蜜臀av一区二区在线免费观看| 欧美三级蜜桃2在线观看| 亚洲一区二区av电影| 欧美挠脚心视频网站| 亚洲第一搞黄网站| 欧美一区二区三级| 狠狠色综合日日| 久久久99精品久久| 91小宝寻花一区二区三区| 国产精品国产三级国产aⅴ中文| 国产**成人网毛片九色| 一区二区三区国产| 欧美日韩一级大片网址| 亚洲欧美日韩一区| 欧美浪妇xxxx高跟鞋交| 精品国产精品一区二区夜夜嗨| 91美女精品福利| 亚洲欧美另类久久久精品 | 亚洲欧洲韩国日本视频| 色999日韩国产欧美一区二区| 天天色天天操综合| 亚洲国产一区视频| 欧美一级日韩不卡播放免费| 国产福利视频一区二区三区| 一区二区成人在线观看| 精品久久久久久久久久久久久久久久久 | 另类综合日韩欧美亚洲| 国产精品美女久久久久久久久久久| 91农村精品一区二区在线| 麻豆精品久久久| 一区二区三区不卡在线观看| 国产三级一区二区三区| 91精品国产色综合久久不卡电影| 成人av资源在线| 久久机这里只有精品| 欧美调教femdomvk| 国产精品美女久久久久久久久| 欧美人牲a欧美精品| av男人天堂一区| 国产一区二区电影| 青娱乐精品在线视频| 亚洲成人www| 亚洲欧美偷拍卡通变态| 久久久91精品国产一区二区精品| 欧美一级淫片007| 欧美日韩在线亚洲一区蜜芽| 99re在线视频这里只有精品| 极品少妇xxxx精品少妇| 九色porny丨国产精品| 美腿丝袜在线亚洲一区| 丝袜诱惑亚洲看片| 亚洲图片有声小说| 亚洲福利视频一区| 亚洲一区二区三区激情| 亚洲福利视频一区| 亚洲成a人v欧美综合天堂下载| 天堂成人国产精品一区| 亚洲无人区一区| 日韩和的一区二区| 日本视频一区二区三区| 麻豆精品视频在线观看免费| 久久成人免费电影| 国产高清精品网站| 99久久精品国产观看| 爽好多水快深点欧美视频| 性感美女久久精品| 亚洲成av人影院| 日日骚欧美日韩| 日本欧美在线看| 久久成人免费网| 国产高清一区日本| 99久久免费精品高清特色大片| a级精品国产片在线观看| 99国产精品久久久久| 91视频.com| 日韩精品一区二区三区四区视频| 欧美大片日本大片免费观看| 久久色.com| 亚洲激情在线播放| 日日欢夜夜爽一区| 久久99九九99精品| 成人免费高清视频在线观看| 色先锋资源久久综合| 欧美日韩高清影院| 久久精品一区二区三区不卡牛牛 | 亚洲图片欧美视频| 国产原创一区二区三区| 99久久精品免费看国产| 欧美一区二区三区婷婷月色| 国产精品免费av| 捆绑紧缚一区二区三区视频| 国产成人亚洲综合a∨婷婷| 精品视频1区2区| 中文字幕的久久| 亚洲午夜精品一区二区三区他趣| 国产一区999| 欧美色综合网站| 欧美激情一二三区| 精品无人码麻豆乱码1区2区| 99久久精品免费看国产免费软件| 精品成人在线观看| 亚洲成人资源在线| 91在线视频免费91| 国产精品欧美综合在线| 精品一区中文字幕| 91精品国产麻豆| 亚洲图片欧美综合| 色视频成人在线观看免| 中文字幕精品一区二区精品绿巨人| 美国十次综合导航| 日韩亚洲欧美中文三级| 亚洲国产日韩一级| 欧美中文字幕一区二区三区亚洲| 国产精品久久久久久久第一福利| 国产在线精品免费| xfplay精品久久| 精品一区二区免费在线观看| 日韩欧美久久久| 爽好久久久欧美精品| 91麻豆精品国产自产在线观看一区| 成人做爰69片免费看网站| 国产欧美一区视频| 不卡的av在线播放| 日韩欧美在线综合网| 免费在线视频一区| 67194成人在线观看| 免费欧美高清视频| 精品国产免费人成在线观看| 亚洲小说春色综合另类电影| 精品一区免费av| 国产拍欧美日韩视频二区| gogogo免费视频观看亚洲一| 日韩精品专区在线| 成人免费视频一区二区| 国产日韩综合av| 欧美人与z0zoxxxx视频| 国产乱码字幕精品高清av| 亚洲图片激情小说| 91污在线观看| 精品一区二区三区免费播放| 精品国精品国产尤物美女| 福利一区二区在线| 欧美国产一区视频在线观看| 99久免费精品视频在线观看| 久久这里只有精品视频网| 日韩中文字幕av电影| 国产亚洲欧美中文| 蜜臀av性久久久久蜜臀aⅴ四虎| 777奇米成人网| 日本欧美在线观看| 中文字幕欧美激情| 8v天堂国产在线一区二区| 色哟哟欧美精品| 成人av网站在线| 日韩精品成人一区二区三区| 中文字幕永久在线不卡| 久久久久国产精品厨房| 7777精品伊人久久久大香线蕉 |