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

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

?? tif_dir.c

?? 支持各種柵格圖像和矢量圖像讀取的庫
?? C
?? 第 1 頁 / 共 3 頁
字號:
/* $Id: tif_dir.c,v 1.74 2006/10/12 16:50:55 dron Exp $ *//* * Copyright (c) 1988-1997 Sam Leffler * Copyright (c) 1991-1997 Silicon Graphics, Inc. * * Permission to use, copy, modify, distribute, and sell this software and  * its documentation for any purpose is hereby granted without fee, provided * that (i) the above copyright notices and this permission notice appear in * all copies of the software and related documentation, and (ii) the names of * Sam Leffler and Silicon Graphics may not be used in any advertising or * publicity relating to the software without the specific, prior written * permission of Sam Leffler and Silicon Graphics. *  * THE SOFTWARE IS PROVIDED "AS-IS" AND WITHOUT WARRANTY OF ANY KIND,  * EXPRESS, IMPLIED OR OTHERWISE, INCLUDING WITHOUT LIMITATION, ANY  * WARRANTY OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.   *  * IN NO EVENT SHALL SAM LEFFLER OR SILICON GRAPHICS BE LIABLE FOR * ANY SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY KIND, * OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, * WHETHER OR NOT ADVISED OF THE POSSIBILITY OF DAMAGE, AND ON ANY THEORY OF  * LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE  * OF THIS SOFTWARE. *//* * TIFF Library. * * Directory Tag Get & Set Routines. * (and also some miscellaneous stuff) */#include "tiffiop.h"/* * These are used in the backwards compatibility code... */#define DATATYPE_VOID		0       /* !untyped data */#define DATATYPE_INT		1       /* !signed integer data */#define DATATYPE_UINT		2       /* !unsigned integer data */#define DATATYPE_IEEEFP		3       /* !IEEE floating point data */static voidsetByteArray(void** vpp, void* vp, size_t nmemb, size_t elem_size){	if (*vpp)		_TIFFfree(*vpp), *vpp = 0;	if (vp) {		tsize_t	bytes = nmemb * elem_size;		if (elem_size && bytes / elem_size == nmemb)			*vpp = (void*) _TIFFmalloc(bytes);		if (*vpp)			_TIFFmemcpy(*vpp, vp, bytes);	}}void _TIFFsetByteArray(void** vpp, void* vp, uint32 n)    { setByteArray(vpp, vp, n, 1); }void _TIFFsetString(char** cpp, char* cp)    { setByteArray((void**) cpp, (void*) cp, strlen(cp)+1, 1); }void _TIFFsetNString(char** cpp, char* cp, uint32 n)    { setByteArray((void**) cpp, (void*) cp, n, 1); }void _TIFFsetShortArray(uint16** wpp, uint16* wp, uint32 n)    { setByteArray((void**) wpp, (void*) wp, n, sizeof (uint16)); }void _TIFFsetLongArray(uint32** lpp, uint32* lp, uint32 n)    { setByteArray((void**) lpp, (void*) lp, n, sizeof (uint32)); }void _TIFFsetFloatArray(float** fpp, float* fp, uint32 n)    { setByteArray((void**) fpp, (void*) fp, n, sizeof (float)); }void _TIFFsetDoubleArray(double** dpp, double* dp, uint32 n)    { setByteArray((void**) dpp, (void*) dp, n, sizeof (double)); }/* * Install extra samples information. */static intsetExtraSamples(TIFFDirectory* td, va_list ap, uint32* v){	uint16* va;	uint32 i;	*v = va_arg(ap, uint32);	if ((uint16) *v > td->td_samplesperpixel)		return (0);	va = va_arg(ap, uint16*);	if (*v > 0 && va == NULL)		/* typically missing param */		return (0);	for (i = 0; i < *v; i++)		if (va[i] > EXTRASAMPLE_UNASSALPHA)			return (0);	td->td_extrasamples = (uint16) *v;	_TIFFsetShortArray(&td->td_sampleinfo, va, td->td_extrasamples);	return (1);}static uint32checkInkNamesString(TIFF* tif, uint32 slen, const char* s){	TIFFDirectory* td = &tif->tif_dir;	uint16 i = td->td_samplesperpixel;	if (slen > 0) {		const char* ep = s+slen;		const char* cp = s;		for (; i > 0; i--) {			for (; *cp != '\0'; cp++)				if (cp >= ep)					goto bad;			cp++;				/* skip \0 */		}		return (cp-s);	}bad:	TIFFErrorExt(tif->tif_clientdata, "TIFFSetField",	    "%s: Invalid InkNames value; expecting %d names, found %d",	    tif->tif_name,	    td->td_samplesperpixel,	    td->td_samplesperpixel-i);	return (0);}static int_TIFFVSetField(TIFF* tif, ttag_t tag, va_list ap){	static const char module[] = "_TIFFVSetField";	const TIFFFieldInfo* fip = _TIFFFindFieldInfo(tif, tag, TIFF_ANY);	TIFFDirectory* td = &tif->tif_dir;	int status = 1;	uint32 v32, i, v;	char* s;	switch (tag) {	case TIFFTAG_SUBFILETYPE:		td->td_subfiletype = va_arg(ap, uint32);		break;	case TIFFTAG_IMAGEWIDTH:		td->td_imagewidth = va_arg(ap, uint32);		break;	case TIFFTAG_IMAGELENGTH:		td->td_imagelength = va_arg(ap, uint32);		break;	case TIFFTAG_BITSPERSAMPLE:		td->td_bitspersample = (uint16) va_arg(ap, int);		/*		 * If the data require post-decoding processing to byte-swap		 * samples, set it up here.  Note that since tags are required		 * to be ordered, compression code can override this behaviour		 * in the setup method if it wants to roll the post decoding		 * work in with its normal work.		 */		if (tif->tif_flags & TIFF_SWAB) {			if (td->td_bitspersample == 16)				tif->tif_postdecode = _TIFFSwab16BitData;			else if (td->td_bitspersample == 24)				tif->tif_postdecode = _TIFFSwab24BitData;			else if (td->td_bitspersample == 32)				tif->tif_postdecode = _TIFFSwab32BitData;			else if (td->td_bitspersample == 64)				tif->tif_postdecode = _TIFFSwab64BitData;			else if (td->td_bitspersample == 128) /* two 64's */				tif->tif_postdecode = _TIFFSwab64BitData;		}		break;	case TIFFTAG_COMPRESSION:		v = va_arg(ap, uint32) & 0xffff;		/*		 * If we're changing the compression scheme, the notify the		 * previous module so that it can cleanup any state it's		 * setup.		 */		if (TIFFFieldSet(tif, FIELD_COMPRESSION)) {			if (td->td_compression == v)				break;			(*tif->tif_cleanup)(tif);			tif->tif_flags &= ~TIFF_CODERSETUP;		}		/*		 * Setup new compression routine state.		 */		if( (status = TIFFSetCompressionScheme(tif, v)) != 0 )                    td->td_compression = (uint16) v;                else                    status = 0;		break;	case TIFFTAG_PHOTOMETRIC:		td->td_photometric = (uint16) va_arg(ap, int);		break;	case TIFFTAG_THRESHHOLDING:		td->td_threshholding = (uint16) va_arg(ap, int);		break;	case TIFFTAG_FILLORDER:		v = va_arg(ap, uint32);		if (v != FILLORDER_LSB2MSB && v != FILLORDER_MSB2LSB)			goto badvalue;		td->td_fillorder = (uint16) v;		break;	case TIFFTAG_ORIENTATION:		v = va_arg(ap, uint32);		if (v < ORIENTATION_TOPLEFT || ORIENTATION_LEFTBOT < v)			goto badvalue;		else			td->td_orientation = (uint16) v;		break;	case TIFFTAG_SAMPLESPERPIXEL:		/* XXX should cross check -- e.g. if pallette, then 1 */		v = va_arg(ap, uint32);		if (v == 0)			goto badvalue;		td->td_samplesperpixel = (uint16) v;		break;	case TIFFTAG_ROWSPERSTRIP:		v32 = va_arg(ap, uint32);		if (v32 == 0)			goto badvalue32;		td->td_rowsperstrip = v32;		if (!TIFFFieldSet(tif, FIELD_TILEDIMENSIONS)) {			td->td_tilelength = v32;			td->td_tilewidth = td->td_imagewidth;		}		break;	case TIFFTAG_MINSAMPLEVALUE:		td->td_minsamplevalue = (uint16) va_arg(ap, int);		break;	case TIFFTAG_MAXSAMPLEVALUE:		td->td_maxsamplevalue = (uint16) va_arg(ap, int);		break;	case TIFFTAG_SMINSAMPLEVALUE:		td->td_sminsamplevalue = va_arg(ap, double);		break;	case TIFFTAG_SMAXSAMPLEVALUE:		td->td_smaxsamplevalue = va_arg(ap, double);		break;	case TIFFTAG_XRESOLUTION:		td->td_xresolution = (float) va_arg(ap, double);		break;	case TIFFTAG_YRESOLUTION:		td->td_yresolution = (float) va_arg(ap, double);		break;	case TIFFTAG_PLANARCONFIG:		v = va_arg(ap, uint32);		if (v != PLANARCONFIG_CONTIG && v != PLANARCONFIG_SEPARATE)			goto badvalue;		td->td_planarconfig = (uint16) v;		break;	case TIFFTAG_XPOSITION:		td->td_xposition = (float) va_arg(ap, double);		break;	case TIFFTAG_YPOSITION:		td->td_yposition = (float) va_arg(ap, double);		break;	case TIFFTAG_RESOLUTIONUNIT:		v = va_arg(ap, uint32);		if (v < RESUNIT_NONE || RESUNIT_CENTIMETER < v)			goto badvalue;		td->td_resolutionunit = (uint16) v;		break;	case TIFFTAG_PAGENUMBER:		td->td_pagenumber[0] = (uint16) va_arg(ap, int);		td->td_pagenumber[1] = (uint16) va_arg(ap, int);		break;	case TIFFTAG_HALFTONEHINTS:		td->td_halftonehints[0] = (uint16) va_arg(ap, int);		td->td_halftonehints[1] = (uint16) va_arg(ap, int);		break;	case TIFFTAG_COLORMAP:		v32 = (uint32)(1L<<td->td_bitspersample);		_TIFFsetShortArray(&td->td_colormap[0], va_arg(ap, uint16*), v32);		_TIFFsetShortArray(&td->td_colormap[1], va_arg(ap, uint16*), v32);		_TIFFsetShortArray(&td->td_colormap[2], va_arg(ap, uint16*), v32);		break;	case TIFFTAG_EXTRASAMPLES:		if (!setExtraSamples(td, ap, &v))			goto badvalue;		break;	case TIFFTAG_MATTEING:		td->td_extrasamples = (uint16) (va_arg(ap, int) != 0);		if (td->td_extrasamples) {			uint16 sv = EXTRASAMPLE_ASSOCALPHA;			_TIFFsetShortArray(&td->td_sampleinfo, &sv, 1);		}		break;	case TIFFTAG_TILEWIDTH:		v32 = va_arg(ap, uint32);		if (v32 % 16) {			if (tif->tif_mode != O_RDONLY)				goto badvalue32;			TIFFWarningExt(tif->tif_clientdata, tif->tif_name,				"Nonstandard tile width %d, convert file", v32);		}		td->td_tilewidth = v32;		tif->tif_flags |= TIFF_ISTILED;		break;	case TIFFTAG_TILELENGTH:		v32 = va_arg(ap, uint32);		if (v32 % 16) {			if (tif->tif_mode != O_RDONLY)				goto badvalue32;			TIFFWarningExt(tif->tif_clientdata, tif->tif_name,			    "Nonstandard tile length %d, convert file", v32);		}		td->td_tilelength = v32;		tif->tif_flags |= TIFF_ISTILED;		break;	case TIFFTAG_TILEDEPTH:		v32 = va_arg(ap, uint32);		if (v32 == 0)			goto badvalue32;		td->td_tiledepth = v32;		break;	case TIFFTAG_DATATYPE:		v = va_arg(ap, uint32);		switch (v) {		case DATATYPE_VOID:	v = SAMPLEFORMAT_VOID;	break;		case DATATYPE_INT:	v = SAMPLEFORMAT_INT;	break;		case DATATYPE_UINT:	v = SAMPLEFORMAT_UINT;	break;		case DATATYPE_IEEEFP:	v = SAMPLEFORMAT_IEEEFP;break;		default:		goto badvalue;		}		td->td_sampleformat = (uint16) v;		break;	case TIFFTAG_SAMPLEFORMAT:		v = va_arg(ap, uint32);		if (v < SAMPLEFORMAT_UINT || SAMPLEFORMAT_COMPLEXIEEEFP < v)			goto badvalue;		td->td_sampleformat = (uint16) v;                /*  Try to fix up the SWAB function for complex data. */                if( td->td_sampleformat == SAMPLEFORMAT_COMPLEXINT                     && td->td_bitspersample == 32                    && tif->tif_postdecode == _TIFFSwab32BitData )                    tif->tif_postdecode = _TIFFSwab16BitData;                else if( (td->td_sampleformat == SAMPLEFORMAT_COMPLEXINT                           || td->td_sampleformat == SAMPLEFORMAT_COMPLEXIEEEFP)                         && td->td_bitspersample == 64                         && tif->tif_postdecode == _TIFFSwab64BitData )                    tif->tif_postdecode = _TIFFSwab32BitData;		break;	case TIFFTAG_IMAGEDEPTH:		td->td_imagedepth = va_arg(ap, uint32);		break;	case TIFFTAG_SUBIFD:		if ((tif->tif_flags & TIFF_INSUBIFD) == 0) {			td->td_nsubifd = (uint16) va_arg(ap, int);			_TIFFsetLongArray(&td->td_subifd, va_arg(ap, uint32*),			    (long) td->td_nsubifd);		} else {			TIFFErrorExt(tif->tif_clientdata, module, "%s: Sorry, cannot nest SubIFDs",				  tif->tif_name);			status = 0;		}		break;	case TIFFTAG_YCBCRPOSITIONING:		td->td_ycbcrpositioning = (uint16) va_arg(ap, int);		break;	case TIFFTAG_YCBCRSUBSAMPLING:		td->td_ycbcrsubsampling[0] = (uint16) va_arg(ap, int);		td->td_ycbcrsubsampling[1] = (uint16) va_arg(ap, int);		break;	case TIFFTAG_TRANSFERFUNCTION:		v = (td->td_samplesperpixel - td->td_extrasamples) > 1 ? 3 : 1;		for (i = 0; i < v; i++)			_TIFFsetShortArray(&td->td_transferfunction[i],			    va_arg(ap, uint16*), 1L<<td->td_bitspersample);		break;	case TIFFTAG_INKNAMES:		v = va_arg(ap, uint32);		s = va_arg(ap, char*);		v = checkInkNamesString(tif, v, s);                status = v > 0;		if( v > 0 ) {			_TIFFsetNString(&td->td_inknames, s, v);			td->td_inknameslen = v;		}		break;        default: {            TIFFTagValue *tv;            int tv_size, iCustom;            /*	     * This can happen if multiple images are open with different	     * codecs which have private tags.  The global tag information	     * table may then have tags that are valid for one file but not	     * the other. If the client tries to set a tag that is not valid	     * for the image's codec then we'll arrive here.  This	     * happens, for example, when tiffcp is used to convert between	     * compression schemes and codec-specific tags are blindly copied.             */            if(fip == NULL || fip->field_bit != FIELD_CUSTOM) {		TIFFErrorExt(tif->tif_clientdata, module,			     "%s: Invalid %stag \"%s\" (not supported by codec)",			     tif->tif_name, isPseudoTag(tag) ? "pseudo-" : "",			     fip ? fip->field_name : "Unknown");		status = 0;		break;            }            /*             * Find the existing entry for this custom value.             */            tv = NULL;            for(iCustom = 0; iCustom < td->td_customValueCount; iCustom++) {                if(td->td_customValues[iCustom].info == fip) {                    tv = td->td_customValues + iCustom;                    if(tv->value != NULL)                    {                        _TIFFfree(tv->value);                        tv->value = NULL;                    }                    break;                }            }            /*             * Grow the custom list if the entry was not found.             */            if(tv == NULL) {		TIFFTagValue	*new_customValues;				td->td_customValueCount++;		new_customValues = (TIFFTagValue *)			_TIFFrealloc(td->td_customValues,				     sizeof(TIFFTagValue) * td->td_customValueCount);		if (!new_customValues) {			TIFFErrorExt(tif->tif_clientdata, module,		"%s: Failed to allocate space for list of custom values",				  tif->tif_name);			status = 0;			goto end;		}		td->td_customValues = new_customValues;                tv = td->td_customValues + (td->td_customValueCount-1);                tv->info = fip;                tv->value = NULL;                tv->count = 0;            }            /*             * Set custom value ... save a copy of the custom tag value.             */	    tv_size = _TIFFDataSize(fip->field_type);	    if (tv_size == 0) {		    status = 0;		    TIFFErrorExt(tif->tif_clientdata, module,				 "%s: Bad field type %d for \"%s\"",				 tif->tif_name, fip->field_type,				 fip->field_name);		    goto end;	    }                       if(fip->field_passcount) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩电影一二三区| 日韩三级av在线播放| 91麻豆精品国产| 久久成人免费网站| 成人综合日日夜夜| 91在线一区二区三区| 欧美日韩在线一区二区| 日韩一区二区在线免费观看| 精品国产乱码久久久久久影片| 精品福利在线导航| 亚洲三级久久久| 蜜臂av日日欢夜夜爽一区| 国产成a人亚洲| 91精品国产免费| 国产精品色哟哟网站| 五月天婷婷综合| 成人av网站在线观看| 欧美一区二区成人6969| 亚洲国产精品高清| 成人av在线一区二区三区| 欧美在线观看视频一区二区三区 | eeuss鲁片一区二区三区| 成人欧美一区二区三区黑人麻豆| 国产日韩欧美精品综合| 色综合久久久久综合99| 欧美年轻男男videosbes| 最新国产精品久久精品| 免费人成在线不卡| 在线精品国精品国产尤物884a| 久久影院电视剧免费观看| 亚洲图片有声小说| 色综合中文综合网| 亚洲影院免费观看| 成人综合日日夜夜| 久久精品一区蜜桃臀影院| 精品一区二区久久久| 日韩一区二区三区在线观看| 亚洲bt欧美bt精品777| 91黄色免费观看| 午夜精品久久久| 精品视频在线看| 欧美男生操女生| 中文字幕国产一区| 久久国产精品99久久久久久老狼 | 亚洲欧美福利一区二区| 亚洲欧美另类久久久精品2019| 国产精品综合一区二区三区| 日韩一级免费一区| 国产最新精品免费| 国产欧美精品国产国产专区| 成人免费毛片嘿嘿连载视频| 国产精品动漫网站| 欧美日韩中文一区| 秋霞av亚洲一区二区三| 久久婷婷色综合| 欧美日韩在线免费视频| 欧美国产欧美综合| 亚洲靠逼com| 国产精品亚洲专一区二区三区 | 麻豆精品一区二区综合av| 日韩精品三区四区| 日韩三级在线免费观看| 九色|91porny| 亚洲一级二级三级在线免费观看| 欧美一级国产精品| 成人综合婷婷国产精品久久蜜臀| 亚洲欧美日韩小说| 久久综合九色综合欧美亚洲| 成人久久18免费网站麻豆| 一卡二卡欧美日韩| 国产日韩精品视频一区| 欧美另类高清zo欧美| 色综合中文字幕国产 | 欧美视频一区二区三区| 成人一区二区三区视频在线观看 | 69成人精品免费视频| 色狠狠av一区二区三区| 成人免费av资源| 国产精品一区不卡| 国产大陆a不卡| 精品亚洲成a人| 久久不见久久见中文字幕免费| 亚洲在线中文字幕| 一区二区三区精品视频| 国产精品成人一区二区艾草| 久久亚洲一级片| 国产精品久久免费看| 日本一区二区在线不卡| 国产日韩精品视频一区| 久久久91精品国产一区二区三区| 久久亚洲一区二区三区明星换脸| 欧美成人猛片aaaaaaa| 久久免费电影网| 亚洲免费观看高清| 亚洲成av人综合在线观看| 麻豆一区二区三| 国产尤物一区二区| 91网站最新网址| 色欲综合视频天天天| 欧美精品丝袜久久久中文字幕| 4438x亚洲最大成人网| 精品国产乱码久久久久久夜甘婷婷| 欧美激情一区二区在线| 亚洲成在人线免费| av中文字幕不卡| 欧洲精品在线观看| 精品欧美一区二区在线观看| 国产精品久久久久毛片软件| 亚洲国产欧美另类丝袜| 粉嫩一区二区三区性色av| 欧美在线短视频| 国产精品天美传媒| 五月天国产精品| 99久久精品99国产精品| 日韩午夜精品电影| 一区二区三区毛片| 国产成人综合在线| 日韩欧美国产成人一区二区| 亚洲男人的天堂av| 97精品电影院| 久久久噜噜噜久久中文字幕色伊伊| 亚洲主播在线观看| 91美女片黄在线观看91美女| 国产欧美日韩另类一区| 国产自产高清不卡| 精品国产三级a在线观看| 国产欧美精品一区二区色综合朱莉| 污片在线观看一区二区 | 国产偷国产偷亚洲高清人白洁| 亚洲国产精品影院| 91官网在线免费观看| 一区二区三区日韩精品| 一本高清dvd不卡在线观看| 国产精品久久久99| www.日韩在线| 亚洲另类一区二区| 欧美日韩中文字幕一区| 日韩成人免费电影| 久久女同性恋中文字幕| 欧美xxxxxxxxx| 依依成人综合视频| 色综合久久中文字幕| 亚洲国产另类精品专区| 日韩欧美在线一区二区三区| 久久99热狠狠色一区二区| 国产午夜久久久久| 日本韩国欧美国产| 蜜臂av日日欢夜夜爽一区| 日韩欧美一级特黄在线播放| 国精产品一区一区三区mba桃花| 国产精品久久久久一区| 在线观看av不卡| 国产成人精品综合在线观看 | 久久精品久久99精品久久| 日本一区二区成人| 欧美精品成人一区二区三区四区| 国产一区二区在线看| 一片黄亚洲嫩模| 中文字幕永久在线不卡| 欧美一区二区在线看| www.99精品| 成人免费毛片aaaaa**| 老司机一区二区| 午夜精品成人在线视频| 一区二区三区成人| 日本一区二区三区四区| 欧美tickling挠脚心丨vk| 欧美在线制服丝袜| 99久久久精品| 99久久伊人精品| 国产99久久久国产精品| 国产真实精品久久二三区| 奇米精品一区二区三区在线观看 | 色综合久久久网| 99国产精品国产精品久久| 国产91对白在线观看九色| 国产成人精品一区二| 成人黄色小视频| 高清成人免费视频| 在线免费观看一区| 欧美久久久影院| 欧美tickle裸体挠脚心vk| 亚洲精品一区二区三区精华液| 久久综合视频网| 国产精品对白交换视频| 亚洲黄色免费电影| 日韩国产精品久久| 国产一区二区三区不卡在线观看 | 免费观看在线综合色| 国产在线播放一区二区三区| av电影在线观看一区| 欧美日本不卡视频| 国产日产欧美一区| 天天色天天爱天天射综合| 国产精品一区二区在线播放| 91网站在线观看视频| 久久蜜臀中文字幕| 亚洲成人先锋电影| 成人永久免费视频| 欧美精品色一区二区三区|