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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? avifile.c

?? 瑞星微公司RK27XX系列芯片的SDK開發(fā)包
?? C
?? 第 1 頁 / 共 5 頁
字號:
    AviFseek(AviVideoFile, tmpIndex.dwOffset, SEEK_SET);

    AviFread(&tmpFcc, sizeof(FOURCC), 1, AviVideoFile);

    AviIdxFile->Clus    = tmpIdxFile.Clus;
    AviIdxFile->Offset  = tmpIdxFile.Offset;

    AviVideoFile->Clus  = tmpVideoFile.Clus;
    AviVideoFile->Offset = tmpVideoFile.Offset;

    if (IS_VIDEO_IDX(tmpFcc))
        return 1;

    return 0;
}
/********************************************************************************************
 Func:
  AviFileParsing()
 Description:
  Parse AVI file .
 Param:
  AviFilePointer *aviPointer - avi file pointer.
  MainAVIHeader *avihdr - Pointer of avi file header struct.
 Return:
  0:  Success.
  -1: File format error.
  -2: Not have index.
  -3: Can not find 'movi' chunk.
  -4: Resolution is not supported.
  -5: Codec is not supported.
 Author:
  ljn
 Date:
  2007-9-17 15:53
 Log:

********************************************************************************************/
int AviFileParsing(AviFilePointer *aviPointer, MainAVIHeader *avihdr)
{
    DWORD riffType;
    int   chunkSize;
    int i;
    AVI_FILE *file = aviPointer->AudioData;
    struct
    {
        FOURCC CkID;
        DWORD Size;
        DWORD Type;
    } list;

    /*************************************************
    [1] Read AVI header.
    **************************************************/

    /* Get AVI header list pointer. */
    if (AviGetChunkPointer(file, SIGN_HDRL))
        return AVI_FILE_FORMAT_ERR;

    /* Seek Main AVI header. */
    if (AviSeek(file, SIGN_AVIH) != sizeof(MainAVIHeader))
        return AVI_FILE_FORMAT_ERR;

    /* Read header. */
    if (AviFread(avihdr, sizeof(MainAVIHeader), 1, file) < sizeof(MainAVIHeader))
        return AVI_FILE_FORMAT_ERR;

    /*************************************************
    [2] Check if audio stream is included.
    **************************************************/

    stream_supported_flag.VideoSupportedFlag = TRUE;

    /* We judge by AVI stream number here. It may be wrong. */
    if (avihdr->dwStreams == 1)
    {
        stream_supported_flag.AudioSupportedFlag = FALSE;
    }
    else
    {
        stream_supported_flag.AudioSupportedFlag = TRUE;
    }

    /**************************************************
    [3] Check if resolution and frame rate is supported.
    ***************************************************/

    if ((avihdr->dwWidth > MAX_FRAME_WIDTH) || (avihdr->dwWidth * avihdr->dwHeight > MAX_FRAME_HEIGHT * MAX_FRAME_WIDTH))
        return AVI_FILE_RESOLUTION_ERR;

    /* Max frame rate: 100fps. */
    if (avihdr->dwMicroSecPerFrame < 10000)
        return AVI_FILE_FORMAT_ERR;

    /*************************************************
    [4] Check if index is included.
    **************************************************/

    if ((avihdr->dwFlags & FLAG_INDEX) == 0)
        return AVI_FILE_INDX_ERR;

    /*************************************************
    [5] Read stream header.
    **************************************************/

    aviWavex.nBlockAlign = 0;
    audioSteamID = 1;
    for (i = 0; i < avihdr->dwStreams; i++)
    {

        /* Only two streams(a video stream, an audio stream) are supported now. */
        if (i >= AVI_SUPPORT_STREAM_NUM)
            break;

        /* Seek stream list. */
        do
        {
            if (!AviSeek(file, SIGN_LIST))
                return AVI_FILE_FORMAT_ERR;
            if (AviFread(&riffType, 1, sizeof(riffType), file) < sizeof(riffType))
                return AVI_FILE_FORMAT_ERR;
        }
        while (riffType != SIGN_STRL);

        /* Seek stream header. */
        if (AviSeek(file, SIGN_STRH) != sizeof(AVISTREAMHEADER))
            return AVI_FILE_FORMAT_ERR;

        /* Read stream header. */
        if (AviFread(&aviStrHdr[i], sizeof(AVISTREAMHEADER), 1, file) < sizeof(AVISTREAMHEADER))
            return AVI_FILE_FORMAT_ERR;

        if (aviStrHdr[i].fccType == SIGN_VIDS)
        {

            if (!(chunkSize = AviSeek(file, SIGN_STRF)))
                return AVI_FILE_FORMAT_ERR;

            /* Read wave header. */
            if (AviFread(&aviBmpInfoHdr, sizeof(BITMAPINFOHEADER), 1, file) != sizeof(BITMAPINFOHEADER))
                return AVI_FILE_FORMAT_ERR;

            switch (aviBmpInfoHdr.biCompression)
            {
                case fccDIVX:
                case fccdivx:
                case fccDivX:
                case fccDX50:
                case fccdx50:
                case fccXVID:
                case fccxvid:
                case fccXviD:
                case fccFMP4:
                case fccfmp4:
                case fccMP4V:
                    stream_supported_flag.VideoCodecLib     = VIDEO_CODEC_LIB_XVID;
                    stream_supported_flag.VideoSupportedFlag = TRUE;
                    break;
                case fccdiv3:
                case fccDIV3:
                case fccDIV4:
                case fccdiv4:
                case fccDIV5:
                case fccdiv5:
                case fccDIV6:
                case fccdiv6:
                case fccMP43:
                case fccmp43:
                case fccMP42:
                case fccmp42:
                case fccDIV2:
                case fccAP41:
                    stream_supported_flag.VideoCodecLib     = VIDEO_CODEC_LIB_DIV3;
                    stream_supported_flag.VideoSupportedFlag = TRUE;
                    break;

                case fccMJPG:
                    stream_supported_flag.VideoCodecLib     = VIDEO_CODEC_LIB_MJPG;
                    stream_supported_flag.VideoSupportedFlag = TRUE;
                    break;

                default:
                    stream_supported_flag.VideoCodecLib     = VIDEO_CODEC_LIB_NULL;
                    stream_supported_flag.VideoSupportedFlag = FALSE;
                    return AVI_FILE_VIDEO_CODEC_ERR;

            }
            //----------------------------------------------
            /*
            請注意:讀取完BITMAPINFOHEADER後,不一定就過渡到了AUDIO的STRF,而且也不一定屬于vprp或者indx chunk,
            因此,要特別注意,這里只有chunkSize是可靠的!
            */
            AviFseek(file, chunkSize - sizeof(BITMAPINFOHEADER), SEEK_CUR);
            //----------------------------------------------
        }
        else if (aviStrHdr[i].fccType == SIGN_AUDS)
        {
            /* Audio stream header. */

            audioSteamID = i;

            /******************************
             Read wave format header.
            *******************************/

            /* Seek strf. */
            if (!AviSeek(file, SIGN_STRF))
                return AVI_FILE_FORMAT_ERR;

            /* Read wave header. */
            if (AviFread(&aviWavex, sizeof(WAVEFORMATEX), 1, file) < sizeof(WAVEFORMATEX))
                return AVI_FILE_FORMAT_ERR;

            /* Check audio codec. */
            if(!((aviWavex.wFormatTag == SIGN_WAVE_FORMAT_MPEG)||(aviWavex.wFormatTag == SIGN_WAVE_FORAMT_MPEGLAYER3)
            	||(aviWavex.wFormatTag == SIGN_WAVE_FORAMT_AC3)||(aviWavex.wFormatTag == SIGN_WAVE_FORAMT_ADPCM)
            	||(aviWavex.wFormatTag == SIGN_WAVE_FORAMT_PCM)))   //check audio codec
                stream_supported_flag.AudioSupportedFlag = FALSE;

            if (stream_supported_flag.VideoCodecLib == VIDEO_CODEC_LIB_MJPG)
                if (aviWavex.wFormatTag == SIGN_WAVE_FORAMT_ADPCM)
                {
                    stream_supported_flag.AudioSupportedFlag = TRUE;
                    aviStrHdr[i].dwSampleSize = 0; // 解決FFD/FFW錯誤
                }
        }
    }

    /* MJPG only support 320x240 */
    if (stream_supported_flag.VideoCodecLib == VIDEO_CODEC_LIB_MJPG)
    {
        long avi_width, avi_height;

        AviGetResolution(&avi_width, &avi_height);
        if (avi_width != 320 || avi_height != 240)
            return AVI_FILE_VIDEO_CODEC_ERR;
    }

    /*************************************************
    [6] Get file pointer of 'idx1'.
    **************************************************/

    /*Get file pointer of 'idx1' for audio. */
    if (AviGetChunkPointer(aviPointer->AudioIndex, SIGN_IDX1))
        return AVI_FILE_INDX_ERR;

    /* Get file pointer of 'idx1' for video. */
#ifdef ON_RKFS
    aviPointer->VideoIndex->Clus = aviPointer->AudioIndex->Clus;
    aviPointer->VideoIndex->Offset = aviPointer->AudioIndex->Offset;
#else
    if (AviGetChunkPointer(aviPointer->VideoIndex, SIGN_IDX1))
        return AVI_FILE_INDX_ERR;
#endif

    /*************************************************
    [7] Get file pointer of 'movi'.
    **************************************************/

    /* Get file pointer of 'movi' for audio. */
    if (AviGetChunkPointer(aviPointer->AudioData, SIGN_MOVI))
        return AVI_FILE_NO_MOVI_CHUNK;

    /* Seek to start of bit stream. */
    AviFseek(aviPointer->AudioData, 4, SEEK_CUR);

    /* Get file pointer of 'movi' for video. */
#ifdef ON_RKFS
    aviPointer->VideoData->Clus = aviPointer->AudioData->Clus;
    aviPointer->VideoData->Offset = aviPointer->AudioData->Offset;
#else
    if (AviGetChunkPointer(aviPointer->VideoData, SIGN_MOVI))
        return AVI_FILE_NO_MOVI_CHUNK;
    /* Seek to start of bit stream. */
    AviFseek(aviPointer->VideoData, 4, SEEK_CUR);
#endif

    /*************************************************
    [8] Initialize.
    **************************************************/
    idx1Pos.Clus = aviPointer->VideoIndex->Clus;
    idx1Pos.Offset = aviPointer->VideoIndex->Offset;
#if 0
    if (AviIdxOffset(aviPointer->VideoIndex))
    {
        AviFseek(aviPointer->VideoData, 8, SEEK_SET);
    }
#else
    if (IsOdmlAvi(aviPointer->VideoIndex, aviPointer->VideoData))
    {
        AviFseek(aviPointer->VideoData, 8, SEEK_SET);
    }
#endif
#ifdef ON_RKFS
    /* Initialize file position information. */
    moviPos.Clus = aviPointer->VideoData->Clus;
    moviPos.Offset = aviPointer->VideoData->Offset;

    /* Initialize video data position information, which is used for ffd/ffw. */
    videoDataPosInfo[0].Clus = moviPos.Clus;
    videoDataPosInfo[0].Offset = moviPos.Offset;

    /* Initialize audio index position information, which is used for ffd/ffw. */
    audioIndexPosInfo[0].filePos.Clus = aviPointer->VideoIndex->Clus;
    audioIndexPosInfo[0].filePos.Offset = aviPointer->VideoIndex->Offset;
    audioIndexPosInfo[0].audioBytePos = 0;
    for (i = 0; i < AVI_AUDIO_POS_INFO_NUM; i ++)
    {
        audioIndexPosInfo[i].streamChunkNum = 0;
    }
#endif

    /* Initialize current chunk information. */
    aviPointer->Video->ReadSize = 0;
    aviPointer->Video->CurOffset = 0;
    aviPointer->Video->CurChunkSize = 0;
    aviPointer->Audio->ReadSize = 0;
    aviPointer->Audio->CurOffset = 0;
    aviPointer->Audio->CurChunkSize = 0;

    /* Initialize chunk number. */
    aviPointer->KeyFrameNum = 0;
    aviPointer->TotalChunkNum = 0;
    aviPointer->VideoChunkNum = 0;
    aviPointer->AudioChunkNum = 0;

    /* Initialize avi gobal variables. */
    beingSkip = AVI_FRAME_SKIP_NONE;  //Skip_mode 2 @LJN
    skipResume = AVI_RESUME_OK;
    audioBytePos = 0;
    lastSkipPoint = 0;

    /**********************************************
    [NOTE] It may be wrong to calculate total audio
           chunk number in this method.
    ***********************************************/
    if (stream_supported_flag.AudioSupportedFlag == TRUE)
    {
        audioChunkNum = (indexSize / (sizeof(idx1))) - avih.dwTotalFrames;
        if (!audioChunkNum)
        {
            audioChunkNum = 1;
        }
        else if (audioChunkNum > (indexSize / (sizeof(idx1))))
        {
            audioChunkNum = (indexSize / (sizeof(idx1)));
        }
        //audioTimePerChunk = (((avih.dwMicroSecPerFrame + 4)>>3)*avih.dwTotalFrames + (audioChunkNum >> 1))/(audioChunkNum-1);
    }
    else
    {
        audioChunkNum = 1;

    }

    /* Create seek table. */
#ifdef  SEEK_TABLE
    AviCreateSeekTab(aviPointer, indexSize);
    if (totalKeyFrmNum == 0)
        return AVI_FILE_INDX_ERR;

    /* reset index file pointer */
#ifdef ON_RKFS
    aviPointer->VideoIndex->Clus = idx1Pos.Clus;
    aviPointer->VideoIndex->Offset = idx1Pos.Offset;
    aviPointer->AudioIndex->Clus = idx1Pos.Clus;
    aviPointer->AudioIndex->Offset = idx1Pos.Offset;
    aviPointer->VideoData->Clus = moviPos.Clus;
    aviPointer->VideoData->Offset = moviPos.Offset;
#else
    if (AviGetChunkPointer(aviPointer->AudioIndex, SIGN_IDX1))
        return AVI_FILE_INDX_ERR;
    if (AviGetChunkPointer(aviPointer->AudioIndex, SIGN_IDX1))

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品一区二区在线播放| 国产欧美一区在线| 国产成人自拍在线| 午夜不卡av免费| 国产精品超碰97尤物18| 精品国产自在久精品国产| 欧美视频一区二区三区在线观看| 国产v综合v亚洲欧| 蜜桃一区二区三区四区| 亚洲黄色录像片| 亚洲国产高清在线观看视频| 日韩欧美国产wwwww| 欧美顶级少妇做爰| 欧美在线不卡一区| av不卡在线观看| 国产麻豆9l精品三级站| 蜜臀av性久久久久蜜臀aⅴ流畅 | 精品国产污污免费网站入口| 91国内精品野花午夜精品 | 99九九99九九九视频精品| 蜜臀久久久久久久| 亚洲一区二区视频在线观看| 日韩美女久久久| 国产精品免费久久| 国产精品网曝门| 精品国产a毛片| 欧美va天堂va视频va在线| 91精品视频网| 欧美一区二区三级| 日韩情涩欧美日韩视频| 7799精品视频| 91精品国产一区二区三区蜜臀| 欧美日韩三级视频| 欧美中文字幕不卡| 欧美午夜宅男影院| 欧美日韩国产首页在线观看| 欧洲另类一二三四区| 色婷婷精品大在线视频| 色狠狠色狠狠综合| 欧美视频在线一区| 7777精品伊人久久久大香线蕉完整版 | 精品少妇一区二区三区免费观看| 在线视频一区二区三| 一本色道久久综合亚洲91 | 精品一区二区三区在线观看国产| 琪琪一区二区三区| 美女一区二区三区| 国产一区二区不卡老阿姨| 国产一区二区精品在线观看| 国产精品中文字幕一区二区三区| 国产成人aaaa| 色诱视频网站一区| 91福利视频久久久久| 欧美亚洲一区二区三区四区| 欧美日韩精品一区二区三区四区| 91 com成人网| 久久久久久久久久电影| 中文字幕日韩精品一区| 亚洲综合色噜噜狠狠| 日本一不卡视频| 国产乱子轮精品视频| 99综合电影在线视频| 在线观看日韩高清av| 91精品免费观看| 久久九九久精品国产免费直播| 国产精品免费aⅴ片在线观看| 亚洲精品亚洲人成人网在线播放| 亚洲福利电影网| 韩国v欧美v日本v亚洲v| 93久久精品日日躁夜夜躁欧美| 91行情网站电视在线观看高清版| 欧美绝品在线观看成人午夜影视| 精品国产成人在线影院| 亚洲免费视频成人| 美女被吸乳得到大胸91| 99久精品国产| 日韩久久久精品| 国产精品国产三级国产| 奇米影视在线99精品| 成人小视频在线观看| 337p亚洲精品色噜噜噜| 久久久噜噜噜久噜久久综合| 亚洲精品自拍动漫在线| 精彩视频一区二区三区| 在线观看日韩电影| 国产欧美日韩不卡免费| 亚洲午夜一区二区| 丰满放荡岳乱妇91ww| 91麻豆精品国产91| 17c精品麻豆一区二区免费| 美国毛片一区二区| 欧洲精品视频在线观看| 久久亚洲春色中文字幕久久久| 亚洲午夜激情av| 成人国产一区二区三区精品| 欧美刺激午夜性久久久久久久 | 亚洲精品视频在线| 国产一区二区伦理| 欧美精品1区2区| 亚洲色图视频网站| 国产精品亚洲第一区在线暖暖韩国| 欧亚一区二区三区| 国产精品久久久久久久久果冻传媒| 蜜臀av一区二区在线观看| 欧洲人成人精品| 国产精品初高中害羞小美女文| 国产在线不卡视频| 日韩视频一区二区| 日韩综合在线视频| 欧美体内she精高潮| 国产精品国产三级国产普通话蜜臀| 久久国内精品视频| 日韩一区二区三免费高清| 一区二区三区波多野结衣在线观看| 国产成人aaaa| 国产网站一区二区| 国产揄拍国内精品对白| 欧美成人激情免费网| 秋霞午夜鲁丝一区二区老狼| 欧美亚州韩日在线看免费版国语版| 中文字幕一区二区三区不卡在线| 国产精品伊人色| 久久亚区不卡日本| 激情文学综合丁香| 欧美一区二区三区在线观看视频| 午夜伦理一区二区| 欧美日韩国产三级| 午夜精彩视频在线观看不卡| 欧美伊人久久大香线蕉综合69| 一区二区三区日韩| 色视频成人在线观看免| 亚洲女子a中天字幕| 91色|porny| 夜夜亚洲天天久久| 欧美亚洲免费在线一区| 一区二区三区四区在线免费观看 | 亚洲国产美国国产综合一区二区| 色哟哟国产精品免费观看| 一区二区三区四区蜜桃| 欧美性淫爽ww久久久久无| 亚洲午夜一区二区| 欧美一区二区在线免费观看| 日韩国产高清影视| 欧美mv日韩mv国产网站| 国产成人av福利| 国产精品剧情在线亚洲| 9色porny自拍视频一区二区| 艳妇臀荡乳欲伦亚洲一区| 欧美日韩不卡一区| 蜜臀国产一区二区三区在线播放| 精品国产一区二区三区忘忧草| 国产一区二区精品久久91| 亚洲高清中文字幕| 欧美一卡二卡三卡四卡| 狠狠色综合日日| 国产精品福利在线播放| 欧美性xxxxxxxx| 看国产成人h片视频| 亚洲国产高清在线观看视频| 91精品福利在线| 免费一级片91| 国产精品天美传媒| 欧美日韩精品一区二区| 国产一区福利在线| 亚洲啪啪综合av一区二区三区| 欧美巨大另类极品videosbest| 国产一区二区免费在线| 一区二区三区自拍| 日韩欧美精品在线视频| 99热在这里有精品免费| 午夜精品一区二区三区三上悠亚 | 亚洲国产精品久久艾草纯爱| 精品欧美黑人一区二区三区| 成人动漫一区二区在线| 香蕉久久夜色精品国产使用方法 | 欧美男生操女生| 国产伦精一区二区三区| 一区二区三区视频在线观看| 日韩精品一区二区三区视频在线观看 | 欧美福利电影网| 国产精品99久| 丝袜美腿高跟呻吟高潮一区| 国产欧美一区二区精品秋霞影院 | 欧美久久久久久蜜桃| 国产成人免费视频网站高清观看视频| 亚洲乱码国产乱码精品精小说| 欧美α欧美αv大片| 色一情一伦一子一伦一区| 狠狠色丁香久久婷婷综合丁香| 亚洲精品午夜久久久| 久久亚洲一区二区三区明星换脸 | 欧美成人vps| 欧美午夜精品免费| 丰满少妇在线播放bd日韩电影| 日韩精品免费视频人成| 亚洲精品日韩一| 国产欧美一区二区精品性色| 日韩欧美在线123| 欧美精三区欧美精三区| 日本道色综合久久|