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

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

?? imageproc.cpp

?? 圖像拼接框架源碼
?? CPP
字號:
#include "ImageProc.h"

//
// Type conversion utilities
//

template <class T1, class T2>
void TypeConvertTyped(T1* src, T2* dst, int n,
                      float scale, float offset,
                      T2 minVal, T2 maxVal)
{
    // This routine does NOT round values when converting from float to int
    const bool scaleOffset = (scale != 1.0f) || (offset != 0.0f);
    const bool clip = (minVal < maxVal);
    if (scaleOffset)
        for (int i = 0; i < n; i++)
        {
            float val = src[i] * scale + offset;
            if (clip)
                val = __min(__max(val, minVal), maxVal);
            dst[i] = (T2) val;
        }
    else if (clip)
        for (int i = 0; i < n; i++)
        {
            dst[i] = (T2) __min(__max(src[i], minVal), maxVal);
        }
    else if (typeid(T1) == typeid(T2))
        memcpy(dst, src, n*sizeof(T2));
    else
        for (int i = 0; i < n; i++)
        {
            dst[i] = (T2) src[i];
        }
}

#if 0
            else
                memcpy(dst, src, n*sizeof(uchar));
#endif

template <class T1, class T2>
void TypeConvert(CImageOf<T1>& src, CImageOf<T2>& dst, float scale, float offset)
{
    // Convert between images of same shape but diffent types
    CShape sShape = src.Shape();
    CShape dShape = dst.Shape();

    // Make sure the shapes (ignoring bands) are compatible
    if (sShape != dShape)
        dst.ReAllocate(sShape);

    // Determine if clipping is required
    T2 minVal = dst.MinVal();
    T2 maxVal = dst.MaxVal();
    if (minVal <= src.MinVal() && maxval >= src.MaxVal())
        minVal = maxVal = 0;

    // Process each row
    for (int y = 0; y < sShape.height; y++)
    {
        TypeConvertLine(&src.Pixel(0, y, 0), &dst.Pixel(0, y, 0),
                        sShape.width, scale, offset, minVal, maxVal);
    }
}

template <class T>
void GrayToRGBA(CImageOf<T>& src, CImageOf<T>& dst)
{
    // Make sure the shapes (ignoring bands) are compatible
    CShape sShape = src.Shape();
    CShape dShape = dst.Shape();
    if (sShape.nBands() != 1)
        throw CError("GrayToRGBA: source image is not single-banded");
    if (! sShape.SameIgnoringNBands(dShape))
    {
        dShape = CShape(sShape.width, sShape.height, 4);
        dst.ReAllocate(dShape);
    }

    // Process each row
    int aC = dst.alphaChannel;
    for (int y = 0; y < sShape.height; y++)
    {
        T* srcP = &src.Pixel(0, y, 0);
        T* dstP = &dst.Pixel(0, y, 0);
        for (int x = 0; x < sShape.width; x++, srcP++)
            for (int b = 0; b < dShape.nBands; b++, dstP++)
                *dstP = (b == aC) ? 255 : *srcP;
    }
}

template <class T>
void RGBAToGray(CImageOf<T>& src, CImageOf<T>& dst)
{
    // Make sure the shapes (ignoring bands) are compatible
    CShape sShape = src.Shape();
    CShape dShape = dst.Shape();
    if (sShape.nBands() != 4)
        throw CError("RGBAToGray: source image is not 4-banded");
    if (! sShape.SameIgnoringNBands(dShape))
        dst.ReAllocate(CShape(sShape.width, sShape.height, 4));
    if (dShape.nBands() != 4)
        throw CError("RGBAToGray: source image is not 4-banded");
    if (src.alphaChannel != 3)
        throw CError("RGBAToGray: source A is not in the 4th band");

    // Process each row
    T minVal = dst.MinVal();
    T maxVal = dst.MaxVal();
    for (int y = 0; y < sShape.height; y++)
    {
        T* srcP = &src.Pixel(0, y, 0);
        T* dstP = &dst.Pixel(0, y, 0);
        for (int x = 0; x < sShape.width; x++, srcP += 4, dstP++)
        {
            RGBA<T>& p = *(RGBA<T> *) srcP;
            float Y = 0.212671 * p.R + 0.715160 * p.G + 0.072169 * p.B;
            dstP = (T) __min(maxVal, __max(minVal, Y));
        }
    }
}

template <class T>
void BandSelect(CImageOf<T>& src, CImageOf<T>& dst, int sBand, int dBand)
{
    // Convert between images of same type but different # of bands
    CShape sShape = src.Shape();
    CShape dShape = dst.Shape();

    // Make sure the shapes (ignoring bands) are compatible
    if (! sShape.SameIgnoringNBands(dShape) || dShape.nBands == 0)
    {
        dShape.width  = sShape.width;
        dShape.height = sShape.height;
        dShape.nBands = (dShape.nBands) ? dShape.nBands : 1;
        dst.ReAllocate(dShape);
    }

    // Check the bands are valid
    int sB = sShape.nBands;
    int dB = dShape.nBands;
    if (sBand < 0 || sBand >= sB)
        throw CError("BandSelect: source band %d is invalid", sBand);
    if (dBand < 0 || dBand >= dB)
        throw CError("BandSelect: destination band %d is invalid", dBand);

    // Process each row
    for (int y = 0; y < sShape.height; y++)
    {
        T* srcP = &src.Pixel(0, y, 0);
        T* dstP = &dst.Pixel(0, y, 0);
        for (int x = 0; x < sShape.width; x++, srcP += sB, dstP += dB)
            dstP[dBand] = srcP[sBand];
    }
}

//
// Helper functions for point and neighborhood processing
//

void PointProcess1(CImage& img1,
                   bool (*fn)(int n, CImage **iptrs, void* p1, int b1))
{
    // Call the line processing function on each line
    CImage *ptr[1] = {&img1};   // pointer for getting at data
    CShape s1 = img1.Shape();
    int w  = s1.width;
    int h  = s1.height;
    int b1 = s1.nBands;
    for (int y = 0; y < s1.height; y++)
    {
        fn(w, ptr, img1.PixelAddress(0, y, 0), b1);
    }
}

//
// Miscellaneous utility routines
//

template <class PixType>
static void CopyPixels(PixType* p1, int s1, PixType* p2, int s2, int w)
{
    s1 /= sizeof(PixType);
    s2 /= sizeof(PixType);
    if (s2 == 1)
    {
        for (int x = 0; x < w; x++, p1 += s1, p2 += s2)
            *p2 = *p1;
    }
    else
    {
        for (int x = 0; x < w; x++, p1 += s1, p2 += s2)
            for (int b = 0; b < s2; b++)
                p2[b] = p1[b];
    }
}

CImage Rotate90(CImage img1, int nTimesCCW)
{
    // Allocate the result image
    nTimesCCW &= 0x3;   // 0, 1, 2, or 3
    CShape s1 = img1.Shape();
    CShape s2((nTimesCCW & 1) ? s1.height : s1.width,
              (nTimesCCW & 1) ? s1.width : s1.height, s1.nBands);
    CImage img2(s2, img1.PixType(), img1.BandSize());

    // Iterate over the output pixels
    //  TODO:  blocking this into tiles could be more efficient...
    for (int y = 0; y < s2.height; y++)
    {
        // Determine the starting location and stride
        int x0, y0, xd, yd;
        switch (nTimesCCW)
        {
        case 0: x0 = 0, y0 = y, xd = 1, yd = 0; break;
        case 1: x0 = s2.height-1-y, y0 = 0, xd = 0, yd = 1; break;
        case 2: x0 = s2.width-1, y0 = s2.height-1-y, xd = -1, yd = 0; break;
        case 3: x0 = y, y0 = s2.width-1, xd = 0, yd = -1; break;
        }
        void* p1a = img1.PixelAddress(x0,    y0,    0);
        void* p1b = img1.PixelAddress(x0+xd, y0+yd, 0);
        void* p2a = img2.PixelAddress(0,     y,     0);
        void* p2b = img2.PixelAddress(1,     y,     0);
        int stride1 = (char *) p1b - (char *) p1a;
        int stride2 = (char *) p2b - (char *) p2a;

        // Copy the pixels using the largest possible unit
        if ((stride2 & -4) == stride2)
            CopyPixels((int *) p1a, stride1, (int *) p2a, stride2, s2.width);
        else if ((stride2 & -2) == stride2)
            CopyPixels((short *) p1a, stride1, (short *) p2a, stride2, s2.width);
        else
            CopyPixels((char *) p1a, stride1, (char *) p2a, stride2, s2.width);
    }

    return img2;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成av人片在线| 亚洲人成在线播放网站岛国| 日韩va欧美va亚洲va久久| 欧美精品久久天天躁| 美女性感视频久久| 26uuu精品一区二区三区四区在线| 蜜臀a∨国产成人精品| 久久久影视传媒| 懂色av中文一区二区三区| 亚洲色图.com| 欧美日韩国产一二三| 久久精品国产澳门| 国产精品进线69影院| 欧美色图在线观看| 免费在线看一区| 欧美激情一区二区在线| 欧美羞羞免费网站| 国产一区二区网址| 亚洲综合一区二区精品导航| 欧美一区二区美女| 成人久久视频在线观看| 亚洲小说欧美激情另类| 精品999在线播放| 91丝袜高跟美女视频| 青青国产91久久久久久| 中文字幕亚洲区| 日韩欧美在线观看一区二区三区| 国产jizzjizz一区二区| 视频一区视频二区中文| 日本一区二区三区在线观看| 欧美在线啊v一区| 国产很黄免费观看久久| 日韩精品亚洲一区二区三区免费| 欧美激情在线看| 欧美一区二区三区播放老司机| 成人av资源站| 免费视频最近日韩| 亚洲国产一区二区a毛片| 中文av一区特黄| 精品精品国产高清a毛片牛牛| 91色porny蝌蚪| 国产精品一级黄| 蜜臀久久久99精品久久久久久| 一区二区三区中文字幕电影| 久久久天堂av| 欧美mv日韩mv亚洲| 欧美理论片在线| 色中色一区二区| bt欧美亚洲午夜电影天堂| 久久99国产精品久久99果冻传媒| 亚洲永久免费视频| 亚洲色图视频免费播放| 亚洲国产激情av| 久久久天堂av| 久久久三级国产网站| 精品久久人人做人人爽| 91精品在线一区二区| 欧美视频在线观看一区| 91福利在线播放| 色视频一区二区| 99精品视频一区二区| 不卡的av中国片| 成人高清免费在线播放| 丁香五精品蜜臀久久久久99网站| 开心九九激情九九欧美日韩精美视频电影| 亚洲国产精品一区二区www在线| 亚洲美腿欧美偷拍| 夜夜嗨av一区二区三区四季av| 亚洲免费在线观看视频| 一区二区免费在线播放| 亚洲精品视频在线看| 亚洲另类在线一区| 亚洲激情欧美激情| 亚洲一区二区综合| 日韩精品一级中文字幕精品视频免费观看 | 亚洲免费在线看| 亚洲欧洲日韩女同| 自拍偷拍亚洲欧美日韩| 亚洲精品美国一| 亚洲国产日韩a在线播放性色| 亚洲综合久久av| 偷拍与自拍一区| 久久精品噜噜噜成人av农村| 韩国视频一区二区| 国产91清纯白嫩初高中在线观看| 国产成人av自拍| av在线播放成人| 91久久奴性调教| 欧美美女一区二区在线观看| 欧美一区日韩一区| 久久久久久久电影| 中文字幕精品一区二区精品绿巨人| 国产精品电影院| 亚洲一二三级电影| 精品一区二区三区在线视频| 国产精品18久久久久久久久 | 99re8在线精品视频免费播放| 97久久精品人人做人人爽50路| 色婷婷av一区二区三区软件| 欧美这里有精品| 日韩三级视频在线看| 国产婷婷精品av在线| 一区二区在线观看视频| 亚洲18女电影在线观看| 久久成人免费日本黄色| aaa欧美日韩| 欧美精品三级在线观看| www亚洲一区| 亚洲男人电影天堂| 麻豆91在线观看| 成人av综合在线| 欧美久久婷婷综合色| 久久日一线二线三线suv| 一区二区三区免费观看| 久久99精品国产.久久久久久 | 欧美精彩视频一区二区三区| 亚洲一区在线电影| 国产精品一色哟哟哟| 欧美自拍偷拍一区| 国产午夜精品在线观看| 亚洲成a人片综合在线| 国产1区2区3区精品美女| 欧美日韩国产综合视频在线观看| 久久久国际精品| 水蜜桃久久夜色精品一区的特点| 国产**成人网毛片九色 | ...av二区三区久久精品| 日韩中文字幕一区二区三区| 99久久免费视频.com| 欧美成人精品3d动漫h| 亚洲精品欧美二区三区中文字幕| 九九**精品视频免费播放| 欧美无乱码久久久免费午夜一区 | 精品国产91洋老外米糕| 亚洲欧美国产毛片在线| 国产精品一卡二卡| 欧美xxxxx裸体时装秀| 亚洲综合自拍偷拍| av中文一区二区三区| 久久亚洲综合av| 久久99在线观看| 日韩一区二区三区四区| 亚洲第一久久影院| 欧美亚洲综合另类| 亚洲天堂2014| 成人av网站在线观看| 久久久久久久久久美女| 久久精品理论片| 日韩一区二区不卡| 日本vs亚洲vs韩国一区三区 | 宅男在线国产精品| 亚洲自拍偷拍九九九| 91麻豆蜜桃一区二区三区| 中文字幕不卡在线播放| 国产99一区视频免费| 精品福利av导航| 精品一区二区久久| 精品日韩成人av| 激情六月婷婷久久| 欧美变态tickling挠脚心| 日韩电影在线观看一区| 欧美妇女性影城| 天天亚洲美女在线视频| 5858s免费视频成人| 日韩精品一级中文字幕精品视频免费观看| 欧美在线你懂的| 三级亚洲高清视频| 日韩欧美中文一区| 精品一区二区三区的国产在线播放 | 麻豆精品视频在线观看视频| 日韩无一区二区| 久国产精品韩国三级视频| 久久一二三国产| 成人丝袜视频网| 亚洲激情自拍偷拍| 欧美性大战xxxxx久久久| 午夜精品视频一区| 日韩精品资源二区在线| 国产综合色视频| 中文字幕视频一区| 欧美亚一区二区| 免费的成人av| 欧美国产日本视频| 欧美综合一区二区| 麻豆高清免费国产一区| 国产日产精品一区| 91精品福利在线| 麻豆高清免费国产一区| 中文字幕国产一区二区| 在线精品视频免费播放| 日本伊人色综合网| 国产色婷婷亚洲99精品小说| 日本精品视频一区二区| 日韩电影在线一区二区| 国产亚洲成aⅴ人片在线观看| 一本色道久久综合亚洲精品按摩| 视频在线观看91| 中文字幕电影一区| 91精品国产综合久久福利软件| 国产成人在线观看免费网站|