X-Git-Url: http://git.kpe.io/?a=blobdiff_plain;f=wdq2wav.h;h=6e740f4e772d7a8b5f7db22b0865764a0bf27b7b;hb=f7a2760c0c2cf784090cf5619a43532804ee079b;hp=e92e1ac6ed12eee201ff32aae34b513322f5ef2e;hpb=b12a849bcbdfc2fdcd6026cab709236587769f42;p=wdq2wav.git diff --git a/wdq2wav.h b/wdq2wav.h index e92e1ac..6e740f4 100644 --- a/wdq2wav.h +++ b/wdq2wav.h @@ -8,7 +8,7 @@ ** ** Copyright (c) 2003 Kevin Rosenberg ** -** $Id: wdq2wav.h,v 1.8 2003/01/21 12:59:56 kevin Exp $ +** $Id$ ** ** This program is free software; you can redistribute it and/or modify ** it under the terms of the GNU General Public License (version 2) as @@ -24,6 +24,7 @@ ** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA ******************************************************************************/ +#include #include #include #include @@ -31,9 +32,22 @@ #include #include #include -#include +#include #include #include +#ifdef WIN32 +#include +#include +#else +#include +#endif + +#ifdef LINUX +#include +#if __BYTE_ORDER == __BIG_ENDIAN +#define WORDS_BIG_ENDIAN 1 +#endif +#endif extern const char* g_szIdStr; extern bool g_quiet; @@ -55,30 +69,37 @@ public: ~WindaqFile (); bool ReadHeader(); - std::string m_strFile; bool m_valid; std::string m_error; int m_fd; - unsigned int m_nChannels; - unsigned int m_nSamples; + bool m_bLegacy_format; + bool m_bHires; + int m_nMaxChannels; + int m_nChannels; + unsigned long int m_nSamples; double m_sample_rate; + std::string m_strFile; unsigned int m_sr_denom, m_sr_numer; unsigned short int m_nHeader_bytes, m_channel_offset, m_nBytes_channel_header; unsigned int m_nData_bytes; unsigned int m_time_acq_start; unsigned int m_time_acq_stop; + double m_time_between_channel_samples; + + bool any_packed_channels(); + bool is_channel_packed(int iChannel); }; -class WindaqChannel +class WindaqChannel { public: - bool m_valid; - unsigned int m_channel; - std::string m_units; + WindaqFile& r_wdq; + signed short int *m_data; double m_slope; double m_intercept; - signed short int *m_data; - WindaqFile& r_wdq; + unsigned int m_channel; + bool m_valid; + std::string m_units; signed short int m_min_raw_data; signed short int m_max_raw_data; double m_max_scaled_data; @@ -92,21 +113,21 @@ public: }; -class WavFile +class WavFile { public: - std::string m_strFile; - int m_fd; bool m_valid; + signed short int* m_data; unsigned long int m_nSamples; + std::string m_strFile; + int m_fd; double m_rate; unsigned int m_nChannels; unsigned int m_nBitsPerSample; unsigned int m_nBytesPerSample; - signed short int* m_data; unsigned long int m_nHeaderBytes; - unsigned long int m_nDataBytes; - unsigned long int m_nFileBytes; + long int m_nDataBytes; + long int m_nFileBytes; WavFile (WindaqChannel& wdq_channel, const char* fname); ~WavFile (); @@ -114,7 +135,14 @@ class WavFile bool WriteFile (); bool Play(); - + private: bool fill_header(); }; + +template +inline T nearest (double x) +{ + return (x > 0 ? + static_cast(x+0.5) : static_cast(x-0.5)); +}