mirror of
https://github.com/ciphervance/supercell-wx.git
synced 2025-10-30 13:30:06 +00:00
Draw 4-bit encoded radial data
This commit is contained in:
parent
41b491314b
commit
8d1be0f54a
7 changed files with 158 additions and 25 deletions
|
|
@ -1,6 +1,6 @@
|
|||
#pragma once
|
||||
|
||||
#include <scwx/wsr88d/rpg/packet.hpp>
|
||||
#include <scwx/wsr88d/rpg/generic_radial_data_packet.hpp>
|
||||
|
||||
#include <cstdint>
|
||||
#include <memory>
|
||||
|
|
@ -14,7 +14,7 @@ namespace rpg
|
|||
|
||||
class DigitalRadialDataArrayPacketImpl;
|
||||
|
||||
class DigitalRadialDataArrayPacket : public Packet
|
||||
class DigitalRadialDataArrayPacket : public GenericRadialDataPacket
|
||||
{
|
||||
public:
|
||||
explicit DigitalRadialDataArrayPacket();
|
||||
|
|
|
|||
|
|
@ -0,0 +1,43 @@
|
|||
#pragma once
|
||||
|
||||
#include <scwx/wsr88d/rpg/packet.hpp>
|
||||
|
||||
#include <cstdint>
|
||||
#include <memory>
|
||||
|
||||
namespace scwx
|
||||
{
|
||||
namespace wsr88d
|
||||
{
|
||||
namespace rpg
|
||||
{
|
||||
|
||||
class GenericRadialDataPacketImpl;
|
||||
|
||||
class GenericRadialDataPacket : public Packet
|
||||
{
|
||||
public:
|
||||
explicit GenericRadialDataPacket();
|
||||
~GenericRadialDataPacket();
|
||||
|
||||
GenericRadialDataPacket(const GenericRadialDataPacket&) = delete;
|
||||
GenericRadialDataPacket& operator=(const GenericRadialDataPacket&) = delete;
|
||||
|
||||
GenericRadialDataPacket(GenericRadialDataPacket&&) noexcept;
|
||||
GenericRadialDataPacket& operator=(GenericRadialDataPacket&&) noexcept;
|
||||
|
||||
virtual int16_t i_center_of_sweep() const = 0;
|
||||
virtual int16_t j_center_of_sweep() const = 0;
|
||||
virtual uint16_t number_of_radials() const = 0;
|
||||
virtual uint16_t number_of_range_bins() const = 0;
|
||||
virtual float start_angle(uint16_t r) const = 0;
|
||||
|
||||
virtual const std::vector<uint8_t>& level(uint16_t r) const = 0;
|
||||
|
||||
private:
|
||||
std::unique_ptr<GenericRadialDataPacketImpl> p;
|
||||
};
|
||||
|
||||
} // namespace rpg
|
||||
} // namespace wsr88d
|
||||
} // namespace scwx
|
||||
|
|
@ -1,6 +1,6 @@
|
|||
#pragma once
|
||||
|
||||
#include <scwx/wsr88d/rpg/packet.hpp>
|
||||
#include <scwx/wsr88d/rpg/generic_radial_data_packet.hpp>
|
||||
|
||||
#include <cstdint>
|
||||
#include <memory>
|
||||
|
|
@ -14,7 +14,7 @@ namespace rpg
|
|||
|
||||
class RadialDataPacketImpl;
|
||||
|
||||
class RadialDataPacket : public Packet
|
||||
class RadialDataPacket : public GenericRadialDataPacket
|
||||
{
|
||||
public:
|
||||
explicit RadialDataPacket();
|
||||
|
|
@ -34,6 +34,10 @@ public:
|
|||
float scale_factor() const;
|
||||
uint16_t number_of_radials() const;
|
||||
|
||||
float start_angle(uint16_t r) const;
|
||||
float delta_angle(uint16_t r) const;
|
||||
const std::vector<uint8_t>& level(uint16_t r) const;
|
||||
|
||||
size_t data_size() const override;
|
||||
|
||||
bool Parse(std::istream& is) override;
|
||||
|
|
|
|||
37
wxdata/source/scwx/wsr88d/rpg/generic_radial_data_packet.cpp
Normal file
37
wxdata/source/scwx/wsr88d/rpg/generic_radial_data_packet.cpp
Normal file
|
|
@ -0,0 +1,37 @@
|
|||
#include <scwx/wsr88d/rpg/generic_radial_data_packet.hpp>
|
||||
|
||||
#include <string>
|
||||
|
||||
#include <boost/log/trivial.hpp>
|
||||
|
||||
namespace scwx
|
||||
{
|
||||
namespace wsr88d
|
||||
{
|
||||
namespace rpg
|
||||
{
|
||||
|
||||
static const std::string logPrefix_ =
|
||||
"[scwx::wsr88d::rpg::generic_radial_data_packet] ";
|
||||
|
||||
class GenericRadialDataPacketImpl
|
||||
{
|
||||
public:
|
||||
explicit GenericRadialDataPacketImpl() = default;
|
||||
~GenericRadialDataPacketImpl() = default;
|
||||
};
|
||||
|
||||
GenericRadialDataPacket::GenericRadialDataPacket() :
|
||||
p(std::make_unique<GenericRadialDataPacketImpl>())
|
||||
{
|
||||
}
|
||||
GenericRadialDataPacket::~GenericRadialDataPacket() = default;
|
||||
|
||||
GenericRadialDataPacket::GenericRadialDataPacket(
|
||||
GenericRadialDataPacket&&) noexcept = default;
|
||||
GenericRadialDataPacket& GenericRadialDataPacket::operator=(
|
||||
GenericRadialDataPacket&&) noexcept = default;
|
||||
|
||||
} // namespace rpg
|
||||
} // namespace wsr88d
|
||||
} // namespace scwx
|
||||
|
|
@ -24,9 +24,14 @@ public:
|
|||
uint16_t startAngle_;
|
||||
uint16_t angleDelta_;
|
||||
std::vector<uint8_t> data_;
|
||||
std::vector<uint8_t> level_;
|
||||
|
||||
Radial() :
|
||||
numberOfRleHalfwords_ {0}, startAngle_ {0}, angleDelta_ {0}, data_ {}
|
||||
numberOfRleHalfwords_ {0},
|
||||
startAngle_ {0},
|
||||
angleDelta_ {0},
|
||||
data_ {},
|
||||
level_ {}
|
||||
{
|
||||
}
|
||||
};
|
||||
|
|
@ -103,6 +108,21 @@ uint16_t RadialDataPacket::number_of_radials() const
|
|||
return p->numberOfRadials_;
|
||||
}
|
||||
|
||||
float RadialDataPacket::start_angle(uint16_t r) const
|
||||
{
|
||||
return p->radial_[r].startAngle_ * 0.1f;
|
||||
}
|
||||
|
||||
float RadialDataPacket::delta_angle(uint16_t r) const
|
||||
{
|
||||
return p->radial_[r].angleDelta_ * 0.1f;
|
||||
}
|
||||
|
||||
const std::vector<uint8_t>& RadialDataPacket::level(uint16_t r) const
|
||||
{
|
||||
return p->radial_[r].level_;
|
||||
}
|
||||
|
||||
size_t RadialDataPacket::data_size() const
|
||||
{
|
||||
return p->dataSize_;
|
||||
|
|
@ -197,6 +217,14 @@ bool RadialDataPacket::Parse(std::istream& is)
|
|||
{
|
||||
radial.data_.pop_back();
|
||||
}
|
||||
|
||||
radial.level_.resize(radial.data_.size());
|
||||
|
||||
std::transform(std::execution::par_unseq,
|
||||
radial.data_.cbegin(),
|
||||
radial.data_.cend(),
|
||||
radial.level_.begin(),
|
||||
[](uint8_t data) -> uint8_t { return data & 0x0f; });
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -80,6 +80,7 @@ set(HDR_WSR88D_RPG include/scwx/wsr88d/rpg/ccb_header.hpp
|
|||
include/scwx/wsr88d/rpg/digital_radial_data_array_packet.hpp
|
||||
include/scwx/wsr88d/rpg/general_status_message.hpp
|
||||
include/scwx/wsr88d/rpg/generic_data_packet.hpp
|
||||
include/scwx/wsr88d/rpg/generic_radial_data_packet.hpp
|
||||
include/scwx/wsr88d/rpg/graphic_alphanumeric_block.hpp
|
||||
include/scwx/wsr88d/rpg/graphic_product_message.hpp
|
||||
include/scwx/wsr88d/rpg/hda_hail_symbol_packet.hpp
|
||||
|
|
@ -118,6 +119,7 @@ set(SRC_WSR88D_RPG source/scwx/wsr88d/rpg/ccb_header.cpp
|
|||
source/scwx/wsr88d/rpg/digital_radial_data_array_packet.cpp
|
||||
source/scwx/wsr88d/rpg/general_status_message.cpp
|
||||
source/scwx/wsr88d/rpg/generic_data_packet.cpp
|
||||
source/scwx/wsr88d/rpg/generic_radial_data_packet.cpp
|
||||
source/scwx/wsr88d/rpg/graphic_alphanumeric_block.cpp
|
||||
source/scwx/wsr88d/rpg/graphic_product_message.cpp
|
||||
source/scwx/wsr88d/rpg/hda_hail_symbol_packet.cpp
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue