⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 wavrecord.h

📁 Trolltech公司发布的图形界面操作系统。可在qt-embedded-2.3.10平台上编译为嵌入式图形界面操作系统。
💻 H
字号:
/************************************************************************ Copyright (C) 2000-2005 Trolltech AS.  All rights reserved.**** This file is part of the Qtopia Environment.** ** This program is free software; you can redistribute it and/or modify it** under the terms of the GNU General Public License as published by the** Free Software Foundation; either version 2 of the License, or (at your** option) any later version.** ** A copy of the GNU GPL license version 2 is included in this package as ** LICENSE.GPL.**** This program is distributed in the hope that it will be useful, but** WITHOUT ANY WARRANTY; without even the implied warranty of** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. ** See the GNU General Public License for more details.**** In addition, as a special exception Trolltech gives permission to link** the code of this program with Qtopia applications copyrighted, developed** and distributed by Trolltech under the terms of the Qtopia Personal Use** License Agreement. You must comply with the GNU General Public License** in all respects for all of the code used other than the applications** licensed under the Qtopia Personal Use License Agreement. If you modify** this file, you may extend this exception to your version of the file,** but you are not obligated to do so. If you do not wish to do so, delete** this exception statement from your version.** ** See http://www.trolltech.com/gpl/ for GPL licensing information.**** Contact info@trolltech.com if any conditions of this licensing are** not clear to you.************************************************************************/#ifndef WAV_RECORD_H #define WAV_RECORD_H#include <qstring.h>#include <qapplication.h>#include <qtopia/mediarecorderplugininterface.h>class WavRecorderPlugin : public MediaRecorderEncoder {public:    WavRecorderPlugin();    virtual ~WavRecorderPlugin() { end(); }    // About Plugin     int pluginNumFormats() const;    QString pluginFormatName( int format ) const;    QString pluginFormatTag( int format ) const;    QString pluginComment() const { return qApp->translate("WavRecorder", "This plugin is used to record wav files"); }    double pluginVersion() const { return 1.0; }    QString pluginMimeType() const { return "audio/x-wav"; }    // I/O device management    bool begin( QIODevice *device, const QString& formatTag );    bool end();    bool isActive() const { return ( device != 0 ); }    // Audio record functionality    bool setAudioChannels( int channels );    bool setAudioFrequency( int frequency );    bool writeAudioSamples( const short *samples, long numSamples );    // Add comments and other meta information    bool addComment( const QString&, const QString& ) { return TRUE; }    // Space estimation.    long estimateAudioBps( int frequency, int channels, const QString& formatTag );    // Capabilities    bool supportsAudio() const { return TRUE; }    bool supportsVideo() const { return FALSE; }    bool supportsComments() const { return FALSE; }    bool requiresDirectAccess() const { return TRUE; }private:    QIODevice *device;    bool encodeAsGsm;    int start;    int channels;    int frequency;    bool writtenHeader;    long totalSamples;    long totalBytes;    bool byteSwap;    int headerLen;    short gsmBuffer[320];    int gsmPosn;    void *gsmHandle;    // Write byte-swapped data to the I/O device.    int writeByteSwapped( const char *data, uint len );    // Write the wav file header to the I/O device.  Called once    // before outputting the first sample block, and then again    // at the end of recording to update the length values.    bool writeHeader();    // Flush the current GSM block.    void gsmFlush( bool last );};#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -