cog/Sound/SoundFile/WavPackFile.m

87 lines
1.6 KiB
Matlab
Raw Normal View History

2005-06-06 17:47:29 +00:00
//
// WavPackFile.m
// Cog
//
2005-07-02 21:02:06 +00:00
// Created by Vincent Spader on 6/6/05.
// Copyright 2005 Vincent Spader All rights reserved.
2005-06-06 17:47:29 +00:00
//
#import "WavPackFile.h"
@implementation WavPackFile
- (BOOL)open:(const char *)filename
{
int open_flags = 0;
char error[80];
wpc = WavpackOpenFileInput(filename, error, open_flags, 0);
if (!wpc)
return NO;
channels = WavpackGetNumChannels(wpc);
2006-04-21 20:43:47 +00:00
bitsPerSample = WavpackGetBitsPerSample(wpc);
// bitsPerSample = 32;
NSLog(@"BYTES PER SAMPLE: %i", WavpackGetBitsPerSample(wpc));
NSLog(@"BYTES PER SAMPLE: %i", WavpackGetBytesPerSample(wpc));
2005-06-29 15:28:20 +00:00
frequency = WavpackGetSampleRate(wpc);
2005-06-06 17:47:29 +00:00
int samples;
samples = WavpackGetNumSamples(wpc);
2006-04-25 20:20:11 +00:00
totalSize = samples * channels * (bitsPerSample/8);
2005-06-06 17:47:29 +00:00
bitRate = (int)(WavpackGetAverageBitrate(wpc, TRUE)/1000.0);
2006-04-21 20:43:47 +00:00
isBigEndian = hostIsBigEndian();
2005-06-06 17:47:29 +00:00
return YES;
}
- (BOOL)readInfo:(const char *)filename
{
2005-06-29 15:28:20 +00:00
[self open:filename]; //does the same damn thing
return YES;
2005-06-06 17:47:29 +00:00
}
- (int)fillBuffer:(void *)buf ofSize:(UInt32)size
{
int numsamples;
int n;
2006-04-21 20:43:47 +00:00
void *sampleBuf = malloc(size*2);
2005-06-06 17:47:29 +00:00
2006-04-21 20:43:47 +00:00
numsamples = size/(bitsPerSample/8)/channels;
2005-06-06 17:47:29 +00:00
// DBLog(@"NUM SAMPLES: %i %i", numsamples, size);
2006-04-21 20:43:47 +00:00
n = WavpackUnpackSamples(wpc, sampleBuf, numsamples);
2005-06-06 17:47:29 +00:00
2005-06-29 15:28:20 +00:00
int i;
2006-04-21 20:43:47 +00:00
for (i = 0; i < n*channels; i++)
2005-06-29 15:28:20 +00:00
{
2006-04-21 20:43:47 +00:00
((UInt16 *)buf)[i] = ((UInt32 *)sampleBuf)[i];
2005-06-29 15:28:20 +00:00
}
2006-04-21 20:43:47 +00:00
n *= (bitsPerSample/8)*channels;
2005-06-29 15:28:20 +00:00
2006-04-28 23:19:14 +00:00
free(sampleBuf);
2005-06-06 17:47:29 +00:00
return n;
}
- (double)seekToTime:(double)milliseconds
{
int sample;
2006-04-25 20:20:11 +00:00
sample = frequency*(milliseconds/1000.0);
2005-06-06 17:47:29 +00:00
WavpackSeekSample(wpc, sample);
return milliseconds;
}
- (void)close
{
WavpackCloseFile(wpc);
}
@end