module GI.GstVideo.Interfaces.ColorBalance
(
ColorBalance(..) ,
noColorBalance ,
IsColorBalance ,
ColorBalanceGetBalanceTypeMethodInfo ,
colorBalanceGetBalanceType ,
ColorBalanceGetValueMethodInfo ,
colorBalanceGetValue ,
ColorBalanceListChannelsMethodInfo ,
colorBalanceListChannels ,
ColorBalanceSetValueMethodInfo ,
colorBalanceSetValue ,
ColorBalanceValueChangedMethodInfo ,
colorBalanceValueChanged ,
C_ColorBalanceValueChangedCallback ,
ColorBalanceValueChangedCallback ,
ColorBalanceValueChangedSignalInfo ,
afterColorBalanceValueChanged ,
genClosure_ColorBalanceValueChanged ,
mk_ColorBalanceValueChangedCallback ,
noColorBalanceValueChangedCallback ,
onColorBalanceValueChanged ,
wrap_ColorBalanceValueChangedCallback ,
) where
import Data.GI.Base.ShortPrelude
import qualified Data.GI.Base.ShortPrelude as SP
import qualified Data.GI.Base.Overloading as O
import qualified Prelude as P
import qualified Data.GI.Base.Attributes as GI.Attributes
import qualified Data.GI.Base.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
import qualified Data.Text as T
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import qualified Foreign.Ptr as FP
import qualified GI.GstVideo.Enums as GstVideo.Enums
import qualified GI.GstVideo.Objects.ColorBalanceChannel as GstVideo.ColorBalanceChannel
newtype ColorBalance = ColorBalance (ManagedPtr ColorBalance)
noColorBalance :: Maybe ColorBalance
noColorBalance = Nothing
type family ResolveColorBalanceMethod (t :: Symbol) (o :: *) :: * where
ResolveColorBalanceMethod "listChannels" o = ColorBalanceListChannelsMethodInfo
ResolveColorBalanceMethod "valueChanged" o = ColorBalanceValueChangedMethodInfo
ResolveColorBalanceMethod "getBalanceType" o = ColorBalanceGetBalanceTypeMethodInfo
ResolveColorBalanceMethod "getValue" o = ColorBalanceGetValueMethodInfo
ResolveColorBalanceMethod "setValue" o = ColorBalanceSetValueMethodInfo
ResolveColorBalanceMethod l o = O.MethodResolutionFailed l o
instance (info ~ ResolveColorBalanceMethod t ColorBalance, O.MethodInfo info ColorBalance p) => O.IsLabelProxy t (ColorBalance -> p) where
fromLabelProxy _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#if MIN_VERSION_base(4,9,0)
instance (info ~ ResolveColorBalanceMethod t ColorBalance, O.MethodInfo info ColorBalance p) => O.IsLabel t (ColorBalance -> p) where
fromLabel _ = O.overloadedMethod (O.MethodProxy :: O.MethodProxy info)
#endif
type ColorBalanceValueChangedCallback =
GstVideo.ColorBalanceChannel.ColorBalanceChannel ->
Int32 ->
IO ()
noColorBalanceValueChangedCallback :: Maybe ColorBalanceValueChangedCallback
noColorBalanceValueChangedCallback = Nothing
type C_ColorBalanceValueChangedCallback =
Ptr () ->
Ptr GstVideo.ColorBalanceChannel.ColorBalanceChannel ->
Int32 ->
Ptr () ->
IO ()
foreign import ccall "wrapper"
mk_ColorBalanceValueChangedCallback :: C_ColorBalanceValueChangedCallback -> IO (FunPtr C_ColorBalanceValueChangedCallback)
genClosure_ColorBalanceValueChanged :: ColorBalanceValueChangedCallback -> IO Closure
genClosure_ColorBalanceValueChanged cb = do
let cb' = wrap_ColorBalanceValueChangedCallback cb
mk_ColorBalanceValueChangedCallback cb' >>= newCClosure
wrap_ColorBalanceValueChangedCallback ::
ColorBalanceValueChangedCallback ->
Ptr () ->
Ptr GstVideo.ColorBalanceChannel.ColorBalanceChannel ->
Int32 ->
Ptr () ->
IO ()
wrap_ColorBalanceValueChangedCallback _cb _ channel value _ = do
channel' <- (newObject GstVideo.ColorBalanceChannel.ColorBalanceChannel) channel
_cb channel' value
onColorBalanceValueChanged :: (GObject a, MonadIO m) => a -> ColorBalanceValueChangedCallback -> m SignalHandlerId
onColorBalanceValueChanged obj cb = liftIO $ connectColorBalanceValueChanged obj cb SignalConnectBefore
afterColorBalanceValueChanged :: (GObject a, MonadIO m) => a -> ColorBalanceValueChangedCallback -> m SignalHandlerId
afterColorBalanceValueChanged obj cb = connectColorBalanceValueChanged obj cb SignalConnectAfter
connectColorBalanceValueChanged :: (GObject a, MonadIO m) =>
a -> ColorBalanceValueChangedCallback -> SignalConnectMode -> m SignalHandlerId
connectColorBalanceValueChanged obj cb after = liftIO $ do
let cb' = wrap_ColorBalanceValueChangedCallback cb
cb'' <- mk_ColorBalanceValueChangedCallback cb'
connectSignalFunPtr obj "value-changed" cb'' after
instance O.HasAttributeList ColorBalance
type instance O.AttributeList ColorBalance = ColorBalanceAttributeList
type ColorBalanceAttributeList = ('[ ] :: [(Symbol, *)])
data ColorBalanceValueChangedSignalInfo
instance SignalInfo ColorBalanceValueChangedSignalInfo where
type HaskellCallbackType ColorBalanceValueChangedSignalInfo = ColorBalanceValueChangedCallback
connectSignal _ = connectColorBalanceValueChanged
type instance O.SignalList ColorBalance = ColorBalanceSignalList
type ColorBalanceSignalList = ('[ '("valueChanged", ColorBalanceValueChangedSignalInfo)] :: [(Symbol, *)])
class ManagedPtrNewtype a => IsColorBalance a
instance IsColorBalance ColorBalance
instance WrappedPtr ColorBalance where
wrappedPtrCalloc = return nullPtr
wrappedPtrCopy = return
wrappedPtrFree = Nothing
foreign import ccall "gst_color_balance_get_balance_type" gst_color_balance_get_balance_type ::
Ptr ColorBalance ->
IO CUInt
colorBalanceGetBalanceType ::
(B.CallStack.HasCallStack, MonadIO m, IsColorBalance a) =>
a
-> m GstVideo.Enums.ColorBalanceType
colorBalanceGetBalanceType balance = liftIO $ do
balance' <- unsafeManagedPtrCastPtr balance
result <- gst_color_balance_get_balance_type balance'
let result' = (toEnum . fromIntegral) result
touchManagedPtr balance
return result'
data ColorBalanceGetBalanceTypeMethodInfo
instance (signature ~ (m GstVideo.Enums.ColorBalanceType), MonadIO m, IsColorBalance a) => O.MethodInfo ColorBalanceGetBalanceTypeMethodInfo a signature where
overloadedMethod _ = colorBalanceGetBalanceType
foreign import ccall "gst_color_balance_get_value" gst_color_balance_get_value ::
Ptr ColorBalance ->
Ptr GstVideo.ColorBalanceChannel.ColorBalanceChannel ->
IO Int32
colorBalanceGetValue ::
(B.CallStack.HasCallStack, MonadIO m, IsColorBalance a, GstVideo.ColorBalanceChannel.IsColorBalanceChannel b) =>
a
-> b
-> m Int32
colorBalanceGetValue balance channel = liftIO $ do
balance' <- unsafeManagedPtrCastPtr balance
channel' <- unsafeManagedPtrCastPtr channel
result <- gst_color_balance_get_value balance' channel'
touchManagedPtr balance
touchManagedPtr channel
return result
data ColorBalanceGetValueMethodInfo
instance (signature ~ (b -> m Int32), MonadIO m, IsColorBalance a, GstVideo.ColorBalanceChannel.IsColorBalanceChannel b) => O.MethodInfo ColorBalanceGetValueMethodInfo a signature where
overloadedMethod _ = colorBalanceGetValue
foreign import ccall "gst_color_balance_list_channels" gst_color_balance_list_channels ::
Ptr ColorBalance ->
IO (Ptr (GList (Ptr GstVideo.ColorBalanceChannel.ColorBalanceChannel)))
colorBalanceListChannels ::
(B.CallStack.HasCallStack, MonadIO m, IsColorBalance a) =>
a
-> m [GstVideo.ColorBalanceChannel.ColorBalanceChannel]
colorBalanceListChannels balance = liftIO $ do
balance' <- unsafeManagedPtrCastPtr balance
result <- gst_color_balance_list_channels balance'
result' <- unpackGList result
result'' <- mapM (newObject GstVideo.ColorBalanceChannel.ColorBalanceChannel) result'
touchManagedPtr balance
return result''
data ColorBalanceListChannelsMethodInfo
instance (signature ~ (m [GstVideo.ColorBalanceChannel.ColorBalanceChannel]), MonadIO m, IsColorBalance a) => O.MethodInfo ColorBalanceListChannelsMethodInfo a signature where
overloadedMethod _ = colorBalanceListChannels
foreign import ccall "gst_color_balance_set_value" gst_color_balance_set_value ::
Ptr ColorBalance ->
Ptr GstVideo.ColorBalanceChannel.ColorBalanceChannel ->
Int32 ->
IO ()
colorBalanceSetValue ::
(B.CallStack.HasCallStack, MonadIO m, IsColorBalance a, GstVideo.ColorBalanceChannel.IsColorBalanceChannel b) =>
a
-> b
-> Int32
-> m ()
colorBalanceSetValue balance channel value = liftIO $ do
balance' <- unsafeManagedPtrCastPtr balance
channel' <- unsafeManagedPtrCastPtr channel
gst_color_balance_set_value balance' channel' value
touchManagedPtr balance
touchManagedPtr channel
return ()
data ColorBalanceSetValueMethodInfo
instance (signature ~ (b -> Int32 -> m ()), MonadIO m, IsColorBalance a, GstVideo.ColorBalanceChannel.IsColorBalanceChannel b) => O.MethodInfo ColorBalanceSetValueMethodInfo a signature where
overloadedMethod _ = colorBalanceSetValue
foreign import ccall "gst_color_balance_value_changed" gst_color_balance_value_changed ::
Ptr ColorBalance ->
Ptr GstVideo.ColorBalanceChannel.ColorBalanceChannel ->
Int32 ->
IO ()
colorBalanceValueChanged ::
(B.CallStack.HasCallStack, MonadIO m, IsColorBalance a, GstVideo.ColorBalanceChannel.IsColorBalanceChannel b) =>
a
-> b
-> Int32
-> m ()
colorBalanceValueChanged balance channel value = liftIO $ do
balance' <- unsafeManagedPtrCastPtr balance
channel' <- unsafeManagedPtrCastPtr channel
gst_color_balance_value_changed balance' channel' value
touchManagedPtr balance
touchManagedPtr channel
return ()
data ColorBalanceValueChangedMethodInfo
instance (signature ~ (b -> Int32 -> m ()), MonadIO m, IsColorBalance a, GstVideo.ColorBalanceChannel.IsColorBalanceChannel b) => O.MethodInfo ColorBalanceValueChangedMethodInfo a signature where
overloadedMethod _ = colorBalanceValueChanged