Files
OpenSpace/modules/softwareintegration/utils.h
Jacob Molin df79184faf [WIP] ColormapEnable not working
Co-authored-by: Victor Lindquist <VLLindqvist@users.noreply.github.com>
2022-05-24 17:07:57 -06:00

164 lines
5.5 KiB
C++

/*****************************************************************************************
* *
* OpenSpace *
* *
* Copyright (c) 2014-2021 *
* *
* Permission is hereby granted, free of charge, to any person obtaining a copy of this *
* software and associated documentation files (the "Software"), to deal in the Software *
* without restriction, including without limitation the rights to use, copy, modify, *
* merge, publish, distribute, sublicense, and/or sell copies of the Software, and to *
* permit persons to whom the Software is furnished to do so, subject to the following *
* conditions: *
* *
* The above copyright notice and this permission notice shall be included in all copies *
* or substantial portions of the Software. *
* *
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, *
* INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A *
* PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT *
* HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF *
* CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE *
* OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. *
****************************************************************************************/
#ifndef __OPENSPACE_MODULE_SOFTWAREINTEGRATION___SIMP___H__
#define __OPENSPACE_MODULE_SOFTWAREINTEGRATION___SIMP___H__
#include <unordered_map>
namespace openspace {
namespace softwareintegration {
namespace storage {
enum class Key : uint32_t {
DataPoints = 0,
Colormap,
ColormapAttrData,
LinearSizeAttrData,
Unknown
};
const std::unordered_map<std::string, Key> _keyStringFromKey {
{"DataPoints", Key::DataPoints},
{"Colormap", Key::Colormap},
{"ColormapAttributeData", Key::ColormapAttrData},
{"LinearSizeAttributeData", Key::LinearSizeAttrData},
};
std::string getStorageKey(const std::string& identifier, Key key);
std::string getStorageKey(const std::string& identifier, const std::string& key);
Key getStorageKeyEnum(const std::string& key);
bool hasStorageKey(const std::string& key);
} // namespace storage
namespace simp {
const std::string ProtocolVersion = "1.9";
const char SEP = ';';
enum class MessageType : uint32_t {
Connection = 0,
PointData,
RemoveSceneGraphNode,
Color,
Colormap,
AttributeData,
Opacity,
FixedSize,
LinearSize,
Visibility,
Disconnection,
Unknown
};
namespace tools {
enum class ErrorCode : uint32_t {
ReachedEndBeforeSeparator = 0,
OffsetLargerThanMessageSize,
InvalidDimensionality,
Generic,
};
const std::unordered_map<std::string, MessageType> _messageTypeFromSIMPType {
{"CONN", MessageType::Connection},
{"PDAT", MessageType::PointData},
{"RSGN", MessageType::RemoveSceneGraphNode},
{"FCOL", MessageType::Color},
{"LCOL", MessageType::Colormap},
{"ATDA", MessageType::AttributeData},
{"FOPA", MessageType::Opacity},
{"FPSI", MessageType::FixedSize},
{"LPSI", MessageType::LinearSize},
{"TOVI", MessageType::Visibility},
{"DISC", MessageType::Disconnection},
};
glm::vec4 readSingleColor(const std::vector<char>& message, size_t& offset);
bool isEndOfCurrentValue(const std::vector<char>& message, size_t offset);
} // namespace tools
class SimpError : public ghoul::RuntimeError {
public:
tools::ErrorCode errorCode;
explicit SimpError(const tools::ErrorCode _errorCode, const std::string& msg);
};
MessageType getMessageType(const std::string& type);
std::string getSIMPType(const MessageType& type);
std::string formatLengthOfSubject(size_t lengthOfSubject);
std::string formatUpdateMessage(MessageType messageType,
std::string_view identifier,
std::string_view value);
std::string formatConnectionMessage(std::string_view value);
std::string formatColorMessage(std::string_view identifier, glm::vec4 color);
std::string formatPointDataCallbackMessage(std::string_view identifier);
std::string floatToHex(const float f);
float hexToFloat(const std::string& f);
float readFloatValue(const std::vector<char>& message, size_t& offset);
int readIntValue(const std::vector<char>& message, size_t& offset);
std::string readString(const std::vector<char>& message, size_t& offset);
glm::vec4 readColor(const std::vector<char>& message, size_t& offset);
void readPointData(
const std::vector<char>& message, size_t& offset, size_t nPoints,
size_t dimensionality, std::vector<float>& pointData
);
void readColormap(
const std::vector<char>& message, size_t& offset, size_t nColors,
std::vector<float>& colorMap
);
} // namespace simp
} // namespace softwareintegration
} // namespace openspace
#endif // __OPENSPACE_MODULE_SOFTWAREINTEGRATION___SIMP___H__