当前位置: 首页>>代码示例>>C#>>正文


C# LibTiff.TIFF类代码示例

本文整理汇总了C#中Free.Ports.LibTiff.TIFF的典型用法代码示例。如果您正苦于以下问题:C# TIFF类的具体用法?C# TIFF怎么用?C# TIFF使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


TIFF类属于Free.Ports.LibTiff命名空间,在下文中一共展示了TIFF类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: alloc_downsampled_buffers

        // Allocate downsampled-data buffers needed for downsampled I/O.
        // We use values computed in jpeg_start_compress or jpeg_start_decompress.
        // We use libjpeg's allocator so that buffers will be released automatically
        // when done with strip/tile.
        // This is also a handy place to compute samplesperclump, bytesperline.
        static bool alloc_downsampled_buffers(TIFF tif, jpeg_component_info[] comp_info, int num_components)
        {
            JPEGState sp=tif.tif_data as JPEGState;

            byte[][] buf;
            int samples_per_clump=0;

            for(int ci=0; ci<num_components; ci++)
            {
                jpeg_component_info compptr=comp_info[ci];

                samples_per_clump+=compptr.h_samp_factor*compptr.v_samp_factor;
                try
                {
                    buf=TIFFjpeg_alloc_sarray(sp, compptr.width_in_blocks*libjpeg.DCTSIZE, (uint)compptr.v_samp_factor*libjpeg.DCTSIZE);
                }
                catch
                {
                    return false;
                }

                sp.ds_buffer[ci]=buf;
            }

            sp.samplesperclump=samples_per_clump;
            return true;
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:32,代码来源:tif_jpeg.cs

示例2: TIFFSetupStrips

        public static bool TIFFSetupStrips(TIFF tif)
        {
            TIFFDirectory td=tif.tif_dir;

            if(isTiled(tif)) td.td_stripsperimage=isUnspecified(tif, FIELD.TILEDIMENSIONS)?td.td_samplesperpixel:TIFFNumberOfTiles(tif);
            else td.td_stripsperimage=isUnspecified(tif, FIELD.ROWSPERSTRIP)?td.td_samplesperpixel:(uint)TIFFNumberOfStrips(tif);

            td.td_nstrips=td.td_stripsperimage;
            if(td.td_planarconfig==PLANARCONFIG.SEPARATE) td.td_stripsperimage/=td.td_samplesperpixel;

            try
            {
                td.td_stripoffset=new uint[td.td_nstrips];
                td.td_stripbytecount=new uint[td.td_nstrips];
            }
            catch
            {
                return false;
            }

            // Place data at the end-of-file
            // (by setting offsets to zero).
            TIFFSetFieldBit(tif, FIELD.STRIPOFFSETS);
            TIFFSetFieldBit(tif, FIELD.STRIPBYTECOUNTS);

            // FIX: Some tools don't like images without ROWSPERSTRIP set.
            if(!TIFFFieldSet(tif, FIELD.ROWSPERSTRIP))
            {
                td.td_rowsperstrip=td.td_imagelength;
                TIFFSetFieldBit(tif, FIELD.ROWSPERSTRIP);
            }

            return true;
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:34,代码来源:tif_write.cs

示例3: TIFFCheckTile

        // Check an (x,y,z,s) coordinate against the image bounds.
        public static bool TIFFCheckTile(TIFF tif, uint x, uint y, uint z, ushort s)
        {
            TIFFDirectory td=tif.tif_dir;

            if(x>=td.td_imagewidth)
            {
                TIFFErrorExt(tif.tif_clientdata, tif.tif_name, "{0}: Col out of range, max {1}", x, td.td_imagewidth-1);
                return false;
            }

            if(y>=td.td_imagelength)
            {
                TIFFErrorExt(tif.tif_clientdata, tif.tif_name, "{0}: Row out of range, max {1}", y, td.td_imagelength-1);
                return false;
            }

            if(z>=td.td_imagedepth)
            {
                TIFFErrorExt(tif.tif_clientdata, tif.tif_name, "{0}: Depth out of range, max {1}", z, td.td_imagedepth-1);
                return false;
            }

            if(td.td_planarconfig==PLANARCONFIG.SEPARATE&&s>=td.td_samplesperpixel)
            {
                TIFFErrorExt(tif.tif_clientdata, tif.tif_name, "{0}: Sample out of range, max {1}", s, td.td_samplesperpixel-1);
                return false;
            }

            return true;
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:31,代码来源:tif_tile.cs

示例4: TIFFComputeTile

        // Compute which tile an (x,y,z,s) value is in.
        public static uint TIFFComputeTile(TIFF tif, uint x, uint y, uint z, ushort s)
        {
            TIFFDirectory td=tif.tif_dir;
            uint dx=td.td_tilewidth;
            uint dy=td.td_tilelength;
            uint dz=td.td_tiledepth;

            if(td.td_imagedepth==1) z=0;
            if(dx==0xffffffff) dx=td.td_imagewidth;
            if(dy==0xffffffff) dy=td.td_imagelength;
            if(dz==0xffffffff) dz=td.td_imagedepth;

            if(dx!=0&&dy!=0&&dz!=0)
            {
                uint xpt=TIFFhowmany(td.td_imagewidth, dx);
                uint ypt=TIFFhowmany(td.td_imagelength, dy);
                uint zpt=TIFFhowmany(td.td_imagedepth, dz);

                if(td.td_planarconfig==PLANARCONFIG.SEPARATE)
                    return xpt*ypt*zpt*s+xpt*ypt*(z/dz)+xpt*(y/dy)+x/dx;

                return xpt*ypt*(z/dz)+xpt*(y/dy)+x/dx;
            }

            return 1;
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:27,代码来源:tif_tile.cs

示例5: TIFFGetTagListEntry

        public static TIFFTAG TIFFGetTagListEntry(TIFF tif, int tag_index)
        {
            TIFFDirectory td=tif.tif_dir;

            if(tag_index<0||tag_index>=td.td_customValueCount) return (TIFFTAG)(-1);
            else return td.td_customValues[tag_index].info.field_tag;
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:7,代码来源:tif_extension.cs

示例6: TIFFRewriteDirectory

        // Similar to TIFFWriteDirectory(), but if the directory has already
        // been written once, it is relocated to the end of the file, in case it
        // has changed in size. Note that this will result in the loss of the
        // previously used directory space.
        public static bool TIFFRewriteDirectory(TIFF tif)
        {
            string module="TIFFRewriteDirectory";

            // We don't need to do anything special if it hasn't been written.
            if(tif.tif_diroff==0) return TIFFWriteDirectory(tif);

            // Find and zero the pointer to this directory, so that TIFFLinkDirectory
            // will cause it to be added after this directories current pre-link.

            // Is it the first directory in the file?
            if(tif.tif_header.tiff_diroff==tif.tif_diroff)
            {
                tif.tif_header.tiff_diroff=0;
                tif.tif_diroff=0;

                TIFFSeekFile(tif, (uint)(TIFF_MAGIC_SIZE+TIFF_VERSION_SIZE), SEEK.SET);
                if(!WriteOK(tif, tif.tif_header.tiff_diroff))
                {
                    TIFFErrorExt(tif.tif_clientdata, tif.tif_name, "Error updating TIFF header");
                    return true;
                }
            }
            else
            {
                uint nextdir=tif.tif_header.tiff_diroff;
                do
                {
                    ushort dircount;
                    if(!SeekOK(tif, nextdir)||!ReadOK(tif, out dircount))
                    {
                        TIFFErrorExt(tif.tif_clientdata, module, "Error fetching directory count");
                        return false;
                    }

                    if((tif.tif_flags&TIF_FLAGS.TIFF_SWAB)!=0) TIFFSwab(ref dircount);
                    TIFFSeekFile(tif, (uint)dircount*12, SEEK.CUR);

                    if(!ReadOK(tif, out nextdir))
                    {
                        TIFFErrorExt(tif.tif_clientdata, module, "Error fetching directory link");
                        return false;
                    }

                    if((tif.tif_flags&TIF_FLAGS.TIFF_SWAB)!=0) TIFFSwab(ref nextdir);
                } while(nextdir!=tif.tif_diroff&&nextdir!=0);

                uint off=TIFFSeekFile(tif, 0, SEEK.CUR); // get current offset
                TIFFSeekFile(tif, off-4, SEEK.SET);
                tif.tif_diroff=0;
                if(!WriteOK(tif, tif.tif_diroff))
                {
                    TIFFErrorExt(tif.tif_clientdata, module, "Error writing directory link");
                    return false;
                }
            }

            // Now use TIFFWriteDirectory() normally.
            return TIFFWriteDirectory(tif);
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:64,代码来源:tif_dirwrite.cs

示例7: TIFFNewScanlineSize

        // Return the number of bytes to read/write in a call to
        // one of the scanline-oriented i/o routines. Note that
        // this number may be 1/samples-per-pixel if data is
        // stored as separate planes.
        // The ScanlineSize in case of YCbCrSubsampling is defined as the
        // strip size divided by the strip height, i.e. the size of a pack of vertical
        // subsampling lines divided by vertical subsampling. It should thus make
        // sense when multiplied by a multiple of vertical subsampling.
        // Some stuff depends on this newer version of TIFFScanlineSize
        // TODO: resolve this
        public static int TIFFNewScanlineSize(TIFF tif)
        {
            TIFFDirectory td=tif.tif_dir;
            uint scanline;

            if(td.td_planarconfig==PLANARCONFIG.CONTIG)
            {
                if(td.td_photometric==PHOTOMETRIC.YCBCR&&!isUpSampled(tif))
                {
                    object[] ap=new object[2];

                    TIFFGetField(tif, TIFFTAG.YCBCRSUBSAMPLING, ap);
                    ushort[] ycbcrsubsampling=new ushort[2];
                    ycbcrsubsampling[0]=__GetAsUshort(ap, 0);
                    ycbcrsubsampling[1]=__GetAsUshort(ap, 1);

                    if(ycbcrsubsampling[0]*ycbcrsubsampling[1]==0)
                    {
                        TIFFErrorExt(tif.tif_clientdata, tif.tif_name, "Invalid YCbCr subsampling");
                        return 0;
                    }

                    return (int)(((((td.td_imagewidth+ycbcrsubsampling[0]-1)/ycbcrsubsampling[0])*(ycbcrsubsampling[0]*ycbcrsubsampling[1]+2)*td.td_bitspersample+7)/8)/ycbcrsubsampling[1]);
                }
                else scanline=multiply(tif, td.td_imagewidth, td.td_samplesperpixel, "TIFFScanlineSize");
            }
            else scanline=td.td_imagewidth;

            return (int)TIFFhowmany8(multiply(tif, scanline, td.td_bitspersample, "TIFFScanlineSize"));
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:40,代码来源:tif_strip.cs

示例8: GTIFNew

		//*********************************************************************
		//
		//							Public Routines
		//
		//*********************************************************************

		// Given an open TIFF file, look for GTIF keys and values and return GTIF structure.
		//
		// This function creates a GeoTIFF information interpretation handle
		// (GTIF) based on a passed in TIFF handle originally from
		// XTIFFOpen().
		//
		// The returned GTIF handle can be used to read or write GeoTIFF tags
		// using the various GTIF functions. The handle should be destroyed using
		// GTIFFree() before the file is closed with TIFFClose().
		//
		// If the file accessed has no GeoTIFF keys, an valid (but empty) GTIF is
		// still returned. GTIFNew() is used both for existing files being read, and
		// for new TIFF files that will have GeoTIFF tags written to them.

		public static GTIF GTIFNew(TIFF tif)
		{
			TIFFMethod default_methods=new TIFFMethod();
			_GTIFSetDefaultTIFF(default_methods);

			return GTIFNewWithMethods(tif, default_methods);
		}
开发者ID:LogoPhonix,项目名称:libgeotiff.net,代码行数:27,代码来源:geo_new.cs

示例9: TIFFGetClientInfo

 public static object TIFFGetClientInfo(TIFF tif, string name)
 {
     foreach(TIFFClientInfoLink link in tif.tif_clientinfo)
     {
         if(link.name==name) return link.data;
     }
     return null;
 }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:8,代码来源:tif_extension.cs

示例10: TIFFCheckpointDirectory

        // Similar to TIFFWriteDirectory(), writes the directory out
        // but leaves all data structures in memory so that it can be
        // written again. This will make a partially written TIFF file
        // readable before it is successfully completed/closed.
        public static bool TIFFCheckpointDirectory(TIFF tif)
        {
            // Setup the strips arrays, if they haven't already been.
            if(tif.tif_dir.td_stripoffset==null) TIFFSetupStrips(tif);

            bool rc=TIFFWriteDirectory(tif, false);
            TIFFSetWriteOffset(tif, TIFFSeekFile(tif, 0, SEEK.END));
            return rc;
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:13,代码来源:tif_dirwrite.cs

示例11: TIFFInitZIP

        static bool TIFFInitZIP(TIFF tif, COMPRESSION scheme)
        {
            string module="TIFFInitZIP";

            #if DEBUG
            if(scheme!=COMPRESSION.DEFLATE&&scheme!=COMPRESSION.ADOBE_DEFLATE) throw new Exception("scheme!=COMPRESSION.DEFLATE&&scheme!=COMPRESSION.ADOBE_DEFLATE");
            #endif

            // Merge codec-specific tag information.
            if(!_TIFFMergeFieldInfo(tif, zipFieldInfo))
            {
                TIFFErrorExt(tif.tif_clientdata, module, "Merging Deflate codec-specific tags failed");
                return false;
            }

            // Allocate state block so tag methods have storage to record values.
            ZIPState sp=null;
            try
            {
                tif.tif_data=sp=new ZIPState();
                sp.stream=new zlib.z_stream();
            }
            catch
            {
                TIFFErrorExt(tif.tif_clientdata, module, "No space for ZIP state block");
                return false;
            }

            // Override parent get/set field methods.
            sp.vgetparent=tif.tif_tagmethods.vgetfield;
            tif.tif_tagmethods.vgetfield=ZIPVGetField; // hook for codec tags
            sp.vsetparent=tif.tif_tagmethods.vsetfield;
            tif.tif_tagmethods.vsetfield=ZIPVSetField; // hook for codec tags

            // Default values for codec-specific fields
            sp.zipquality=zlib.Z_DEFAULT_COMPRESSION; // default comp. level
            sp.state=ZSTATE.None;

            // Install codec methods.
            tif.tif_setupdecode=ZIPSetupDecode;
            tif.tif_predecode=ZIPPreDecode;
            tif.tif_decoderow=ZIPDecode;
            tif.tif_decodestrip=ZIPDecode;
            tif.tif_decodetile=ZIPDecode;
            tif.tif_setupencode=ZIPSetupEncode;
            tif.tif_preencode=ZIPPreEncode;
            tif.tif_postencode=ZIPPostEncode;
            tif.tif_encoderow=ZIPEncode;
            tif.tif_encodestrip=ZIPEncode;
            tif.tif_encodetile=ZIPEncode;
            tif.tif_cleanup=ZIPCleanup;

            // Setup predictor setup.
            TIFFPredictorInit(tif);
            return true;
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:56,代码来源:tif_zip.cs

示例12: TIFFComputeStrip

        // Compute which strip a (row, sample) value is in.
        public static int TIFFComputeStrip(TIFF tif, uint row, ushort sample)
        {
            TIFFDirectory td=tif.tif_dir;
            uint strip;

            strip=row/td.td_rowsperstrip;
            if(td.td_planarconfig==PLANARCONFIG.SEPARATE)
            {
                if(sample>=td.td_samplesperpixel)
                {
                    TIFFErrorExt(tif.tif_clientdata, tif.tif_name, "{0}: Sample out of range, max {1}", sample, td.td_samplesperpixel);
                    return 0;
                }
                strip+=sample*td.td_stripsperimage;
            }
            return (int)strip;
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:18,代码来源:tif_strip.cs

示例13: fpAcc

        // Floating point predictor accumulation routine.
        static unsafe void fpAcc(TIFF tif, byte[] cp0, int cp0_offset, int cc)
        {
            int stride=((TIFFPredictorState)tif.tif_data).stride;
            int bps=tif.tif_dir.td_bitspersample/8;
            int wc=cc/bps;
            int count=cc;

            byte[] tmp=null;
            try
            {
                tmp=new byte[cc];
            }
            catch
            {
                return;
            }

            fixed(byte* cp0_=cp0)
            {
                byte* cp=cp0_+cp0_offset;

                while(count>stride)
                {
                    //was REPEAT4(stride, cp[stride]+=*(cp++));
                    switch(stride)
                    {
                        default: for(int i=stride-4; i>0; i--) cp[stride]+=*(cp++); goto case 4;
                        case 4: cp[stride]+=*(cp++); goto case 3;
                        case 3: cp[stride]+=*(cp++); goto case 2;
                        case 2: cp[stride]+=*(cp++); goto case 1;
                        case 1: cp[stride]+=*(cp++); break;
                        case 0: break;
                    }
                    count-=stride;
                }

                Array.Copy(cp0, cp0_offset, tmp, 0, cc);
                cp=cp0_+cp0_offset;
                for(count=0; count<wc; count++)
                {
                    for(uint b=0; b<bps; b++) cp[bps*count+b]=tmp[(bps-b-1)*wc+count];
                }
            }
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:45,代码来源:tif_predict.cs

示例14: TIFFSetClientInfo

        public static void TIFFSetClientInfo(TIFF tif, object data, string name)
        {
            // Do we have an existing link with this name? If so, just
            // set it.
            foreach(TIFFClientInfoLink link in tif.tif_clientinfo)
            {
                if(link.name==name)
                {
                    link.data=data;
                    return;
                }
            }

            // Create a new link.
            TIFFClientInfoLink newlink=new TIFFClientInfoLink();
            newlink.name=name;
            newlink.data=data;

            tif.tif_clientinfo.Add(newlink);
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:20,代码来源:tif_extension.cs

示例15: TIFFFillStrip

        const uint NOTILE = 0xffffffff; // undefined state

        #endregion Fields

        #region Methods

        // Read the specified strip and setup for decoding.
        // The data buffer is expanded, as necessary, to
        // hold the strip's data.
        public static bool TIFFFillStrip(TIFF tif, uint strip)
        {
            string module="TIFFFillStrip";
            TIFFDirectory td=tif.tif_dir;

            if((tif.tif_flags&TIF_FLAGS.TIFF_NOREADRAW)==0)
            {
                // FIXME: butecount should have tsize_t type, but for now
                // libtiff defines tsize_t as a signed 32-bit integer and we
                // are losing ability to read arrays larger than 2^31 bytes.
                // So we are using uint32 instead of tsize_t here.
                uint bytecount=td.td_stripbytecount[strip];

                if(bytecount<=0)
                {
                    TIFFErrorExt(tif.tif_clientdata, tif.tif_name, "{0}: Invalid strip byte count, strip {1}", bytecount, strip);
                    return false;
                }

                // Expand raw data buffer, if needed, to
                // hold data strip coming from file
                // (perhaps should set upper bound on
                // the size of a buffer we'll use?).
                if(bytecount>tif.tif_rawdatasize)
                {
                    tif.tif_curstrip=NOSTRIP;
                    if((tif.tif_flags&TIF_FLAGS.TIFF_MYBUFFER)==0)
                    {
                        TIFFErrorExt(tif.tif_clientdata, module, "{0}: Data buffer too small to hold strip {1}", tif.tif_name, strip);
                        return false;
                    }

                    if(!TIFFReadBufferSetup(tif, null, (int)TIFFroundup(bytecount, 1024))) return false;
                }
                if((uint)TIFFReadRawStrip1(tif, strip, tif.tif_rawdata, (int)bytecount, module)!=bytecount) return false;

                if(!isFillOrder(tif, td.td_fillorder)&&(tif.tif_flags&TIF_FLAGS.TIFF_NOBITREV)==0)
                    TIFFReverseBits(tif.tif_rawdata, (uint)bytecount);
            }
            return TIFFStartStrip(tif, strip);
        }
开发者ID:JoshDullen,项目名称:libtiffN,代码行数:50,代码来源:tif_read.cs


注:本文中的Free.Ports.LibTiff.TIFF类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。