亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
黄色日韩网站视频| 99久久精品国产导航| 亚洲国产日产av| 国产人成亚洲第一网站在线播放| 精品国产免费一区二区三区香蕉| 色天使久久综合网天天| 在线看国产一区| 日本久久精品电影| 日韩欧美资源站| 欧美国产一区在线| 亚洲欧美怡红院| 午夜欧美在线一二页| 日本大胆欧美人术艺术动态| 日韩成人一区二区| 国产精品一区二区在线播放 | 波多野结衣在线一区| 久久99热国产| 91在线小视频| 久久久噜噜噜久久中文字幕色伊伊 | 国产精品天干天干在观线| 亚洲欧美日韩在线不卡| 精品一二三四区| 91搞黄在线观看| 国产欧美日韩麻豆91| 亚洲综合色区另类av| 国产福利一区二区三区视频| 色婷婷狠狠综合| 精品免费日韩av| 一二三四区精品视频| 青草av.久久免费一区| 成人av免费在线| 日韩一区二区免费高清| 亚洲视频每日更新| 国产成人一区在线| 91精品国产乱| 精品国产成人系列| 视频一区在线播放| 在线观看亚洲成人| 亚洲图片你懂的| 国产电影一区在线| 久久综合色天天久久综合图片| 一区二区三区四区蜜桃| 色婷婷综合久久久中文一区二区| 久久综合久久鬼色| 国产精品一区二区免费不卡| 欧美精品九九99久久| 一区二区三区资源| 欧美日韩国产影片| 免费高清在线视频一区·| 欧美日韩一区二区三区在线看| 亚洲成人精品一区二区| 欧美日韩中文字幕一区| 亚洲高清视频中文字幕| 在线观看91精品国产麻豆| 免费人成精品欧美精品| 久久综合九色综合久久久精品综合| 日本视频中文字幕一区二区三区| 91精品国产综合久久婷婷香蕉| 九九视频精品免费| 中文字幕高清不卡| 在线观看不卡视频| 国产在线一区二区综合免费视频| 亚洲国产成人在线| 欧美日本一道本| 精品夜夜嗨av一区二区三区| 国产精品国产自产拍高清av| 欧美三级一区二区| 午夜精品福利在线| 亚洲天堂精品在线观看| 欧美一区二区女人| 91福利资源站| 国产精品一区一区| 成人午夜激情视频| 欧美在线播放高清精品| 欧美日韩在线一区二区| 欧美高清hd18日本| 欧美在线免费视屏| 日韩三级电影网址| 一区精品在线播放| 午夜欧美2019年伦理| 自拍偷拍国产精品| 91精彩视频在线| 色综合久久88色综合天天免费| 国产精品一区二区在线播放| 婷婷久久综合九色国产成人| 亚洲国产日韩综合久久精品| 亚洲免费观看在线观看| 一区二区三区精品在线| 亚洲一区二区精品视频| 天涯成人国产亚洲精品一区av| 亚洲狠狠爱一区二区三区| 亚洲综合色婷婷| 日韩av电影免费观看高清完整版在线观看 | 99精品一区二区三区| 91在线丨porny丨国产| 91麻豆精品秘密| 欧美男生操女生| 久久伊人蜜桃av一区二区| 久久精品视频一区二区三区| 日本一区二区成人| 亚洲私人影院在线观看| 日本视频一区二区三区| 激情综合色丁香一区二区| 国产精品99久久久久久久女警 | 久久综合九色综合久久久精品综合| 亚洲老妇xxxxxx| 另类小说色综合网站| 成人听书哪个软件好| 伦理电影国产精品| 久久99国产精品尤物| 国产99精品视频| 97aⅴ精品视频一二三区| 在线欧美小视频| 日韩区在线观看| 国产精品网站导航| 日韩综合小视频| 国产精品白丝av| 一本大道久久a久久综合婷婷| 欧美色欧美亚洲另类二区| 日韩一区二区在线观看视频| 国产精品私人自拍| 天堂在线一区二区| 粉嫩嫩av羞羞动漫久久久| 欧美无砖砖区免费| 久久久精品一品道一区| 一区二区欧美国产| 久久成人综合网| 91久久精品日日躁夜夜躁欧美| 欧美一级片免费看| 中文字幕在线观看一区二区| 日韩中文字幕一区二区三区| 高清在线成人网| 欧美日韩www| 欧美国产日韩精品免费观看| 亚洲高清不卡在线观看| 国产精品中文字幕一区二区三区| 欧美中文字幕一区二区三区亚洲| 精品国产一区二区三区久久影院| 亚洲精品福利视频网站| 国产美女av一区二区三区| 91精品国产综合久久久久久久久久| 中文天堂在线一区| 国产在线乱码一区二区三区| 欧美午夜免费电影| 久久精品在线免费观看| 日日夜夜免费精品| 在线视频综合导航| 中文欧美字幕免费| 韩国女主播成人在线观看| 777奇米四色成人影色区| 亚洲人一二三区| 粉嫩av一区二区三区在线播放| 欧美一区二区女人| 午夜视频在线观看一区二区| av高清不卡在线| 国产欧美日韩激情| 国产精品一区二区久久精品爱涩| 欧美一级黄色大片| 日韩精品国产精品| 欧美麻豆精品久久久久久| 一个色综合网站| k8久久久一区二区三区| 欧美国产一区二区在线观看| 国内国产精品久久| 久久美女高清视频| 韩国v欧美v日本v亚洲v| 精品国产91久久久久久久妲己 | 成年人午夜久久久| 欧美激情综合五月色丁香小说| 国产综合久久久久影院| 精品欧美一区二区在线观看| 久草中文综合在线| 精品福利在线导航| 九九视频精品免费| 久久久噜噜噜久久中文字幕色伊伊 | 欧美日韩一区二区三区四区五区 | 91成人看片片| 亚洲一区二区偷拍精品| 欧洲人成人精品| 亚洲国产va精品久久久不卡综合| 欧美午夜精品电影| 婷婷丁香久久五月婷婷| 日韩欧美国产三级| 国产一区在线不卡| 中文在线一区二区| 色狠狠色噜噜噜综合网| 亚洲综合色区另类av| 欧美年轻男男videosbes| 毛片av一区二区三区| 2021中文字幕一区亚洲| 国产成人精品影视| 亚洲欧美激情在线| 欧美色爱综合网| 久久99精品国产| 国产精品国产三级国产a| 欧美三片在线视频观看| 精品一区二区三区香蕉蜜桃 | 中文字幕一区二区三区在线观看| 日本精品一区二区三区高清 | 欧美一区二区三区日韩视频|