mirror of
https://github.com/ciphervance/supercell-wx.git
synced 2025-10-30 19:10:06 +00:00
Wind barb data packet
This commit is contained in:
parent
5dcf65b79c
commit
6d4428b8e0
4 changed files with 199 additions and 0 deletions
44
wxdata/include/scwx/wsr88d/rpg/wind_barb_data_packet.hpp
Normal file
44
wxdata/include/scwx/wsr88d/rpg/wind_barb_data_packet.hpp
Normal file
|
|
@ -0,0 +1,44 @@
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <scwx/wsr88d/rpg/packet.hpp>
|
||||||
|
|
||||||
|
#include <cstdint>
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
namespace scwx
|
||||||
|
{
|
||||||
|
namespace wsr88d
|
||||||
|
{
|
||||||
|
namespace rpg
|
||||||
|
{
|
||||||
|
|
||||||
|
class WindBarbDataPacketImpl;
|
||||||
|
|
||||||
|
class WindBarbDataPacket : public Packet
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit WindBarbDataPacket();
|
||||||
|
~WindBarbDataPacket();
|
||||||
|
|
||||||
|
WindBarbDataPacket(const WindBarbDataPacket&) = delete;
|
||||||
|
WindBarbDataPacket& operator=(const WindBarbDataPacket&) = delete;
|
||||||
|
|
||||||
|
WindBarbDataPacket(WindBarbDataPacket&&) noexcept;
|
||||||
|
WindBarbDataPacket& operator=(WindBarbDataPacket&&) noexcept;
|
||||||
|
|
||||||
|
uint16_t packet_code() const;
|
||||||
|
uint16_t length_of_block() const;
|
||||||
|
|
||||||
|
size_t data_size() const override;
|
||||||
|
|
||||||
|
bool Parse(std::istream& is) override;
|
||||||
|
|
||||||
|
static std::shared_ptr<WindBarbDataPacket> Create(std::istream& is);
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::unique_ptr<WindBarbDataPacketImpl> p;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // namespace rpg
|
||||||
|
} // namespace wsr88d
|
||||||
|
} // namespace scwx
|
||||||
|
|
@ -12,6 +12,7 @@
|
||||||
#include <scwx/wsr88d/rpg/unlinked_contour_vector_packet.hpp>
|
#include <scwx/wsr88d/rpg/unlinked_contour_vector_packet.hpp>
|
||||||
#include <scwx/wsr88d/rpg/unlinked_vector_packet.hpp>
|
#include <scwx/wsr88d/rpg/unlinked_vector_packet.hpp>
|
||||||
#include <scwx/wsr88d/rpg/vector_arrow_data_packet.hpp>
|
#include <scwx/wsr88d/rpg/vector_arrow_data_packet.hpp>
|
||||||
|
#include <scwx/wsr88d/rpg/wind_barb_data_packet.hpp>
|
||||||
|
|
||||||
#include <unordered_map>
|
#include <unordered_map>
|
||||||
|
|
||||||
|
|
@ -32,6 +33,7 @@ typedef std::function<std::shared_ptr<Packet>(std::istream&)>
|
||||||
static const std::unordered_map<uint16_t, CreateMessageFunction> create_ {
|
static const std::unordered_map<uint16_t, CreateMessageFunction> create_ {
|
||||||
{1, TextAndSpecialSymbolPacket::Create},
|
{1, TextAndSpecialSymbolPacket::Create},
|
||||||
{2, TextAndSpecialSymbolPacket::Create},
|
{2, TextAndSpecialSymbolPacket::Create},
|
||||||
|
{4, WindBarbDataPacket::Create},
|
||||||
{5, VectorArrowDataPacket::Create},
|
{5, VectorArrowDataPacket::Create},
|
||||||
{6, LinkedVectorPacket::Create},
|
{6, LinkedVectorPacket::Create},
|
||||||
{7, UnlinkedVectorPacket::Create},
|
{7, UnlinkedVectorPacket::Create},
|
||||||
|
|
|
||||||
151
wxdata/source/scwx/wsr88d/rpg/wind_barb_data_packet.cpp
Normal file
151
wxdata/source/scwx/wsr88d/rpg/wind_barb_data_packet.cpp
Normal file
|
|
@ -0,0 +1,151 @@
|
||||||
|
#include <scwx/wsr88d/rpg/wind_barb_data_packet.hpp>
|
||||||
|
|
||||||
|
#include <istream>
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
#include <boost/log/trivial.hpp>
|
||||||
|
|
||||||
|
namespace scwx
|
||||||
|
{
|
||||||
|
namespace wsr88d
|
||||||
|
{
|
||||||
|
namespace rpg
|
||||||
|
{
|
||||||
|
|
||||||
|
static const std::string logPrefix_ =
|
||||||
|
"[scwx::wsr88d::rpg::wind_barb_data_packet] ";
|
||||||
|
|
||||||
|
struct WindBarb
|
||||||
|
{
|
||||||
|
uint16_t value_;
|
||||||
|
int16_t xCoordinate_;
|
||||||
|
int16_t yCoordinate_;
|
||||||
|
uint16_t directionOfWind_;
|
||||||
|
uint16_t windSpeed_;
|
||||||
|
|
||||||
|
WindBarb() :
|
||||||
|
value_ {0},
|
||||||
|
xCoordinate_ {0},
|
||||||
|
yCoordinate_ {0},
|
||||||
|
directionOfWind_ {0},
|
||||||
|
windSpeed_ {0}
|
||||||
|
{
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
class WindBarbDataPacketImpl
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
explicit WindBarbDataPacketImpl() :
|
||||||
|
packetCode_ {0}, lengthOfBlock_ {0}, windBarb_ {}
|
||||||
|
{
|
||||||
|
}
|
||||||
|
~WindBarbDataPacketImpl() = default;
|
||||||
|
|
||||||
|
uint16_t packetCode_;
|
||||||
|
uint16_t lengthOfBlock_;
|
||||||
|
|
||||||
|
std::vector<WindBarb> windBarb_;
|
||||||
|
};
|
||||||
|
|
||||||
|
WindBarbDataPacket::WindBarbDataPacket() :
|
||||||
|
p(std::make_unique<WindBarbDataPacketImpl>())
|
||||||
|
{
|
||||||
|
}
|
||||||
|
WindBarbDataPacket::~WindBarbDataPacket() = default;
|
||||||
|
|
||||||
|
WindBarbDataPacket::WindBarbDataPacket(WindBarbDataPacket&&) noexcept = default;
|
||||||
|
WindBarbDataPacket&
|
||||||
|
WindBarbDataPacket::operator=(WindBarbDataPacket&&) noexcept = default;
|
||||||
|
|
||||||
|
uint16_t WindBarbDataPacket::packet_code() const
|
||||||
|
{
|
||||||
|
return p->packetCode_;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint16_t WindBarbDataPacket::length_of_block() const
|
||||||
|
{
|
||||||
|
return p->lengthOfBlock_;
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t WindBarbDataPacket::data_size() const
|
||||||
|
{
|
||||||
|
return p->lengthOfBlock_ + 4u;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool WindBarbDataPacket::Parse(std::istream& is)
|
||||||
|
{
|
||||||
|
bool blockValid = true;
|
||||||
|
|
||||||
|
std::streampos isBegin = is.tellg();
|
||||||
|
|
||||||
|
is.read(reinterpret_cast<char*>(&p->packetCode_), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&p->lengthOfBlock_), 2);
|
||||||
|
|
||||||
|
p->packetCode_ = ntohs(p->packetCode_);
|
||||||
|
p->lengthOfBlock_ = ntohs(p->lengthOfBlock_);
|
||||||
|
|
||||||
|
if (is.eof())
|
||||||
|
{
|
||||||
|
BOOST_LOG_TRIVIAL(debug) << logPrefix_ << "Reached end of file";
|
||||||
|
blockValid = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (p->packetCode_ != 4)
|
||||||
|
{
|
||||||
|
BOOST_LOG_TRIVIAL(warning)
|
||||||
|
<< logPrefix_ << "Invalid packet code: " << p->packetCode_;
|
||||||
|
blockValid = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// The number of vectors is equal to the size divided by the number of bytes
|
||||||
|
// in a vector
|
||||||
|
size_t vectorCount = p->lengthOfBlock_ / 10;
|
||||||
|
|
||||||
|
p->windBarb_.resize(vectorCount);
|
||||||
|
|
||||||
|
for (int v = 0; v < vectorCount && !is.eof(); v++)
|
||||||
|
{
|
||||||
|
WindBarb& windBarb = p->windBarb_[v];
|
||||||
|
|
||||||
|
is.read(reinterpret_cast<char*>(&windBarb.value_), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&windBarb.xCoordinate_), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&windBarb.yCoordinate_), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&windBarb.directionOfWind_), 2);
|
||||||
|
is.read(reinterpret_cast<char*>(&windBarb.windSpeed_), 2);
|
||||||
|
|
||||||
|
windBarb.value_ = ntohs(windBarb.value_);
|
||||||
|
windBarb.xCoordinate_ = ntohs(windBarb.xCoordinate_);
|
||||||
|
windBarb.yCoordinate_ = ntohs(windBarb.yCoordinate_);
|
||||||
|
windBarb.directionOfWind_ = ntohs(windBarb.directionOfWind_);
|
||||||
|
windBarb.windSpeed_ = ntohs(windBarb.windSpeed_);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::streampos isEnd = is.tellg();
|
||||||
|
|
||||||
|
if (!ValidateMessage(is, isEnd - isBegin))
|
||||||
|
{
|
||||||
|
blockValid = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
return blockValid;
|
||||||
|
}
|
||||||
|
|
||||||
|
std::shared_ptr<WindBarbDataPacket> WindBarbDataPacket::Create(std::istream& is)
|
||||||
|
{
|
||||||
|
std::shared_ptr<WindBarbDataPacket> packet =
|
||||||
|
std::make_shared<WindBarbDataPacket>();
|
||||||
|
|
||||||
|
if (!packet->Parse(is))
|
||||||
|
{
|
||||||
|
packet.reset();
|
||||||
|
}
|
||||||
|
|
||||||
|
return packet;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace rpg
|
||||||
|
} // namespace wsr88d
|
||||||
|
} // namespace scwx
|
||||||
|
|
@ -63,6 +63,7 @@ set(HDR_WSR88D_RPG include/scwx/wsr88d/rpg/digital_precipitation_data_array_pack
|
||||||
include/scwx/wsr88d/rpg/unlinked_contour_vector_packet.hpp
|
include/scwx/wsr88d/rpg/unlinked_contour_vector_packet.hpp
|
||||||
include/scwx/wsr88d/rpg/unlinked_vector_packet.hpp
|
include/scwx/wsr88d/rpg/unlinked_vector_packet.hpp
|
||||||
include/scwx/wsr88d/rpg/vector_arrow_data_packet.hpp
|
include/scwx/wsr88d/rpg/vector_arrow_data_packet.hpp
|
||||||
|
include/scwx/wsr88d/rpg/wind_barb_data_packet.hpp
|
||||||
include/scwx/wsr88d/rpg/wmo_header.hpp)
|
include/scwx/wsr88d/rpg/wmo_header.hpp)
|
||||||
set(SRC_WSR88D_RPG source/scwx/wsr88d/rpg/digital_precipitation_data_array_packet.cpp
|
set(SRC_WSR88D_RPG source/scwx/wsr88d/rpg/digital_precipitation_data_array_packet.cpp
|
||||||
source/scwx/wsr88d/rpg/digital_radial_data_array_packet.cpp
|
source/scwx/wsr88d/rpg/digital_radial_data_array_packet.cpp
|
||||||
|
|
@ -81,6 +82,7 @@ set(SRC_WSR88D_RPG source/scwx/wsr88d/rpg/digital_precipitation_data_array_packe
|
||||||
source/scwx/wsr88d/rpg/unlinked_contour_vector_packet.cpp
|
source/scwx/wsr88d/rpg/unlinked_contour_vector_packet.cpp
|
||||||
source/scwx/wsr88d/rpg/unlinked_vector_packet.cpp
|
source/scwx/wsr88d/rpg/unlinked_vector_packet.cpp
|
||||||
source/scwx/wsr88d/rpg/vector_arrow_data_packet.cpp
|
source/scwx/wsr88d/rpg/vector_arrow_data_packet.cpp
|
||||||
|
source/scwx/wsr88d/rpg/wind_barb_data_packet.cpp
|
||||||
source/scwx/wsr88d/rpg/wmo_header.cpp)
|
source/scwx/wsr88d/rpg/wmo_header.cpp)
|
||||||
|
|
||||||
add_library(wxdata OBJECT ${HDR_COMMON}
|
add_library(wxdata OBJECT ${HDR_COMMON}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue