Mercurial > projects > dstep
diff dstep/qtkit/QTSampleBuffer.d @ 16:19885b43130e
Huge update, the bridge actually works now
author | Jacob Carlborg <doob@me.com> |
---|---|
date | Sun, 03 Jan 2010 22:06:11 +0100 |
parents | |
children | b9de51448c6b |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/dstep/qtkit/QTSampleBuffer.d Sun Jan 03 22:06:11 2010 +0100 @@ -0,0 +1,179 @@ +/** + * Copyright: Copyright (c) 2009 Jacob Carlborg. + * Authors: Jacob Carlborg + * Version: Initial created: Sep 28, 2009 + * License: $(LINK2 http://www.boost.org/LICENSE_1_0.txt, Boost Software License 1.0) + */ +module dstep.qtkit.QTSampleBuffer; + +import dstep.coreaudio.CoreAudioTypes; +import dstep.foundation.Foundation; +import dstep.objc.bridge.Bridge; +import dstep.objc.objc; +import dstep.qtkit.QTFormatDescription; +import dstep.qtkit.QTKitDefines; +import dstep.qtkit.QTTime; + +import bindings = dstep.qtkit.QTSampleBuffer_bindings; + +alias NSUInteger QTSampleBufferAudioBufferListOptions; + +private +{ + NSString QTSampleBufferSMPTETimeAttribute_; + NSString QTSampleBufferDateRecordedAttribute_; + NSString QTSampleBufferHostTimeAttribute_; + NSString QTSampleBufferSceneChangeTypeAttribute_; + NSString QTSampleBufferExplicitSceneChange_; + NSString QTSampleBufferTimeStampDiscontinuitySceneChange_; +} + +NSString QTSampleBufferSMPTETimeAttribute () +{ + if (QTSampleBufferSMPTETimeAttribute_) + return QTSampleBufferSMPTETimeAttribute_; + + return QTSampleBufferSMPTETimeAttribute_ = new NSString(bindings.QTSampleBufferSMPTETimeAttribute); +} + +NSString QTSampleBufferDateRecordedAttribute () +{ + if (QTSampleBufferDateRecordedAttribute_) + return QTSampleBufferDateRecordedAttribute_; + + return QTSampleBufferDateRecordedAttribute_ = new NSString(bindings.QTSampleBufferDateRecordedAttribute); +} + +NSString QTSampleBufferHostTimeAttribute () +{ + if (QTSampleBufferHostTimeAttribute_) + return QTSampleBufferHostTimeAttribute_; + + return QTSampleBufferHostTimeAttribute_ = new NSString(bindings.QTSampleBufferHostTimeAttribute); +} + +NSString QTSampleBufferSceneChangeTypeAttribute () +{ + if (QTSampleBufferSceneChangeTypeAttribute_) + return QTSampleBufferSceneChangeTypeAttribute_; + + return QTSampleBufferSceneChangeTypeAttribute_ = new NSString(bindings.QTSampleBufferSceneChangeTypeAttribute); +} + +NSString QTSampleBufferExplicitSceneChange () +{ + if (QTSampleBufferExplicitSceneChange_) + return QTSampleBufferExplicitSceneChange_; + + return QTSampleBufferExplicitSceneChange_ = new NSString(bindings.QTSampleBufferExplicitSceneChange); +} + +NSString QTSampleBufferTimeStampDiscontinuitySceneChange () +{ + if (QTSampleBufferTimeStampDiscontinuitySceneChange_) + return QTSampleBufferTimeStampDiscontinuitySceneChange_; + + return QTSampleBufferTimeStampDiscontinuitySceneChange_ = new NSString(bindings.QTSampleBufferTimeStampDiscontinuitySceneChange); +} + +enum +{ + QTSampleBufferAudioBufferListOptionAssure16ByteAlignment = (1L << 0) +} + +const TQTSampleBufferUseCount = ` + + NSUInteger sampleUseCount () + { + return invokeObjcSelf!(NSUInteger, "sampleUseCount"); + } + + void incrementSampleUseCount () + { + return invokeObjcSelf!(void, "incrementSampleUseCount"); + } + + void decrementSampleUseCount () + { + return invokeObjcSelf!(void, "decrementSampleUseCount"); + } + + //mixin ObjcBindMethod!(sampleUseCount, "sampleUseCount"); + //mixin ObjcBindMethod!(incrementSampleUseCount, "incrementSampleUseCount"); + //mixin ObjcBindMethod!(decrementSampleUseCount, "decrementSampleUseCount"); + +`; + +const TQTAudioSampleBuffer = ` + + bool getAudioStreamPacketDescriptions (AudioStreamPacketDescription* audioStreamPacketDescriptions, NSRange range) + { + return invokeObjcSelf!(bool, "getAudioStreamPacketDescriptions:inRange:", AudioStreamPacketDescription*, NSRange)(audioStreamPacketDescriptions, range); + } + + //mixin ObjcBindMethod!(getAudioStreamPacketDescriptions, "getAudioStreamPacketDescriptions:inRange:"); + +`; + +class QTSampleBuffer : NSObject +{ + mixin (ObjcWrap); + + QTFormatDescription formatDescription () + { + return invokeObjcSelf!(QTFormatDescription, "formatDescription"); + } + + QTTime duration () + { + return invokeObjcSelf!(QTTime, "duration"); + } + + QTTime decodeTime () + { + return invokeObjcSelf!(QTTime, "decodeTime"); + } + + QTTime presentationTime () + { + return invokeObjcSelf!(QTTime, "presentationTime"); + } + + NSUInteger numberOfSamples () + { + return invokeObjcSelf!(NSUInteger, "numberOfSamples"); + } + + NSDictionary sampleBufferAttributes () + { + return invokeObjcSelf!(NSDictionary, "sampleBufferAttributes"); + } + + Object attributeForKey (NSString key) + { + return invokeObjcSelf!(Object, "attributeForKey:", NSString)(key); + } + + // QTSampleBufferUseCount + NSUInteger sampleUseCount () + { + return invokeObjcSelf!(NSUInteger, "sampleUseCount"); + } + + void incrementSampleUseCount () + { + return invokeObjcSelf!(void, "incrementSampleUseCount"); + } + + void decrementSampleUseCount () + { + return invokeObjcSelf!(void, "decrementSampleUseCount"); + } + + // QTAudioSampleBuffer + bool getAudioStreamPacketDescriptions (AudioStreamPacketDescription* audioStreamPacketDescriptions, NSRange range) + { + return invokeObjcSelf!(bool, "getAudioStreamPacketDescriptions:inRange:", AudioStreamPacketDescription*, NSRange)(audioStreamPacketDescriptions, range); + } +} +