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


C++ Wav::ok方法代码示例

本文整理汇总了C++中Wav::ok方法的典型用法代码示例。如果您正苦于以下问题:C++ Wav::ok方法的具体用法?C++ Wav::ok怎么用?C++ Wav::ok使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Wav的用法示例。


在下文中一共展示了Wav::ok方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: loadDir

int SampleHold::loadDir(const string& path)
{
    ProgramState& progstate = ProgramState::instance();

    if(path.size()==0)
    {
        DERROR("path empty");
        return 1;
    }

    FileDir fd;
    bool exist = fd.read(path, false, ".wav", false, false);
    if(!exist)
    {
        DERROR("(E) SampleHold loadDIR(): no such dir!");
        return 1;
    }

    vector<string> files;
    fd.getFiles(files);

    if(files.size()==0)return 0;

    for(unsigned int i=0; i<files.size(); i++)
    {
        Wav w;

        string str=path+files[i];

        //FIXME: better errorchecking!
        Wav::err ret = w.load(str);
        //w.info();

        if(ret==Wav::FILE_NOTFOUND_ERR)continue;

        //something went wrong but probably file does not exist...
        if(!w.ok())
        {
            DERROR("something wrong happend");
            continue;
        }

        WavSample* samp;
        if(w.isStereo())
        {
            SampleValue* l = new SampleValue(w.makeSample(Wav::EXTRACT_LEFT));
            l->setResampleRate(w.getSampleRate(), progstate.getSampleRate());

            SampleValue* r = new SampleValue(w.makeSample(Wav::EXTRACT_RIGHT));
            r->setResampleRate(w.getSampleRate(), progstate.getSampleRate());


            samp = new WavSample(files[i], l,r);
        }
        else
        {
            SampleValue* m = new SampleValue(w.makeSample(Wav::EXTRACT_ALL));
            m->setResampleRate(w.getSampleRate(), progstate.getSampleRate());

            samp = new WavSample(files[i], m);
        }
        samples.push_back(samp);

        w.del();
    }

    return 0;
}
开发者ID:tenso,项目名称:subphonic,代码行数:68,代码来源:g_wav.cpp


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