commonMain.com.divpundir.mavlink.definitions.ardupilotmega.OsdParamConfig.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of definitions-jvm Show documentation
Show all versions of definitions-jvm Show documentation
A modern MAVLink library for the JVM written in Kotlin.
The newest version!
package com.divpundir.mavlink.definitions.ardupilotmega
import com.divpundir.mavlink.api.GeneratedMavField
import com.divpundir.mavlink.api.GeneratedMavMessage
import com.divpundir.mavlink.api.MavEnumValue
import com.divpundir.mavlink.api.MavMessage
import com.divpundir.mavlink.serialization.MavDataDecoder
import com.divpundir.mavlink.serialization.MavDataEncoder
import com.divpundir.mavlink.serialization.encodeEnumValue
import com.divpundir.mavlink.serialization.encodeFloat
import com.divpundir.mavlink.serialization.encodeString
import com.divpundir.mavlink.serialization.encodeUInt32
import com.divpundir.mavlink.serialization.encodeUInt8
import com.divpundir.mavlink.serialization.safeDecodeEnumValue
import com.divpundir.mavlink.serialization.safeDecodeFloat
import com.divpundir.mavlink.serialization.safeDecodeString
import com.divpundir.mavlink.serialization.safeDecodeUInt32
import com.divpundir.mavlink.serialization.safeDecodeUInt8
import com.divpundir.mavlink.serialization.truncateZeros
import kotlin.Byte
import kotlin.ByteArray
import kotlin.Float
import kotlin.Int
import kotlin.String
import kotlin.UByte
import kotlin.UInt
import kotlin.Unit
/**
* Configure an OSD parameter slot.
*
* @param targetSystem System ID.
* @param targetComponent Component ID.
* @param requestId Request ID - copied to reply.
* @param osdScreen OSD parameter screen index.
* @param osdIndex OSD parameter display index.
* @param paramId Onboard parameter id, terminated by NULL if the length is less than 16
* human-readable chars and WITHOUT null termination (NULL) byte if the length is exactly 16 chars -
* applications have to provide 16+1 bytes storage if the ID is stored as string
* @param configType Config type.
* @param minValue OSD parameter minimum value.
* @param maxValue OSD parameter maximum value.
* @param increment OSD parameter increment.
*/
@GeneratedMavMessage(
id = 11_033u,
crcExtra = -61,
)
public data class OsdParamConfig(
/**
* System ID.
*/
@GeneratedMavField(type = "uint8_t")
public val targetSystem: UByte = 0u,
/**
* Component ID.
*/
@GeneratedMavField(type = "uint8_t")
public val targetComponent: UByte = 0u,
/**
* Request ID - copied to reply.
*/
@GeneratedMavField(type = "uint32_t")
public val requestId: UInt = 0u,
/**
* OSD parameter screen index.
*/
@GeneratedMavField(type = "uint8_t")
public val osdScreen: UByte = 0u,
/**
* OSD parameter display index.
*/
@GeneratedMavField(type = "uint8_t")
public val osdIndex: UByte = 0u,
/**
* Onboard parameter id, terminated by NULL if the length is less than 16 human-readable chars and
* WITHOUT null termination (NULL) byte if the length is exactly 16 chars - applications have to
* provide 16+1 bytes storage if the ID is stored as string
*/
@GeneratedMavField(type = "char[16]")
public val paramId: String = "",
/**
* Config type.
*/
@GeneratedMavField(type = "uint8_t")
public val configType: MavEnumValue = MavEnumValue.fromValue(0u),
/**
* OSD parameter minimum value.
*/
@GeneratedMavField(type = "float")
public val minValue: Float = 0F,
/**
* OSD parameter maximum value.
*/
@GeneratedMavField(type = "float")
public val maxValue: Float = 0F,
/**
* OSD parameter increment.
*/
@GeneratedMavField(type = "float")
public val increment: Float = 0F,
) : MavMessage {
override val instanceCompanion: MavMessage.MavCompanion = Companion
override fun serializeV1(): ByteArray {
val encoder = MavDataEncoder(SIZE_V1)
encoder.encodeUInt32(requestId)
encoder.encodeFloat(minValue)
encoder.encodeFloat(maxValue)
encoder.encodeFloat(increment)
encoder.encodeUInt8(targetSystem)
encoder.encodeUInt8(targetComponent)
encoder.encodeUInt8(osdScreen)
encoder.encodeUInt8(osdIndex)
encoder.encodeString(paramId, 16)
encoder.encodeEnumValue(configType.value, 1)
return encoder.bytes
}
override fun serializeV2(): ByteArray {
val encoder = MavDataEncoder(SIZE_V2)
encoder.encodeUInt32(requestId)
encoder.encodeFloat(minValue)
encoder.encodeFloat(maxValue)
encoder.encodeFloat(increment)
encoder.encodeUInt8(targetSystem)
encoder.encodeUInt8(targetComponent)
encoder.encodeUInt8(osdScreen)
encoder.encodeUInt8(osdIndex)
encoder.encodeString(paramId, 16)
encoder.encodeEnumValue(configType.value, 1)
return encoder.bytes.truncateZeros()
}
public companion object : MavMessage.MavCompanion {
private const val SIZE_V1: Int = 37
private const val SIZE_V2: Int = 37
override val id: UInt = 11_033u
override val crcExtra: Byte = -61
override fun deserialize(bytes: ByteArray): OsdParamConfig {
val decoder = MavDataDecoder(bytes)
val requestId = decoder.safeDecodeUInt32()
val minValue = decoder.safeDecodeFloat()
val maxValue = decoder.safeDecodeFloat()
val increment = decoder.safeDecodeFloat()
val targetSystem = decoder.safeDecodeUInt8()
val targetComponent = decoder.safeDecodeUInt8()
val osdScreen = decoder.safeDecodeUInt8()
val osdIndex = decoder.safeDecodeUInt8()
val paramId = decoder.safeDecodeString(16)
val configType = decoder.safeDecodeEnumValue(1).let { value ->
val entry = OsdParamConfigType.getEntryFromValueOrNull(value)
if (entry != null) MavEnumValue.of(entry) else MavEnumValue.fromValue(value)
}
return OsdParamConfig(
targetSystem = targetSystem,
targetComponent = targetComponent,
requestId = requestId,
osdScreen = osdScreen,
osdIndex = osdIndex,
paramId = paramId,
configType = configType,
minValue = minValue,
maxValue = maxValue,
increment = increment,
)
}
public operator fun invoke(builderAction: Builder.() -> Unit): OsdParamConfig =
Builder().apply(builderAction).build()
}
public class Builder {
public var targetSystem: UByte = 0u
public var targetComponent: UByte = 0u
public var requestId: UInt = 0u
public var osdScreen: UByte = 0u
public var osdIndex: UByte = 0u
public var paramId: String = ""
public var configType: MavEnumValue = MavEnumValue.fromValue(0u)
public var minValue: Float = 0F
public var maxValue: Float = 0F
public var increment: Float = 0F
public fun build(): OsdParamConfig = OsdParamConfig(
targetSystem = targetSystem,
targetComponent = targetComponent,
requestId = requestId,
osdScreen = osdScreen,
osdIndex = osdIndex,
paramId = paramId,
configType = configType,
minValue = minValue,
maxValue = maxValue,
increment = increment,
)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy