diff --git a/assets/webconfig/i18n/en.json b/assets/webconfig/i18n/en.json
index 455638ed..29659df4 100644
--- a/assets/webconfig/i18n/en.json
+++ b/assets/webconfig/i18n/en.json
@@ -62,7 +62,7 @@
"conf_leds_layout_btn_checklist": "Show checklist",
"conf_leds_layout_button_savelay": "Save Layout",
"conf_leds_layout_button_updsim": "Update Preview",
- "conf_leds_layout_checkp1": "The black led is your first led, the first led is the point where you input your data signal.",
+ "conf_leds_layout_checkp1": "The black LED is your first LED, the first LED is the point where you input your data signal.",
"conf_leds_layout_checkp2": "The layout is always the front view of your TV, never the back view.",
"conf_leds_layout_checkp3": "Make sure the direction is right. The grey LEDs indicate LED number 2 and 3 to visualise the data direction.",
"conf_leds_layout_checkp4": "Case Gap: To create a gap, ignore it first when you define Top/Bottom/Left/Right and set afterwards your gap length to remove a amount of leds. Modify the gap position until it matches.",
@@ -91,7 +91,7 @@
"conf_leds_layout_cl_vleddepth": "Vertical LED depth",
"conf_leds_layout_frame": "Classic Layout (LED Frame)",
"conf_leds_layout_generatedconf": "Generated/Current LED Configuration",
- "conf_leds_layout_intro": "You need also a led layout, which reflects your led positions. The classic layout is the usual used tv frame, but we also support led matrix (led walls) creation. The view on this layout is ALWAYS of the FRONT of your TV.",
+ "conf_leds_layout_intro": "You also need an LED layout, which reflects your LED positions. The classic layout is the usually used TV frame, but we also support LED matrix (LED walls) creation. The view on this layout is ALWAYS from the FRONT of your TV.",
"conf_leds_layout_ma_cabling": "Cabling",
"conf_leds_layout_ma_horiz": "Horizontal",
"conf_leds_layout_ma_optbottomleft": "Bottom left",
@@ -109,8 +109,8 @@
"conf_leds_layout_pbl": "Point Bottom Left",
"conf_leds_layout_pbr": "Point Bottom Right",
"conf_leds_layout_peview": "LED Layout Preview",
- "conf_leds_layout_preview_l1": "This is your first led (input position)",
- "conf_leds_layout_preview_l2": "This visualizes the data direction (second/third led)",
+ "conf_leds_layout_preview_l1": "This is your first LED (input position)",
+ "conf_leds_layout_preview_l2": "This visualizes the data direction (second/third LED)",
"conf_leds_layout_preview_ledpower": "Max. power consumption: $1 A",
"conf_leds_layout_preview_originCL": "Created from: Classic Layout (LED Frame)",
"conf_leds_layout_preview_originMA": "Created from: Matrix Layout(LED wall)",
@@ -121,7 +121,7 @@
"conf_leds_layout_ptln": "Tripplepoints",
"conf_leds_layout_ptlv": "Vertical",
"conf_leds_layout_ptr": "Point Top Right",
- "conf_leds_layout_textf1": "This text field shows by default your current loaded layout and will be overwritten if you generate a new one with the options above. Optional you could perform further edits.",
+ "conf_leds_layout_textf1": "This text field shows by default your current loaded layout and will be overwritten if you generate a new one with the options above. Optionally, you could perform further edits.",
"conf_leds_nav_label_ledcontroller": "LED Controller",
"conf_leds_nav_label_ledlayout": "LED Layout",
"conf_leds_note_layout_overwrite": "Note: Overwrite creates a default layout for {{plural:$1| one LED| all $1 LEDs}} given by the hardware LED count",
@@ -147,7 +147,7 @@
"conf_network_bobl_intro": "Receiver for Boblight",
"conf_network_createToken_btn": "Create Token",
"conf_network_fbs_intro": "Google Flatbuffers Receiver. Used for fast image transmission.",
- "conf_network_forw_intro": "Forward all input to a second Hyperion installation which could be driven with another led controller",
+ "conf_network_forw_intro": "Forward all input to a second Hyperion installation which could be driven with another LED controller",
"conf_network_json_intro": "The JSON-RPC-Port of all Hyperion instances, used for remote control.",
"conf_network_net_intro": "Network related settings which are applied to all network services.",
"conf_network_proto_intro": "The PROTO-Port of all Hyperion instances, used for picture streams (HyperionScreenCap, Kodi Addon, Android Hyperion Grabber, ...)",
@@ -187,10 +187,10 @@
"dashboard_infobox_label_statush": "Hyperion status:",
"dashboard_infobox_label_title": "Information",
"dashboard_infobox_label_watchedversionbranch": "Watched version branch:",
- "dashboard_infobox_message_updatesuccess": "You run the latest version of Hyperion.",
+ "dashboard_infobox_message_updatesuccess": "You are running the latest version of Hyperion.",
"dashboard_infobox_message_updatewarning": "A newer version of Hyperion is available! ($1)",
- "dashboard_label_intro": "The dashboard give you a quick overview about the status of Hyperion.",
- "dashboard_message_default_password": "The default password for the WebUi is set. We strongly recommend to change this.",
+ "dashboard_label_intro": "The dashboard gives you a quick overview on the status of Hyperion",
+ "dashboard_message_default_password": "The WebUI currently has the default password set. We strongly recommend changing this.",
"dashboard_message_default_password_t": "WebUI default password is set",
"dashboard_message_do_not_show_again": "Do not show this message again",
"dashboard_message_global_setting": "The settings on this page are not depending on a specific instance. Changes will be stored globally for all instances.",
@@ -215,11 +215,11 @@
"edt_conf_bb_borderFrameCnt_expl": "Number of frames before a consistent detected border is set.",
"edt_conf_bb_borderFrameCnt_title": "Border frames",
"edt_conf_bb_heading_title": "Blackbar detector",
- "edt_conf_bb_maxInconsistentCnt_expl": "Number of inconsistent frames that are ignored before a new border gets a chance to proof consistency.",
+ "edt_conf_bb_maxInconsistentCnt_expl": "Number of inconsistent frames that are ignored before a new border gets a chance to prove consistency.",
"edt_conf_bb_maxInconsistentCnt_title": "Inconsistent frames",
"edt_conf_bb_mode_expl": "Algorithm for processing. (see Wiki)",
"edt_conf_bb_mode_title": "Mode",
- "edt_conf_bb_threshold_expl": "If the detection doesn't work, higher the threshold to adjust on 'greyish' black",
+ "edt_conf_bb_threshold_expl": "If the detection doesn't work, increase the threshold to adjust it to 'greyish' black",
"edt_conf_bb_threshold_title": "Threshold",
"edt_conf_bb_unknownFrameCnt_expl": "Number of frames without any detection before the border is set to 0.",
"edt_conf_bb_unknownFrameCnt_title": "Unknown frames",
@@ -253,8 +253,8 @@
"edt_conf_color_heading_title": "Color Calibration",
"edt_conf_color_id_expl": "User given name",
"edt_conf_color_id_title": "ID",
- "edt_conf_color_imageToLedMappingType_expl": "Overwrites the led area assignment of your led layout if it's not \"multicolor\"",
- "edt_conf_color_imageToLedMappingType_title": "Led area assignment",
+ "edt_conf_color_imageToLedMappingType_expl": "Overwrites the LED area assignment of your LED layout if it's not \"multicolor\"",
+ "edt_conf_color_imageToLedMappingType_title": "LED area assignment",
"edt_conf_color_leds_expl": "Assign this adjustment to all LEDs (*) or just some (0-24).",
"edt_conf_color_leds_title": "LED index",
"edt_conf_color_magenta_expl": "The calibrated magenta value.",
@@ -318,7 +318,7 @@
"edt_conf_enum_transeffect_sudden": "Sudden",
"edt_conf_enum_unicolor_mean": "Unicolor",
"edt_conf_fbs_heading_title": "Flatbuffers Server",
- "edt_conf_fbs_timeout_expl": "If no data are received for the given period, the component will be (soft) disabled.",
+ "edt_conf_fbs_timeout_expl": "If no data is received for the given period, the component will be (soft) disabled.",
"edt_conf_fbs_timeout_title": "Timeout",
"edt_conf_fg_display_expl": "Select which desktop should be captured (multi monitor setup)",
"edt_conf_fg_display_title": "Display",
@@ -372,7 +372,7 @@
"edt_conf_instC_screen_grabber_device_title": "Screen capture device",
"edt_conf_instC_systemEnable_expl": "Enables the screen capture for this led hardware instance",
"edt_conf_instC_systemEnable_title": "Enable screen capture",
- "edt_conf_instC_v4lEnable_expl": "Enables the USB capture for this led hardware instance",
+ "edt_conf_instC_v4lEnable_expl": "Enables the USB capture for this LED hardware instance",
"edt_conf_instC_v4lEnable_title": "Enable USB capture",
"edt_conf_instC_video_grabber_device_expl": "The video capture device used",
"edt_conf_instC_video_grabber_device_title": "Video capture device",
@@ -381,17 +381,17 @@
"edt_conf_log_heading_title": "Logging",
"edt_conf_log_level_expl": "Depending on loglevel you see less or more messages in your log.",
"edt_conf_log_level_title": "Log-Level",
- "edt_conf_net_apiAuth_expl": "Enforce all applications that use the Hyperion API to authenticate themself against Hyperion (Exception see \"Local API Authentication\"). Higher security, as you control the access and revoke it at any time.",
+ "edt_conf_net_apiAuth_expl": "Enforce all applications that use the Hyperion API to authenticate themself against Hyperion (Exception: see \"Local API Authentication\"). Higher security, as you control the access and revoke it at any time.",
"edt_conf_net_apiAuth_title": "API Authentication",
"edt_conf_net_heading_title": "Network",
- "edt_conf_net_internetAccessAPI_expl": "Allow access to the Hyperion API/Webinterface from the internet, disable for higher security.",
+ "edt_conf_net_internetAccessAPI_expl": "Allow access to the Hyperion API/Webinterface from the internet. Disable for higher security.",
"edt_conf_net_internetAccessAPI_title": "Internet API Access",
"edt_conf_net_ipWhitelist_expl": "You can whitelist IP addresses instead allowing all connections from internet to connect to the Hyperion API/Webinterface.",
"edt_conf_net_ipWhitelist_title": "Whitelisted IP's",
"edt_conf_net_ip_itemtitle": "IP",
"edt_conf_net_localAdminAuth_expl": "When enabled, administration access from your local network needs a password.",
"edt_conf_net_localAdminAuth_title": "Local Admin API Authentication",
- "edt_conf_net_localApiAuth_expl": "When enabled, connections from your home network needs to authenticate themself against Hyperion with a token.",
+ "edt_conf_net_localApiAuth_expl": "When enabled, connections from your home network needs to authenticate themselves against Hyperion with a token.",
"edt_conf_net_localApiAuth_title": "Local API Authentication",
"edt_conf_net_restirctedInternetAccessAPI_expl": "You can restrict the access to the API through the internet to certain IP's.",
"edt_conf_net_restirctedInternetAccessAPI_title": "Restrict to IP's",
@@ -407,7 +407,7 @@
"edt_conf_smooth_heading_title": "Smoothing",
"edt_conf_smooth_interpolationRate_expl": "Speed of the calculation of smooth intermediate frames.",
"edt_conf_smooth_interpolationRate_title": "Interpolation Rate",
- "edt_conf_smooth_outputRate_expl": "The output speed to your led controller.",
+ "edt_conf_smooth_outputRate_expl": "The output speed to your LED controller.",
"edt_conf_smooth_outputRate_title": "Output Rate",
"edt_conf_smooth_time_ms_expl": "How long should the smoothing gather pictures?",
"edt_conf_smooth_time_ms_title": "Time",
@@ -415,7 +415,7 @@
"edt_conf_smooth_type_title": "Type",
"edt_conf_smooth_updateDelay_expl": "Delay the output in case your ambient light is faster than your TV.",
"edt_conf_smooth_updateDelay_title": "Update delay",
- "edt_conf_smooth_updateFrequency_expl": "The output speed to your led controller.",
+ "edt_conf_smooth_updateFrequency_expl": "The output speed to your LED controller.",
"edt_conf_smooth_updateFrequency_title": "Update frequency",
"edt_conf_v4l2_blueSignalThreshold_expl": "Darkens low blue values (recognized as black)",
"edt_conf_v4l2_blueSignalThreshold_title": "Blue signal threshold",
@@ -642,8 +642,8 @@
"edt_eff_interval": "Interval",
"edt_eff_knightrider_header": "Knight Rider",
"edt_eff_knightrider_header_desc": "K.I.T.T is back! The front-scanner of the well known car, this time not just in red.",
- "edt_eff_ledlist": "Led List",
- "edt_eff_ledtest_header": "Led Test",
+ "edt_eff_ledlist": "LED List",
+ "edt_eff_ledtest_header": "LED Test",
"edt_eff_ledtest_header_desc": "Rotating output: Red, Green, Blue, White, Black",
"edt_eff_length": "Length",
"edt_eff_lightclock_header": "Light Clock",
@@ -659,7 +659,7 @@
"edt_eff_moodblobs_header_desc": "Relax at the evening with slow moving and color changing blobs.",
"edt_eff_offset": "Offset",
"edt_eff_pacman_header": "Pac-Man",
- "edt_eff_pacman_header_desc": "Small hungry and yellow. Who will survive?",
+ "edt_eff_pacman_header_desc": "Small, hungry and yellow. Who will survive?",
"edt_eff_plasma_header": "Plasma",
"edt_eff_plasma_header_desc": "Color distortion in different directions",
"edt_eff_police_header": "Police",
@@ -820,32 +820,32 @@
"infoDialog_general_error_title": "Error",
"infoDialog_general_success_title": "Success",
"infoDialog_general_warning_title": "Warning",
- "infoDialog_import_comperror_text": "Sad! Your browser doesn't support a import. Please try again with another browser.",
+ "infoDialog_import_comperror_text": "Sad! Your browser doesn't support importing. Please try again with another browser.",
"infoDialog_import_confirm_text": "Are you sure to import \"$1\"? This process can't be reverted!",
"infoDialog_import_confirm_title": "Confirm import",
"infoDialog_import_hyperror_text": "The selected configuration file \"$1\" can't be imported. It's not compatible with Hyperion 2.0 and higher!",
- "infoDialog_import_jsonerror_text": "The selected configuration file \"$1\" is no .json file or it's corrupted. Error message: ($2)",
+ "infoDialog_import_jsonerror_text": "The selected configuration file \"$1\" is not a .json file, or it's corrupted. Error message: ($2)",
"infoDialog_wizrgb_text": "Your RGB Byte Order is already well adjusted.",
"infoDialog_writeconf_error_text": "Saving your configuration failed.",
- "infoDialog_writeimage_error_text": "The selected file \"$1\" is no image file or it's corrupted! Please select another image file.",
+ "infoDialog_writeimage_error_text": "The selected file \"$1\" is not an image file, or it's corrupted! Please select another image file.",
"info_404": "The page you requested is not available!",
- "info_conlost_label_autorecon": "We reconnect again after Hyperion is available.",
+ "info_conlost_label_autorecon": "Will reconnect again after Hyperion is available.",
"info_conlost_label_autorefresh": "This page will be automatically refreshed.",
"info_conlost_label_reason": "Possible reasons:",
"info_conlost_label_reason1": "- Bad WLAN connection",
- "info_conlost_label_reason2": "- You perform an update",
+ "info_conlost_label_reason2": "- You performed an update",
"info_conlost_label_reason3": "- Hyperion isn't running",
- "info_conlost_label_reload": "Auto reconnect stopped - limit exceeded, please refresh page or click me.",
+ "info_conlost_label_reload": "Auto reconnect stopped - limit exceeded. Please refresh page, or click me!",
"info_conlost_label_title": "Lost connection to Hyperion service!",
"info_restart_contus": "If you still hang around here after 20 seconds and you have no clue why please open a new topic at our support forum...",
"info_restart_contusa": "...with your last steps. Thank you!",
"info_restart_rightback": "Hyperion will be right back immediately!",
- "info_restart_title": "Restarts currently...",
+ "info_restart_title": "Currently restarting...",
"main_ledsim_btn_togglelednumber": "LED numbers",
"main_ledsim_btn_toggleleds": "Show LEDs",
"main_ledsim_btn_togglelivevideo": "Live video",
"main_ledsim_btn_togglesigdetect": "Signal detection area",
- "main_ledsim_text": "Live visualization of led colors and optional the current video stream of your capture device.",
+ "main_ledsim_text": "Live visualization of LED colors and optional the current video stream of your capture device.",
"main_ledsim_title": "LED Visualization",
"main_menu_about_token": "About Hyperion",
"main_menu_colors_conf_token": "Image Processing",
@@ -865,10 +865,10 @@
"main_menu_system_token": "System",
"main_menu_update_token": "Update",
"main_menu_webconfig_token": "Web configuration",
- "remote_adjustment_intro": "Modify color/brightness/compensation during runtime. $1",
+ "remote_adjustment_intro": "Modify color/brightness/compensation at runtime. $1",
"remote_adjustment_label": "Color adjustment",
"remote_color_button_reset": "Reset Color/Effect",
- "remote_color_intro": "Set an effect or color. Also your self created effects are listed (if available). $1",
+ "remote_color_intro": "Set an effect or color. Also the effects created by yourself are listed (if available). $1",
"remote_color_label": "Colors/Effects",
"remote_color_label_color": "Color:",
"remote_components_intro": "Enable and disable components of Hyperion during runtime. $1",
@@ -887,8 +887,8 @@
"remote_input_setsource_btn": "Select Source",
"remote_input_sourceactiv_btn": "Source active",
"remote_input_status": "Status/Action",
- "remote_losthint": "Note: All changes are lost after a restart.",
- "remote_maptype_intro": "Usually the led layout defines which LED covers a specific picture area, you could change it here: $1.",
+ "remote_losthint": "Note: All changes will be lost after a restart.",
+ "remote_maptype_intro": "Usually the LED layout defines which LED covers a specific picture area. You can change it here: $1.",
"remote_maptype_label": "Mapping type",
"remote_maptype_label_multicolor_mean": "Multicolor",
"remote_maptype_label_unicolor_mean": "Unicolor",
@@ -899,7 +899,7 @@
"remote_videoMode_2D": "2D",
"remote_videoMode_3DSBS": "3DSBS",
"remote_videoMode_3DTAB": "3DTAB",
- "remote_videoMode_intro": "Switch between different video modes to enjoy 3D movies! Supported are all capture devices. $1",
+ "remote_videoMode_intro": "Switch between different video modes to enjoy 3D movies! All capture devices are supported. $1",
"remote_videoMode_label": "Video mode",
"support_label_affinstr1": "Click on the appropriate link of your country",
"support_label_affinstr2": "Everything you buy (doesn't matter what) we get a small fee based on your turnover",
@@ -913,7 +913,7 @@
"support_label_ggtext": "Circle us on Google +!",
"support_label_ghtext": "Visit us on GitHub",
"support_label_igtext": "Visit us on Instagram to watch the latest Hyperion pictures!",
- "support_label_intro": "Hyperion is a free non-profit software. A small team is working on it and this is why we need your steady support.",
+ "support_label_intro": "Hyperion is a free, non-profit software. A small team is working on it and this is why we need your steady support.",
"support_label_spreadtheword": "Spread the word",
"support_label_title": "Support Hyperion",
"support_label_twtext": "Share and follow on Twitter, be always up to date with latest post about the Hyperion development",
@@ -940,7 +940,7 @@
"wiz_cc_btn_stop": "Stop video",
"wiz_cc_btn_switchpic": "Switch picture",
"wiz_cc_chooseid": "Define a name for this color profile.",
- "wiz_cc_intro1": "This wizard will guide you through your led calibration. If you are using Kodi, the calibration pictures and videos can be sent directly to it. Prerequisite: You need to enable \"Allow remote control from applications on other systems\" in Kodi.
Alternatively, you might want downloading these files yourself and display them when the wizard asks you to adjust the setting.",
+ "wiz_cc_intro1": "This wizard will guide you through your LED calibration. If you are using Kodi, the calibration pictures and videos can be sent directly to it. Prerequisite: You need to enable \"Allow remote control from applications on other systems\" in Kodi.
Alternatively, you might want downloading these files yourself and display them when the wizard asks you to adjust the setting.",
"wiz_cc_kodicon": "Kodi found, proceed with Kodi support.",
"wiz_cc_kodidiscon": "Kodi not found, proceed without Kodi support (please check, if remote control by other systems is activated).",
"wiz_cc_kodidisconlink": "Download link pictures:",
diff --git a/dependencies/external/rpi_ws281x b/dependencies/external/rpi_ws281x
index 3a20f1bd..0814bae5 160000
--- a/dependencies/external/rpi_ws281x
+++ b/dependencies/external/rpi_ws281x
@@ -1 +1 @@
-Subproject commit 3a20f1bdd740a144de180a07d8d3317920459d2d
+Subproject commit 0814bae544f0184ab1600bc2660486874eef5970
diff --git a/include/hyperion/ImageToLedsMap.h b/include/hyperion/ImageToLedsMap.h
index 71cfc9de..779082ab 100644
--- a/include/hyperion/ImageToLedsMap.h
+++ b/include/hyperion/ImageToLedsMap.h
@@ -154,7 +154,7 @@ namespace hyperion
const unsigned _verticalBorder;
/// The absolute indices into the image for each led
- std::vector> _colorsMap;
+ std::vector> _colorsMap;
///
/// Calculates the 'mean color' of the given list. This is the mean over each color-channel
@@ -166,7 +166,7 @@ namespace hyperion
/// @return The mean of the given list of colors (or black when empty)
///
template
- ColorRgb calcMeanColor(const Image & image, const std::vector & colors) const
+ ColorRgb calcMeanColor(const Image & image, const std::vector & colors) const
{
const auto colorVecSize = colors.size();
diff --git a/libsrc/hyperion/Hyperion.cpp b/libsrc/hyperion/Hyperion.cpp
index e20cca5c..23ba6e82 100644
--- a/libsrc/hyperion/Hyperion.cpp
+++ b/libsrc/hyperion/Hyperion.cpp
@@ -580,7 +580,7 @@ void Hyperion::update()
// copy image & process OR copy ledColors from muxer
Image image = priorityInfo.image;
- if(image.size() > 3)
+ if (image.width() > 1 || image.height() > 1)
{
emit currentImage(image);
_ledBuffer = _imageProcessor->process(image);
diff --git a/libsrc/hyperion/ImageProcessor.cpp b/libsrc/hyperion/ImageProcessor.cpp
index cf47425c..e442f086 100644
--- a/libsrc/hyperion/ImageProcessor.cpp
+++ b/libsrc/hyperion/ImageProcessor.cpp
@@ -28,7 +28,7 @@ QString ImageProcessor::mappingTypeToStr(int mappingType)
ImageProcessor::ImageProcessor(const LedString& ledString, Hyperion* hyperion)
: QObject(hyperion)
- , _log(Logger::getInstance("BLACKBORDER"))
+ , _log(Logger::getInstance("IMAGETOLED"))
, _ledString(ledString)
, _borderProcessor(new BlackBorderProcessor(hyperion, this))
, _imageToLeds(nullptr)
diff --git a/libsrc/hyperion/ImageToLedsMap.cpp b/libsrc/hyperion/ImageToLedsMap.cpp
index caebe20b..783fdedd 100644
--- a/libsrc/hyperion/ImageToLedsMap.cpp
+++ b/libsrc/hyperion/ImageToLedsMap.cpp
@@ -59,7 +59,7 @@ ImageToLedsMap::ImageToLedsMap(
const auto maxYLedCount = qMin(maxY_idx, yOffset+actualHeight);
const auto maxXLedCount = qMin(maxX_idx, xOffset+actualWidth);
- std::vector ledColors;
+ std::vector ledColors;
ledColors.reserve((size_t) maxXLedCount*maxYLedCount);
for (unsigned y = minY_idx; y < maxYLedCount; ++y)
diff --git a/libsrc/leddevice/dev_other/LedDeviceFile.cpp b/libsrc/leddevice/dev_other/LedDeviceFile.cpp
index bb26a371..0dba14d8 100644
--- a/libsrc/leddevice/dev_other/LedDeviceFile.cpp
+++ b/libsrc/leddevice/dev_other/LedDeviceFile.cpp
@@ -114,7 +114,7 @@ int LedDeviceFile::write(const std::vector & ledValues)
}
#if (QT_VERSION >= QT_VERSION_CHECK(5, 14, 0))
- out << "]" << Qt::endl;
+ out << QString("]") << Qt::endl;
#else
out << "]" << endl;
#endif