mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-12-18 19:16:42 +03:00
Compare commits
30 Commits
e888581660
...
782ea8f8c6
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
782ea8f8c6 | ||
|
|
e79ff9a079 | ||
|
|
fe47620153 | ||
|
|
8520ade5c4 | ||
|
|
1c7ed45f21 | ||
|
|
130c7c9eec | ||
|
|
26e630aa8c | ||
|
|
a478da45a3 | ||
|
|
694f72d577 | ||
|
|
1e42cedf9e | ||
|
|
a35a0fc8ba | ||
|
|
10b7ffe3d1 | ||
|
|
42c6cfc9a2 | ||
|
|
e8bf570d21 | ||
|
|
cdbd9038b8 | ||
|
|
1e05abb0ea | ||
|
|
70d1c2e041 | ||
|
|
f4d128b3ee | ||
|
|
dd64ffca6c | ||
|
|
fce1f78bdc | ||
|
|
69ca63d608 | ||
|
|
111b83e8e3 | ||
|
|
198733b729 | ||
|
|
03d9fd6f19 | ||
|
|
f90a54f1d9 | ||
|
|
bbec4c4a60 | ||
|
|
9fe16d7b17 | ||
|
|
dc886b11f3 | ||
|
|
3bbe24f5f8 | ||
|
|
f6746c0d9a |
@ -81,3 +81,5 @@ librosa==0.11.*
|
||||
soundfile==0.13.*
|
||||
# DeGirum detector
|
||||
degirum == 0.16.*
|
||||
# Memory profiling
|
||||
memray == 1.15.*
|
||||
|
||||
@ -2,7 +2,7 @@ variable "AMDGPU" {
|
||||
default = "gfx900"
|
||||
}
|
||||
variable "ROCM" {
|
||||
default = "7.1"
|
||||
default = "7.1.0"
|
||||
}
|
||||
variable "HSA_OVERRIDE_GFX_VERSION" {
|
||||
default = ""
|
||||
|
||||
@ -232,7 +232,7 @@ When your browser runs into problems playing back your camera streams, it will l
|
||||
- **mse-decode**
|
||||
|
||||
- What it means: The browser reported a decoding error while trying to play the stream, which usually is a result of a codec incompatibility or corrupted frames.
|
||||
- What to try: Ensure your camera/restream is using H.264 video and AAC audio (these are the most compatible). If your camera uses a non-standard audio codec, configure `go2rtc` to transcode the stream to AAC. Try another browser (some browsers have stricter MSE/codec support) and, for iPhone, ensure you're on iOS 17.1 or newer.
|
||||
- What to try: Check the browser console for the supported and negotiated codecs. Ensure your camera/restream is using H.264 video and AAC audio (these are the most compatible). If your camera uses a non-standard audio codec, configure `go2rtc` to transcode the stream to AAC. Try another browser (some browsers have stricter MSE/codec support) and, for iPhone, ensure you're on iOS 17.1 or newer.
|
||||
|
||||
- Possible console messages from the player code:
|
||||
|
||||
|
||||
129
docs/docs/troubleshooting/memory.md
Normal file
129
docs/docs/troubleshooting/memory.md
Normal file
@ -0,0 +1,129 @@
|
||||
---
|
||||
id: memory
|
||||
title: Memory Troubleshooting
|
||||
---
|
||||
|
||||
Frigate includes built-in memory profiling using [memray](https://bloomberg.github.io/memray/) to help diagnose memory issues. This feature allows you to profile specific Frigate modules to identify memory leaks, excessive allocations, or other memory-related problems.
|
||||
|
||||
## Enabling Memory Profiling
|
||||
|
||||
Memory profiling is controlled via the `FRIGATE_MEMRAY_MODULES` environment variable. Set it to a comma-separated list of module names you want to profile:
|
||||
|
||||
```bash
|
||||
export FRIGATE_MEMRAY_MODULES="frigate.review_segment_manager,frigate.capture"
|
||||
```
|
||||
|
||||
### Module Names
|
||||
|
||||
Frigate processes are named using a module-based naming scheme. Common module names include:
|
||||
|
||||
- `frigate.review_segment_manager` - Review segment processing
|
||||
- `frigate.recording_manager` - Recording management
|
||||
- `frigate.capture` - Camera capture processes (all cameras with this module name)
|
||||
- `frigate.process` - Camera processing/tracking (all cameras with this module name)
|
||||
- `frigate.output` - Output processing
|
||||
- `frigate.audio_manager` - Audio processing
|
||||
- `frigate.embeddings` - Embeddings processing
|
||||
|
||||
You can also specify the full process name (including camera-specific identifiers) if you want to profile a specific camera:
|
||||
|
||||
```bash
|
||||
export FRIGATE_MEMRAY_MODULES="frigate.capture:front_door"
|
||||
```
|
||||
|
||||
When you specify a module name (e.g., `frigate.capture`), all processes with that module prefix will be profiled. For example, `frigate.capture` will profile all camera capture processes.
|
||||
|
||||
## How It Works
|
||||
|
||||
1. **Binary File Creation**: When profiling is enabled, memray creates a binary file (`.bin`) in `/config/memray_reports/` that is updated continuously in real-time as the process runs.
|
||||
|
||||
2. **Automatic HTML Generation**: On normal process exit, Frigate automatically:
|
||||
|
||||
- Stops memray tracking
|
||||
- Generates an HTML flamegraph report
|
||||
- Saves it to `/config/memray_reports/<module_name>.html`
|
||||
|
||||
3. **Crash Recovery**: If a process crashes (SIGKILL, segfault, etc.), the binary file is preserved with all data up to the crash point. You can manually generate the HTML report from the binary file.
|
||||
|
||||
## Viewing Reports
|
||||
|
||||
### Automatic Reports
|
||||
|
||||
After a process exits normally, you'll find HTML reports in `/config/memray_reports/`. Open these files in a web browser to view interactive flamegraphs showing memory usage patterns.
|
||||
|
||||
### Manual Report Generation
|
||||
|
||||
If a process crashes or you want to generate a report from an existing binary file, you can manually create the HTML report:
|
||||
|
||||
```bash
|
||||
memray flamegraph /config/memray_reports/<module_name>.bin
|
||||
```
|
||||
|
||||
This will generate an HTML file that you can open in your browser.
|
||||
|
||||
## Understanding the Reports
|
||||
|
||||
Memray flamegraphs show:
|
||||
|
||||
- **Memory allocations over time**: See where memory is being allocated in your code
|
||||
- **Call stacks**: Understand the full call chain leading to allocations
|
||||
- **Memory hotspots**: Identify functions or code paths that allocate the most memory
|
||||
- **Memory leaks**: Spot patterns where memory is allocated but not freed
|
||||
|
||||
The interactive HTML reports allow you to:
|
||||
|
||||
- Zoom into specific time ranges
|
||||
- Filter by function names
|
||||
- View detailed allocation information
|
||||
- Export data for further analysis
|
||||
|
||||
## Best Practices
|
||||
|
||||
1. **Profile During Issues**: Enable profiling when you're experiencing memory issues, not all the time, as it adds some overhead.
|
||||
|
||||
2. **Profile Specific Modules**: Instead of profiling everything, focus on the modules you suspect are causing issues.
|
||||
|
||||
3. **Let Processes Run**: Allow processes to run for a meaningful duration to capture representative memory usage patterns.
|
||||
|
||||
4. **Check Binary Files**: If HTML reports aren't generated automatically (e.g., after a crash), check for `.bin` files in `/config/memray_reports/` and generate reports manually.
|
||||
|
||||
5. **Compare Reports**: Generate reports at different times to compare memory usage patterns and identify trends.
|
||||
|
||||
## Troubleshooting
|
||||
|
||||
### No Reports Generated
|
||||
|
||||
- Check that the environment variable is set correctly
|
||||
- Verify the module name matches exactly (case-sensitive)
|
||||
- Check logs for memray-related errors
|
||||
- Ensure `/config/memray_reports/` directory exists and is writable
|
||||
|
||||
### Process Crashed Before Report Generation
|
||||
|
||||
- Look for `.bin` files in `/config/memray_reports/`
|
||||
- Manually generate HTML reports using: `memray flamegraph <file>.bin`
|
||||
- The binary file contains all data up to the crash point
|
||||
|
||||
### Reports Show No Data
|
||||
|
||||
- Ensure the process ran long enough to generate meaningful data
|
||||
- Check that memray is properly installed (included by default in Frigate)
|
||||
- Verify the process actually started and ran (check process logs)
|
||||
|
||||
## Example Usage
|
||||
|
||||
```bash
|
||||
# Enable profiling for review and capture modules
|
||||
export FRIGATE_MEMRAY_MODULES="frigate.review_segment_manager,frigate.capture"
|
||||
|
||||
# Start Frigate
|
||||
# ... let it run for a while ...
|
||||
|
||||
# Check for reports
|
||||
ls -lh /config/memray_reports/
|
||||
|
||||
# If a process crashed, manually generate report
|
||||
memray flamegraph /config/memray_reports/frigate_capture_front_door.bin
|
||||
```
|
||||
|
||||
For more information about memray and interpreting reports, see the [official memray documentation](https://bloomberg.github.io/memray/).
|
||||
@ -131,6 +131,7 @@ const sidebars: SidebarsConfig = {
|
||||
"troubleshooting/recordings",
|
||||
"troubleshooting/gpu",
|
||||
"troubleshooting/edgetpu",
|
||||
"troubleshooting/memory",
|
||||
],
|
||||
Development: [
|
||||
"development/contributing",
|
||||
|
||||
@ -1753,7 +1753,7 @@ def create_trigger_embedding(
|
||||
body.data, (base64.b64encode(thumbnail).decode("ASCII"))
|
||||
)
|
||||
|
||||
if embedding is None:
|
||||
if not embedding:
|
||||
return JSONResponse(
|
||||
content={
|
||||
"success": False,
|
||||
@ -1888,7 +1888,7 @@ def update_trigger_embedding(
|
||||
body.data, (base64.b64encode(thumbnail).decode("ASCII"))
|
||||
)
|
||||
|
||||
if embedding is None:
|
||||
if not embedding:
|
||||
return JSONResponse(
|
||||
content={
|
||||
"success": False,
|
||||
|
||||
@ -2,7 +2,6 @@ import glob
|
||||
import logging
|
||||
import os
|
||||
import shutil
|
||||
import time
|
||||
import urllib.request
|
||||
import zipfile
|
||||
from queue import Queue
|
||||
@ -55,6 +54,9 @@ class MemryXDetector(DetectionApi):
|
||||
)
|
||||
return
|
||||
|
||||
# Initialize stop_event as None, will be set later by set_stop_event()
|
||||
self.stop_event = None
|
||||
|
||||
model_cfg = getattr(detector_config, "model", None)
|
||||
|
||||
# Check if model_type was explicitly set by the user
|
||||
@ -363,26 +365,43 @@ class MemryXDetector(DetectionApi):
|
||||
def process_input(self):
|
||||
"""Input callback function: wait for frames in the input queue, preprocess, and send to MX3 (return)"""
|
||||
while True:
|
||||
# Check if shutdown is requested
|
||||
if self.stop_event and self.stop_event.is_set():
|
||||
logger.debug("[process_input] Stop event detected, returning None")
|
||||
return None
|
||||
try:
|
||||
# Wait for a frame from the queue (blocking call)
|
||||
frame = self.capture_queue.get(
|
||||
block=True
|
||||
) # Blocks until data is available
|
||||
# Wait for a frame from the queue with timeout to check stop_event periodically
|
||||
frame = self.capture_queue.get(block=True, timeout=0.5)
|
||||
|
||||
return frame
|
||||
|
||||
except Exception as e:
|
||||
logger.info(f"[process_input] Error processing input: {e}")
|
||||
time.sleep(0.1) # Prevent busy waiting in case of error
|
||||
# Silently handle queue.Empty timeouts (expected during normal operation)
|
||||
# Log any other unexpected exceptions
|
||||
if "Empty" not in str(type(e).__name__):
|
||||
logger.warning(f"[process_input] Unexpected error: {e}")
|
||||
# Loop continues and will check stop_event at the top
|
||||
|
||||
def receive_output(self):
|
||||
"""Retrieve processed results from MemryX output queue + a copy of the original frame"""
|
||||
connection_id = (
|
||||
self.capture_id_queue.get()
|
||||
) # Get the corresponding connection ID
|
||||
detections = self.output_queue.get() # Get detections from MemryX
|
||||
try:
|
||||
# Get connection ID with timeout
|
||||
connection_id = self.capture_id_queue.get(
|
||||
block=True, timeout=1.0
|
||||
) # Get the corresponding connection ID
|
||||
detections = self.output_queue.get() # Get detections from MemryX
|
||||
|
||||
return connection_id, detections
|
||||
return connection_id, detections
|
||||
|
||||
except Exception as e:
|
||||
# On timeout or stop event, return None
|
||||
if self.stop_event and self.stop_event.is_set():
|
||||
logger.debug("[receive_output] Stop event detected, exiting")
|
||||
# Silently handle queue.Empty timeouts, they're expected during normal operation
|
||||
elif "Empty" not in str(type(e).__name__):
|
||||
logger.warning(f"[receive_output] Error receiving output: {e}")
|
||||
|
||||
return None, None
|
||||
|
||||
def post_process_yolonas(self, output):
|
||||
predictions = output[0]
|
||||
@ -831,6 +850,19 @@ class MemryXDetector(DetectionApi):
|
||||
f"{self.memx_model_type} is currently not supported for memryx. See the docs for more info on supported models."
|
||||
)
|
||||
|
||||
def set_stop_event(self, stop_event):
|
||||
"""Set the stop event for graceful shutdown."""
|
||||
self.stop_event = stop_event
|
||||
|
||||
def shutdown(self):
|
||||
"""Gracefully shutdown the MemryX accelerator"""
|
||||
try:
|
||||
if hasattr(self, "accl") and self.accl is not None:
|
||||
self.accl.shutdown()
|
||||
logger.info("MemryX accelerator shutdown complete")
|
||||
except Exception as e:
|
||||
logger.error(f"Error during MemryX shutdown: {e}")
|
||||
|
||||
def detect_raw(self, tensor_input: np.ndarray):
|
||||
"""Removed synchronous detect_raw() function so that we only use async"""
|
||||
return 0
|
||||
|
||||
@ -43,6 +43,7 @@ class BaseLocalDetector(ObjectDetector):
|
||||
self,
|
||||
detector_config: BaseDetectorConfig = None,
|
||||
labels: str = None,
|
||||
stop_event: MpEvent = None,
|
||||
):
|
||||
self.fps = EventsPerSecond()
|
||||
if labels is None:
|
||||
@ -60,6 +61,10 @@ class BaseLocalDetector(ObjectDetector):
|
||||
|
||||
self.detect_api = create_detector(detector_config)
|
||||
|
||||
# If the detector supports stop_event, pass it
|
||||
if hasattr(self.detect_api, "set_stop_event") and stop_event:
|
||||
self.detect_api.set_stop_event(stop_event)
|
||||
|
||||
def _transform_input(self, tensor_input: np.ndarray) -> np.ndarray:
|
||||
if self.input_transform:
|
||||
tensor_input = np.transpose(tensor_input, self.input_transform)
|
||||
@ -240,6 +245,10 @@ class AsyncDetectorRunner(FrigateProcess):
|
||||
while not self.stop_event.is_set():
|
||||
connection_id, detections = self._detector.async_receive_output()
|
||||
|
||||
# Handle timeout case (queue.Empty) - just continue
|
||||
if connection_id is None:
|
||||
continue
|
||||
|
||||
if not self.send_times:
|
||||
# guard; shouldn't happen if send/recv are balanced
|
||||
continue
|
||||
@ -266,21 +275,38 @@ class AsyncDetectorRunner(FrigateProcess):
|
||||
|
||||
self._frame_manager = SharedMemoryFrameManager()
|
||||
self._publisher = ObjectDetectorPublisher()
|
||||
self._detector = AsyncLocalObjectDetector(detector_config=self.detector_config)
|
||||
self._detector = AsyncLocalObjectDetector(
|
||||
detector_config=self.detector_config, stop_event=self.stop_event
|
||||
)
|
||||
|
||||
for name in self.cameras:
|
||||
self.create_output_shm(name)
|
||||
|
||||
t_detect = threading.Thread(target=self._detect_worker, daemon=True)
|
||||
t_result = threading.Thread(target=self._result_worker, daemon=True)
|
||||
t_detect = threading.Thread(target=self._detect_worker, daemon=False)
|
||||
t_result = threading.Thread(target=self._result_worker, daemon=False)
|
||||
t_detect.start()
|
||||
t_result.start()
|
||||
|
||||
while not self.stop_event.is_set():
|
||||
time.sleep(0.5)
|
||||
try:
|
||||
while not self.stop_event.is_set():
|
||||
time.sleep(0.5)
|
||||
|
||||
self._publisher.stop()
|
||||
logger.info("Exited async detection process...")
|
||||
logger.info(
|
||||
"Stop event detected, waiting for detector threads to finish..."
|
||||
)
|
||||
|
||||
# Wait for threads to finish processing
|
||||
t_detect.join(timeout=5)
|
||||
t_result.join(timeout=5)
|
||||
|
||||
# Shutdown the AsyncDetector
|
||||
self._detector.detect_api.shutdown()
|
||||
|
||||
self._publisher.stop()
|
||||
except Exception as e:
|
||||
logger.error(f"Error during async detector shutdown: {e}")
|
||||
finally:
|
||||
logger.info("Exited Async detection process...")
|
||||
|
||||
|
||||
class ObjectDetectProcess:
|
||||
@ -308,7 +334,7 @@ class ObjectDetectProcess:
|
||||
# if the process has already exited on its own, just return
|
||||
if self.detect_process and self.detect_process.exitcode:
|
||||
return
|
||||
self.detect_process.terminate()
|
||||
|
||||
logging.info("Waiting for detection process to exit gracefully...")
|
||||
self.detect_process.join(timeout=30)
|
||||
if self.detect_process.exitcode is None:
|
||||
|
||||
@ -1,7 +1,10 @@
|
||||
import atexit
|
||||
import faulthandler
|
||||
import logging
|
||||
import multiprocessing as mp
|
||||
import os
|
||||
import pathlib
|
||||
import subprocess
|
||||
import threading
|
||||
from logging.handlers import QueueHandler
|
||||
from multiprocessing.synchronize import Event as MpEvent
|
||||
@ -48,6 +51,7 @@ class FrigateProcess(BaseProcess):
|
||||
|
||||
def before_start(self) -> None:
|
||||
self.__log_queue = frigate.log.log_listener.queue
|
||||
self.__memray_tracker = None
|
||||
|
||||
def pre_run_setup(self, logConfig: LoggerConfig | None = None) -> None:
|
||||
os.nice(self.priority)
|
||||
@ -64,3 +68,86 @@ class FrigateProcess(BaseProcess):
|
||||
frigate.log.apply_log_levels(
|
||||
logConfig.default.value.upper(), logConfig.logs
|
||||
)
|
||||
|
||||
self._setup_memray()
|
||||
|
||||
def _setup_memray(self) -> None:
|
||||
"""Setup memray profiling if enabled via environment variable."""
|
||||
memray_modules = os.environ.get("FRIGATE_MEMRAY_MODULES", "")
|
||||
|
||||
if not memray_modules:
|
||||
return
|
||||
|
||||
# Extract module name from process name (e.g., "frigate.capture:camera" -> "frigate.capture")
|
||||
process_name = self.name
|
||||
module_name = (
|
||||
process_name.split(":")[0] if ":" in process_name else process_name
|
||||
)
|
||||
|
||||
enabled_modules = [m.strip() for m in memray_modules.split(",")]
|
||||
|
||||
if module_name not in enabled_modules and process_name not in enabled_modules:
|
||||
return
|
||||
|
||||
try:
|
||||
import memray
|
||||
|
||||
reports_dir = pathlib.Path("/config/memray_reports")
|
||||
reports_dir.mkdir(parents=True, exist_ok=True)
|
||||
safe_name = (
|
||||
process_name.replace(":", "_").replace("/", "_").replace("\\", "_")
|
||||
)
|
||||
|
||||
binary_file = reports_dir / f"{safe_name}.bin"
|
||||
|
||||
self.__memray_tracker = memray.Tracker(str(binary_file))
|
||||
self.__memray_tracker.__enter__()
|
||||
|
||||
# Register cleanup handler to stop tracking and generate HTML report
|
||||
# atexit runs on normal exits and most signal-based terminations (SIGTERM, SIGINT)
|
||||
# For hard kills (SIGKILL) or segfaults, the binary file is preserved for manual generation
|
||||
atexit.register(self._cleanup_memray, safe_name, binary_file)
|
||||
|
||||
self.logger.info(
|
||||
f"Memray profiling enabled for module {module_name} (process: {self.name}). "
|
||||
f"Binary file (updated continuously): {binary_file}. "
|
||||
f"HTML report will be generated on exit: {reports_dir}/{safe_name}.html. "
|
||||
f"If process crashes, manually generate with: memray flamegraph {binary_file}"
|
||||
)
|
||||
except Exception as e:
|
||||
self.logger.error(f"Failed to setup memray profiling: {e}", exc_info=True)
|
||||
|
||||
def _cleanup_memray(self, safe_name: str, binary_file: pathlib.Path) -> None:
|
||||
"""Stop memray tracking and generate HTML report."""
|
||||
if self.__memray_tracker is None:
|
||||
return
|
||||
|
||||
try:
|
||||
self.__memray_tracker.__exit__(None, None, None)
|
||||
self.__memray_tracker = None
|
||||
|
||||
reports_dir = pathlib.Path("/config/memray_reports")
|
||||
html_file = reports_dir / f"{safe_name}.html"
|
||||
|
||||
result = subprocess.run(
|
||||
["memray", "flamegraph", "--output", str(html_file), str(binary_file)],
|
||||
capture_output=True,
|
||||
text=True,
|
||||
timeout=10,
|
||||
)
|
||||
|
||||
if result.returncode == 0:
|
||||
self.logger.info(f"Memray report generated: {html_file}")
|
||||
else:
|
||||
self.logger.error(
|
||||
f"Failed to generate memray report: {result.stderr}. "
|
||||
f"Binary file preserved at {binary_file} for manual generation."
|
||||
)
|
||||
|
||||
# Keep the binary file for manual report generation if needed
|
||||
# Users can run: memray flamegraph {binary_file}
|
||||
|
||||
except subprocess.TimeoutExpired:
|
||||
self.logger.error("Memray report generation timed out")
|
||||
except Exception as e:
|
||||
self.logger.error(f"Failed to cleanup memray profiling: {e}", exc_info=True)
|
||||
|
||||
19
web/package-lock.json
generated
19
web/package-lock.json
generated
@ -88,7 +88,7 @@
|
||||
"@tailwindcss/forms": "^0.5.9",
|
||||
"@testing-library/jest-dom": "^6.6.2",
|
||||
"@types/lodash": "^4.17.12",
|
||||
"@types/node": "^20.14.10",
|
||||
"@types/node": "^24.9.2",
|
||||
"@types/react": "^18.3.2",
|
||||
"@types/react-dom": "^18.3.0",
|
||||
"@types/react-grid-layout": "^1.3.5",
|
||||
@ -3867,13 +3867,13 @@
|
||||
"license": "MIT"
|
||||
},
|
||||
"node_modules/@types/node": {
|
||||
"version": "20.14.10",
|
||||
"resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.10.tgz",
|
||||
"integrity": "sha512-MdiXf+nDuMvY0gJKxyfZ7/6UFsETO7mGKF54MVD/ekJS6HdFtpZFBgrh6Pseu64XTb2MLyFPlbW6hj8HYRQNOQ==",
|
||||
"version": "24.9.2",
|
||||
"resolved": "https://registry.npmjs.org/@types/node/-/node-24.9.2.tgz",
|
||||
"integrity": "sha512-uWN8YqxXxqFMX2RqGOrumsKeti4LlmIMIyV0lgut4jx7KQBcBiW6vkDtIBvHnHIquwNfJhk8v2OtmO8zXWHfPA==",
|
||||
"dev": true,
|
||||
"license": "MIT",
|
||||
"dependencies": {
|
||||
"undici-types": "~5.26.4"
|
||||
"undici-types": "~7.16.0"
|
||||
}
|
||||
},
|
||||
"node_modules/@types/prop-types": {
|
||||
@ -9674,10 +9674,11 @@
|
||||
}
|
||||
},
|
||||
"node_modules/undici-types": {
|
||||
"version": "5.26.5",
|
||||
"resolved": "https://registry.npmjs.org/undici-types/-/undici-types-5.26.5.tgz",
|
||||
"integrity": "sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==",
|
||||
"dev": true
|
||||
"version": "7.16.0",
|
||||
"resolved": "https://registry.npmjs.org/undici-types/-/undici-types-7.16.0.tgz",
|
||||
"integrity": "sha512-Zz+aZWSj8LE6zoxD+xrjh4VfkIG8Ya6LvYkZqtUQGJPZjYl53ypCaUwWqo7eI0x66KBGeRo+mlBEkMSeSZ38Nw==",
|
||||
"dev": true,
|
||||
"license": "MIT"
|
||||
},
|
||||
"node_modules/universalify": {
|
||||
"version": "0.2.0",
|
||||
|
||||
@ -94,7 +94,7 @@
|
||||
"@tailwindcss/forms": "^0.5.9",
|
||||
"@testing-library/jest-dom": "^6.6.2",
|
||||
"@types/lodash": "^4.17.12",
|
||||
"@types/node": "^20.14.10",
|
||||
"@types/node": "^24.9.2",
|
||||
"@types/react": "^18.3.2",
|
||||
"@types/react-dom": "^18.3.0",
|
||||
"@types/react-grid-layout": "^1.3.5",
|
||||
|
||||
@ -1 +1,5 @@
|
||||
{}
|
||||
{
|
||||
"form": {
|
||||
"user": "Потребителско име"
|
||||
}
|
||||
}
|
||||
|
||||
@ -8,5 +8,8 @@
|
||||
"lastHour_other": "Последните {{count}} часа"
|
||||
},
|
||||
"select": "Избери"
|
||||
},
|
||||
"restart": {
|
||||
"title": "Сигурен ли сте, че искате да рестартирате Frigate?"
|
||||
}
|
||||
}
|
||||
|
||||
@ -1 +1,5 @@
|
||||
{}
|
||||
{
|
||||
"iconPicker": {
|
||||
"selectIcon": "Изберете иконка"
|
||||
}
|
||||
}
|
||||
|
||||
@ -1 +1,7 @@
|
||||
{}
|
||||
{
|
||||
"button": {
|
||||
"downloadVideo": {
|
||||
"label": "Свали видео"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -18,5 +18,6 @@
|
||||
"bicycle": "Велосипед",
|
||||
"skateboard": "Скейтборд",
|
||||
"door": "Врата",
|
||||
"blender": "Блендер"
|
||||
"blender": "Блендер",
|
||||
"person": "Човек"
|
||||
}
|
||||
|
||||
@ -1 +1,3 @@
|
||||
{}
|
||||
{
|
||||
"documentTitle": "Експорт - Frigate"
|
||||
}
|
||||
|
||||
@ -63,5 +63,6 @@
|
||||
},
|
||||
"cameraSettings": {
|
||||
"cameraEnabled": "Камерата е включена"
|
||||
}
|
||||
},
|
||||
"documentTitle": "Наживо - Frigate"
|
||||
}
|
||||
|
||||
@ -104,7 +104,8 @@
|
||||
"anonymous": "Anònim",
|
||||
"logout": "Tanca la sessió",
|
||||
"current": "Usuari actual: {{user}}"
|
||||
}
|
||||
},
|
||||
"classification": "Classificació"
|
||||
},
|
||||
"pagination": {
|
||||
"previous": {
|
||||
@ -197,7 +198,10 @@
|
||||
"formattedTimestampMonthDayYearHourMinute": {
|
||||
"12hour": "MMM d yyyy, h:mm aaa",
|
||||
"24hour": "MMM d yyyy, HH:mm"
|
||||
}
|
||||
},
|
||||
"inProgress": "En curs",
|
||||
"invalidStartTime": "Hora d'inici no vàlida",
|
||||
"invalidEndTime": "Hora de finalització no vàlida"
|
||||
},
|
||||
"unit": {
|
||||
"speed": {
|
||||
@ -221,7 +225,9 @@
|
||||
"back": "Torna enrere",
|
||||
"hide": "Oculta {{item}}",
|
||||
"show": "Mostra {{item}}",
|
||||
"ID": "ID"
|
||||
"ID": "ID",
|
||||
"none": "Cap",
|
||||
"all": "Tots"
|
||||
},
|
||||
"button": {
|
||||
"apply": "Aplicar",
|
||||
@ -258,7 +264,8 @@
|
||||
"off": "APAGAT",
|
||||
"unselect": "Desseleccionar",
|
||||
"enable": "Habilitar",
|
||||
"enabled": "Habilitat"
|
||||
"enabled": "Habilitat",
|
||||
"continue": "Continua"
|
||||
},
|
||||
"toast": {
|
||||
"copyUrlToClipboard": "URL copiada al porta-retalls.",
|
||||
|
||||
@ -17,31 +17,40 @@
|
||||
"categorizedImage": "Imatge classificada amb èxit",
|
||||
"trainedModel": "Model entrenat amb èxit.",
|
||||
"trainingModel": "S'ha iniciat amb èxit la formació de models.",
|
||||
"deletedModel_one": "S'ha suprimit correctament el model {{count}}",
|
||||
"deletedModel_many": "S'han suprimit correctament {{count}} models",
|
||||
"deletedModel_other": "",
|
||||
"updatedModel": "S'ha actualitzat correctament la configuració del model"
|
||||
"deletedModel_one": "S'ha suprimit correctament {{count}} model",
|
||||
"deletedModel_many": "S'han suprimit correctament els {{count}} models",
|
||||
"deletedModel_other": "S'han suprimit correctament els {{count}} models",
|
||||
"updatedModel": "S'ha actualitzat correctament la configuració del model",
|
||||
"renamedCategory": "S'ha canviat el nom de la classe a {{name}}"
|
||||
},
|
||||
"error": {
|
||||
"deleteImageFailed": "No s'ha pogut suprimir: {{errorMessage}}",
|
||||
"deleteCategoryFailed": "No s'ha pogut suprimir la classe: {{errorMessage}}",
|
||||
"categorizeFailed": "No s'ha pogut categoritzar la imatge: {{errorMessage}}",
|
||||
"trainingFailed": "No s'ha pogut iniciar l'entrenament del model: {{errorMessage}}",
|
||||
"trainingFailed": "Ha fallat l'entrenament del model. Comproveu els registres de fragata per a més detalls.",
|
||||
"deleteModelFailed": "No s'ha pogut suprimir el model: {{errorMessage}}",
|
||||
"updateModelFailed": "No s'ha pogut actualitzar el model: {{errorMessage}}"
|
||||
"updateModelFailed": "No s'ha pogut actualitzar el model: {{errorMessage}}",
|
||||
"renameCategoryFailed": "No s'ha pogut canviar el nom de la classe: {{errorMessage}}",
|
||||
"trainingFailedToStart": "Errar en arrencar l'entrenament del model: {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"deleteCategory": {
|
||||
"title": "Suprimeix la classe",
|
||||
"desc": "Esteu segur que voleu suprimir la classe {{name}}? Això suprimirà permanentment totes les imatges associades i requerirà tornar a entrenar el model."
|
||||
"desc": "Esteu segur que voleu suprimir la classe {{name}}? Això suprimirà permanentment totes les imatges associades i requerirà tornar a entrenar el model.",
|
||||
"minClassesTitle": "No es pot suprimir la classe",
|
||||
"minClassesDesc": "Un model de classificació ha de tenir almenys 2 classes. Afegeix una altra classe abans d'eliminar aquesta."
|
||||
},
|
||||
"deleteDatasetImages": {
|
||||
"title": "Suprimeix les imatges del conjunt de dades",
|
||||
"desc": "Esteu segur que voleu suprimir {{count}} imatges de {{dataset}}? Aquesta acció no es pot desfer i requerirà tornar a entrenar el model."
|
||||
"desc_one": "Esteu segur que voleu suprimir {{count}} imatge de {{dataset}}? Aquesta acció no es pot desfer i requerirà tornar a entrenar el model.",
|
||||
"desc_many": "Esteu segur que voleu suprimir {{count}} imatges de {{dataset}}? Aquesta acció no es pot desfer i requerirà tornar a entrenar el model.",
|
||||
"desc_other": "Esteu segur que voleu suprimir {{count}} imatges de {{dataset}}? Aquesta acció no es pot desfer i requerirà tornar a entrenar el model."
|
||||
},
|
||||
"deleteTrainImages": {
|
||||
"title": "Suprimeix les imatges del tren",
|
||||
"desc": "Esteu segur que voleu suprimir {{count}} imatges? Aquesta acció no es pot desfer."
|
||||
"desc_one": "Esteu segur que voleu suprimir {{count}} imatge? Aquesta acció no es pot desfer.",
|
||||
"desc_many": "Esteu segur que voleu suprimir {{count}} imatges? Aquesta acció no es pot desfer.",
|
||||
"desc_other": "Esteu segur que voleu suprimir {{count}} imatges? Aquesta acció no es pot desfer."
|
||||
},
|
||||
"renameCategory": {
|
||||
"title": "Reanomena la classe",
|
||||
@ -140,13 +149,18 @@
|
||||
"generationFailed": "Ha fallat la generació. Torneu-ho a provar.",
|
||||
"classifyFailed": "No s'han pogut classificar les imatges: {{error}}"
|
||||
},
|
||||
"generateSuccess": "Imatges de mostra generades amb èxit"
|
||||
"generateSuccess": "Imatges de mostra generades amb èxit",
|
||||
"allImagesRequired_one": "Classifiqueu totes les imatges. Queda {{count}} imatge.",
|
||||
"allImagesRequired_many": "Classifiqueu totes les imatges. Queden {{count}} imatges.",
|
||||
"allImagesRequired_other": "Classifiqueu totes les imatges. Queden {{count}} imatges."
|
||||
}
|
||||
},
|
||||
"deleteModel": {
|
||||
"title": "Suprimeix el model de classificació",
|
||||
"single": "Esteu segur que voleu suprimir {{name}}? Això suprimirà permanentment totes les dades associades, incloses les imatges i les dades d'entrenament. Aquesta acció no es pot desfer.",
|
||||
"desc": "Esteu segur que voleu suprimir {{count}} model(s)? Això suprimirà permanentment totes les dades associades, incloses les imatges i les dades d'entrenament. Aquesta acció no es pot desfer."
|
||||
"desc_one": "Esteu segur que voleu suprimir el model {{count}}? Això suprimirà permanentment totes les dades associades, incloses les imatges i les dades d'entrenament. Aquesta acció no es pot desfer.",
|
||||
"desc_many": "Esteu segur que voleu suprimir {{count}} models? Això suprimirà permanentment totes les dades associades, incloses les imatges i les dades d'entrenament. Aquesta acció no es pot desfer.",
|
||||
"desc_other": "Esteu segur que voleu suprimir {{count}} models? Això suprimirà permanentment totes les dades associades, incloses les imatges i les dades d'entrenament. Aquesta acció no es pot desfer."
|
||||
},
|
||||
"menu": {
|
||||
"objects": "Objectes",
|
||||
@ -160,5 +174,11 @@
|
||||
"descriptionState": "Edita les classes per a aquest model de classificació d'estats. Els canvis requeriran tornar a entrenar el model.",
|
||||
"descriptionObject": "Edita el tipus d'objecte i el tipus de classificació per a aquest model de classificació d'objectes.",
|
||||
"stateClassesInfo": "Nota: Canviar les classes d'estat requereix tornar a entrenar el model amb les classes actualitzades."
|
||||
},
|
||||
"tooltip": {
|
||||
"trainingInProgress": "El model s'està entrenant actualment",
|
||||
"noNewImages": "Sense noves imatges per entrenar. Classifica més imatges primer.",
|
||||
"modelNotReady": "El model no está preparat per entrenar",
|
||||
"noChanges": "No hi ha canvis al conjunt de dades des de l'última formació."
|
||||
}
|
||||
}
|
||||
|
||||
@ -39,9 +39,9 @@
|
||||
"threateningActivity": "Activitat amenaçadora",
|
||||
"detail": {
|
||||
"noDataFound": "No hi ha dades detallades a revisar",
|
||||
"trackedObject_one": "objecte",
|
||||
"trackedObject_one": "{{count}} objecte",
|
||||
"aria": "Canvia la vista de detall",
|
||||
"trackedObject_other": "objectes",
|
||||
"trackedObject_other": "{{count}} objectes",
|
||||
"noObjectDetailData": "No hi ha dades de detall d'objecte disponibles.",
|
||||
"label": "Detall",
|
||||
"settings": "Configuració de la vista detallada",
|
||||
|
||||
@ -85,7 +85,8 @@
|
||||
"snapshot": "instantània",
|
||||
"video": "vídeo",
|
||||
"object_lifecycle": "cicle de vida de l'objecte",
|
||||
"thumbnail": "miniatura"
|
||||
"thumbnail": "miniatura",
|
||||
"tracking_details": "detalls del seguiment"
|
||||
},
|
||||
"details": {
|
||||
"timestamp": "Marca temporal",
|
||||
@ -99,7 +100,7 @@
|
||||
"updatedSublabel": "Subetiqueta actualitzada amb èxit.",
|
||||
"updatedLPR": "Matrícula actualitzada amb èxit.",
|
||||
"regenerate": "El {{provider}} ha sol·licitat una nova descripció. En funció de la velocitat del vostre proveïdor, la nova descripció pot trigar un temps a regenerar-se.",
|
||||
"audioTranscription": "Transcripció d'àudio sol·licitada amb èxit."
|
||||
"audioTranscription": "S'ha sol·licitat correctament la transcripció d'àudio. Depenent de la velocitat del vostre servidor Frigate, la transcripció pot trigar una estona a completar-se."
|
||||
},
|
||||
"error": {
|
||||
"regenerate": "No s'ha pogut contactar amb {{provider}} per obtenir una nova descripció: {{errorMessage}}",
|
||||
@ -170,7 +171,9 @@
|
||||
"success": "L'objectes amb seguiment s'ha suprimit correctament.",
|
||||
"error": "No s'ha pogut suprimir l'objecte rastrejat: {{errorMessage}}"
|
||||
}
|
||||
}
|
||||
},
|
||||
"nextTrackedObject": "Següent objecte rastrejat",
|
||||
"previousTrackedObject": "Objecte rastrejat anterior"
|
||||
},
|
||||
"itemMenu": {
|
||||
"downloadVideo": {
|
||||
@ -273,7 +276,7 @@
|
||||
"label": "Òfset d'Anotació",
|
||||
"desc": "Aquestes dades provenen del flux de detecció de la càmera, però se superposen a les imatges del flux de gravació. És poc probable que els dos fluxos estiguin perfectament sincronitzats. Com a resultat, el quadre delimitador i les imatges no s'alinearan perfectament. Tanmateix, es pot utilitzar el camp <code>annotation_offset</code> per ajustar-ho.",
|
||||
"millisecondsToOffset": "Millisegons per l'òfset de detecció d'anotacions per. <em>Per defecte: 0</em>",
|
||||
"tips": "CONSELL: Imagineu-vos que hi ha un clip d'esdeveniment amb una persona caminant d'esquerra a dreta. Si el quadre delimitador de la cronologia de l'esdeveniment està constantment a l'esquerra de la persona, aleshores s'hauria de disminuir el valor. De la mateixa manera, si una persona camina d'esquerra a dreta i el quadre delimitador està constantment per davant de la persona, aleshores s'hauria d'augmentar el valor.",
|
||||
"tips": "Reduïu el valor si la reproducció del vídeo es troba per davant dels quadres i els punts de ruta, i augmenteu-lo si es troba per darrere. Aquest valor pot ser negatiu.",
|
||||
"toast": {
|
||||
"success": "L'Òfset d'anotació per a {{camera}} s'ha desat al fitxer de configuració. Reinicieu Frigate per aplicar els canvis."
|
||||
}
|
||||
|
||||
@ -67,7 +67,7 @@
|
||||
"toast": {
|
||||
"success": {
|
||||
"trainedFace": "Rostre entrenat amb èxit.",
|
||||
"updatedFaceScore": "Puntació de rostre actualitzada amb èxit.",
|
||||
"updatedFaceScore": "S'ha actualitzat correctament la puntuació de la cara a {{name}} ({{score}}).",
|
||||
"uploadedImage": "Imatge pujada amb èxit.",
|
||||
"addFaceLibrary": "{{name}} s'ha afegit amb èxit a la biblioteca de rostres!",
|
||||
"deletedName_one": "{{count}} rostre s'ha suprimit amb èxit.",
|
||||
|
||||
@ -180,6 +180,10 @@
|
||||
"noCameras": {
|
||||
"title": "No s'ha configurat cap càmera",
|
||||
"description": "Comenceu connectant una càmera a Frigate.",
|
||||
"buttonText": "Afegeix una càmera"
|
||||
"buttonText": "Afegeix una càmera",
|
||||
"restricted": {
|
||||
"title": "No hi ha càmeres disponibles",
|
||||
"description": "No teniu permís per veure cap càmera en aquest grup."
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -7,7 +7,7 @@
|
||||
"authentication": "Configuració d'autenticació - Frigate",
|
||||
"camera": "Paràmetres de càmera - Frigate",
|
||||
"masksAndZones": "Editor de màscares i zones - Frigate",
|
||||
"general": "Paràmetres Generals - Frigate",
|
||||
"general": "Configuració de la interfície d'usuari - Fragata",
|
||||
"frigatePlus": "Paràmetres de Frigate+ - Frigate",
|
||||
"notifications": "Paràmetres de notificació - Frigate",
|
||||
"cameraManagement": "Gestionar càmeres - Frigate",
|
||||
@ -39,7 +39,7 @@
|
||||
"noCamera": "Cap càmera"
|
||||
},
|
||||
"general": {
|
||||
"title": "Paràmetres generals",
|
||||
"title": "Paràmetres de la interfície d'usuari",
|
||||
"liveDashboard": {
|
||||
"title": "Panell en directe",
|
||||
"automaticLiveView": {
|
||||
@ -53,6 +53,10 @@
|
||||
"displayCameraNames": {
|
||||
"label": "Mostra sempre els noms de la càmera",
|
||||
"desc": "Mostra sempre els noms de les càmeres en un xip al tauler de visualització en directe multicàmera."
|
||||
},
|
||||
"liveFallbackTimeout": {
|
||||
"label": "Temps d'espera per a la reserva del jugador en directe",
|
||||
"desc": "Quan el flux en viu d'alta qualitat d'una càmera no està disponible, torneu al mode d'amplada de banda baixa després d'aquests molts segons. Per defecte: 3."
|
||||
}
|
||||
},
|
||||
"storedLayouts": {
|
||||
@ -858,9 +862,9 @@
|
||||
"createRole": "Rol {{role}} creat exitosament",
|
||||
"updateCameras": "Càmeres actualitzades per al rol {{role}}",
|
||||
"deleteRole": "Rol {{role}} eliminat exitosament",
|
||||
"userRolesUpdated_one": "{{count}} usuari(s) asignats a aquest rol s'han actualitzat a 'visor', i tenen accés a totes les càmeres.",
|
||||
"userRolesUpdated_many": "",
|
||||
"userRolesUpdated_other": ""
|
||||
"userRolesUpdated_one": "{{count}} l'usuari assignat a aquest rol s'ha actualitzat a 'visor', que té accés a totes les càmeres.",
|
||||
"userRolesUpdated_many": "{{count}} usuaris assignats a aquest rol s'han actualitzat a 'visor', que té accés a totes les càmeres.",
|
||||
"userRolesUpdated_other": "{{count}} usuaris assignats a aquest rol s'han actualitzat a 'visor', que té accés a totes les càmeres."
|
||||
},
|
||||
"error": {
|
||||
"createRoleFailed": "Error al crear el rol: {{errorMessage}}",
|
||||
@ -871,16 +875,17 @@
|
||||
}
|
||||
},
|
||||
"cameraWizard": {
|
||||
"title": "Afegir C àmera",
|
||||
"title": "Afegir Càmera",
|
||||
"description": "Seguiu els passos de sota per afegir una nova càmera a la instal·lació.",
|
||||
"steps": {
|
||||
"nameAndConnection": "Nom i connexió",
|
||||
"streamConfiguration": "Configuració de stream",
|
||||
"validationAndTesting": "Validació i proves"
|
||||
"validationAndTesting": "Validació i proves",
|
||||
"probeOrSnapshot": "Prova o instantània"
|
||||
},
|
||||
"step1": {
|
||||
"cameraBrand": "Marca de la càmera",
|
||||
"description": "Introduïu els detalls de la càmera i proveu la connexió.",
|
||||
"description": "Introduïu els detalls de la càmera i trieu provar la càmera o seleccionar manualment la marca.",
|
||||
"cameraName": "Nom de la càmera",
|
||||
"cameraNamePlaceholder": "p. ex., vista general de la porta davantera o de la barra posterior",
|
||||
"host": "Adreça de l'amfitrió/IP",
|
||||
@ -919,7 +924,16 @@
|
||||
"testing": {
|
||||
"probingMetadata": "S'estan provant les metadades de la càmera...",
|
||||
"fetchingSnapshot": "S'està recuperant la instantània de la càmera..."
|
||||
}
|
||||
},
|
||||
"connectionSettings": "Configuració de la connexió",
|
||||
"detectionMethod": "Mètode de detecció de flux",
|
||||
"onvifPort": "ONVIF Port",
|
||||
"probeMode": "Càmera de prova",
|
||||
"manualMode": "Selecció manual",
|
||||
"detectionMethodDescription": "Proveu la càmera amb ONVIF (si és compatible) per trobar URL de flux de càmera, o seleccioneu manualment la marca de càmera per utilitzar URL predefinits. Per a introduir un URL RTSP personalitzat, trieu el mètode manual i seleccioneu \"Altres\".",
|
||||
"onvifPortDescription": "Per a les càmeres que suporten ONVIF, això sol ser 80 o 8080.",
|
||||
"useDigestAuth": "Utilitza l'autenticació digest",
|
||||
"useDigestAuthDescription": "Usa l'autenticació de resum HTTP per a ONVIF. Algunes càmeres poden requerir un nom d'usuari/contrasenya ONVIF dedicat en lloc de l'usuari administrador estàndard."
|
||||
},
|
||||
"save": {
|
||||
"failure": "SS'ha produït un error en desar {{cameraName}}.",
|
||||
@ -936,7 +950,7 @@
|
||||
"testFailed": "Ha fallat la prova de flux: {{error}}"
|
||||
},
|
||||
"step2": {
|
||||
"description": "Configura els rols de flux i afegeix fluxos addicionals per a la càmera.",
|
||||
"description": "Proveu la càmera per als fluxos disponibles o configureu la configuració manual basada en el mètode de detecció seleccionat.",
|
||||
"streamsTitle": "Fluxos de la càmera",
|
||||
"addStream": "Afegeix un flux",
|
||||
"addAnotherStream": "Afegeix un altre flux",
|
||||
@ -953,8 +967,8 @@
|
||||
"audio": "Àudio"
|
||||
},
|
||||
"testStream": "Prova la connexió",
|
||||
"testSuccess": "Prova de flux amb èxit!",
|
||||
"testFailed": "Ha fallat la prova del flux",
|
||||
"testSuccess": "Prova de connexió correcta!",
|
||||
"testFailed": "Ha fallat la prova de connexió. Si us plau, comproveu la vostra entrada i torneu-ho a provar.",
|
||||
"testFailedTitle": "Ha fallat la prova",
|
||||
"connected": "Connectat",
|
||||
"notConnected": "No connectat",
|
||||
@ -972,7 +986,39 @@
|
||||
"description": "Utilitzeu el restreaming go2rtc per reduir les connexions a la càmera."
|
||||
},
|
||||
"roles": "Rols",
|
||||
"streamUrlPlaceholder": "rtsp://usuari:contrasenya@host:port/ruta"
|
||||
"streamUrlPlaceholder": "rtsp://usuari:contrasenya@host:port/ruta",
|
||||
"streamDetails": "Detalls del flux",
|
||||
"probing": "Provant càmera...",
|
||||
"retry": "Intentar de nou",
|
||||
"testing": {
|
||||
"probingMetadata": "S'estan provant les metadades de la càmera...",
|
||||
"fetchingSnapshot": "S'està recuperant la instantània de la càmera..."
|
||||
},
|
||||
"probeFailed": "No s'ha pogut provar la càmera: {{error}}",
|
||||
"probingDevice": "Provant dispositiu...",
|
||||
"probeSuccessful": "Prova exitosa",
|
||||
"probeError": "Error de prova",
|
||||
"probeNoSuccess": "La prova no ha tingut èxit",
|
||||
"deviceInfo": "Informació del dispositiu",
|
||||
"manufacturer": "Fabricant",
|
||||
"model": "Model",
|
||||
"firmware": "Firmware",
|
||||
"profiles": "Perfils",
|
||||
"ptzSupport": "Suport PTZ",
|
||||
"autotrackingSupport": "Implementació de seguiment automàtic",
|
||||
"presets": "Predefinits",
|
||||
"rtspCandidates": "Candidats RTSP",
|
||||
"rtspCandidatesDescription": "S'han trobat els següents URL RTSP de la sonda de la càmera. Proveu la connexió per a veure les metadades del flux.",
|
||||
"noRtspCandidates": "No s'ha trobat cap URL RTSP a la càmera. Les vostres credencials poden ser incorrectes, o la càmera pot no admetre ONVIF o el mètode utilitzat per recuperar els URL RTSP. Torneu enrere i introduïu l'URL RTSP manualment.",
|
||||
"candidateStreamTitle": "Candidat {{number}}",
|
||||
"useCandidate": "Utilitza",
|
||||
"uriCopy": "Copia",
|
||||
"uriCopied": "URI copiat al porta-retalls",
|
||||
"testConnection": "Prova la connexió",
|
||||
"toggleUriView": "Feu clic per a commutar la vista completa de l'URI",
|
||||
"errors": {
|
||||
"hostRequired": "Es requereix l'adreça de l'amfitrió/IP"
|
||||
}
|
||||
},
|
||||
"step3": {
|
||||
"none": "Cap",
|
||||
@ -996,7 +1042,7 @@
|
||||
"resolutionHigh": "Una resolució de {{resolution}} pot causar un ús més gran dels recursos.",
|
||||
"resolutionLow": "Una resolució de {{resolution}} pot ser massa baixa per a la detecció fiable d'objectes petits."
|
||||
},
|
||||
"description": "Validació i anàlisi final abans de desar la nova càmera. Connecta cada flux abans de desar-lo.",
|
||||
"description": "Configura els rols de flux i afegeix fluxos addicionals per a la càmera.",
|
||||
"validationTitle": "Validació del flux",
|
||||
"connectAllStreams": "Connecta tots els fluxos",
|
||||
"reconnectionSuccess": "S'ha reconnectat correctament.",
|
||||
@ -1016,7 +1062,91 @@
|
||||
"streamValidated": "El flux {{number}} s'ha validat correctament",
|
||||
"streamValidationFailed": "Ha fallat la validació del flux {{number}}",
|
||||
"ffmpegModule": "Usa el mode de compatibilitat del flux",
|
||||
"ffmpegModuleDescription": "Si el flux no es carrega després de diversos intents, proveu d'activar-ho. Quan està activat, Frigate utilitzarà el mòdul ffmpeg amb go2rtc. Això pot proporcionar una millor compatibilitat amb alguns fluxos de càmera."
|
||||
"ffmpegModuleDescription": "Si el flux no es carrega després de diversos intents, proveu d'activar-ho. Quan està activat, Frigate utilitzarà el mòdul ffmpeg amb go2rtc. Això pot proporcionar una millor compatibilitat amb alguns fluxos de càmera.",
|
||||
"streamsTitle": "Fluxos de la càmera",
|
||||
"addStream": "Afegeix un flux",
|
||||
"addAnotherStream": "Afegeix un altre flux",
|
||||
"streamUrl": "URL del flux",
|
||||
"streamUrlPlaceholder": "rtsp://usuari:contrasenya@host:port/ruta",
|
||||
"selectStream": "Selecciona un flux",
|
||||
"searchCandidates": "Cerca candidats...",
|
||||
"noStreamFound": "No s'ha trobat cap flux",
|
||||
"url": "URL",
|
||||
"resolution": "Resolució",
|
||||
"selectResolution": "Selecciona la resolució",
|
||||
"quality": "Qualitat",
|
||||
"selectQuality": "Selecciona la qualitat",
|
||||
"roleLabels": {
|
||||
"detect": "Detecció d'objectes",
|
||||
"record": "Enregistrament",
|
||||
"audio": "Àudio"
|
||||
},
|
||||
"testStream": "Prova la connexió",
|
||||
"testSuccess": "Prova de flux amb èxit!",
|
||||
"testFailed": "Ha fallat la prova del flux",
|
||||
"testFailedTitle": "Ha fallat la prova",
|
||||
"connected": "Connectat",
|
||||
"notConnected": "No connectat",
|
||||
"featuresTitle": "Característiques",
|
||||
"go2rtc": "Redueix les connexions a la càmera",
|
||||
"detectRoleWarning": "Almenys un flux ha de tenir el rol de \"detecte\" per continuar.",
|
||||
"rolesPopover": {
|
||||
"title": "Roles de flux",
|
||||
"detect": "Canal principal per a la detecció d'objectes.",
|
||||
"record": "Desa els segments del canal de vídeo basats en la configuració.",
|
||||
"audio": "Canal per a la detecció basada en àudio."
|
||||
},
|
||||
"featuresPopover": {
|
||||
"title": "Característiques del flux",
|
||||
"description": "Utilitzeu el restreaming go2rtc per reduir les connexions a la càmera."
|
||||
}
|
||||
},
|
||||
"step4": {
|
||||
"description": "Validació i anàlisi final abans de desar la nova càmera. Connecta cada flux abans de desar-lo.",
|
||||
"validationTitle": "Validació del flux",
|
||||
"connectAllStreams": "Connecta tots els fluxos",
|
||||
"reconnectionSuccess": "S'ha reconnectat correctament.",
|
||||
"reconnectionPartial": "Alguns fluxos no s'han pogut tornar a connecta.",
|
||||
"streamUnavailable": "La vista prèvia del flux no està disponible",
|
||||
"reload": "Torna a carregar",
|
||||
"connecting": "S'està connectant...",
|
||||
"streamTitle": "Flux {{number}}",
|
||||
"valid": "Vàlid",
|
||||
"failed": "Ha fallat",
|
||||
"notTested": "No provat",
|
||||
"connectStream": "Connecta",
|
||||
"connectingStream": "Connectant",
|
||||
"disconnectStream": "Desconnecta",
|
||||
"estimatedBandwidth": "Amplada de banda estimada",
|
||||
"roles": "Roles",
|
||||
"ffmpegModule": "Usa el mode de compatibilitat del flux",
|
||||
"ffmpegModuleDescription": "Si el flux no es carrega després de diversos intents, proveu d'activar-ho. Quan està activat, Frigate utilitzarà el mòdul ffmpeg amb go2rtc. Això pot proporcionar una millor compatibilitat amb alguns fluxos de càmera.",
|
||||
"none": "Cap",
|
||||
"error": "Error",
|
||||
"streamValidated": "El flux {{number}} s'ha validat correctament",
|
||||
"streamValidationFailed": "Ha fallat la validació del flux {{number}}",
|
||||
"saveAndApply": "Desa una càmera nova",
|
||||
"saveError": "Configuració no vàlida. Si us plau, comproveu la configuració.",
|
||||
"issues": {
|
||||
"title": "Validació del flux",
|
||||
"videoCodecGood": "El còdec de vídeo és {{codec}}.",
|
||||
"audioCodecGood": "El còdec d'àudio és {{codec}}.",
|
||||
"resolutionHigh": "Una resolució de {{resolution}} pot causar un ús més gran dels recursos.",
|
||||
"resolutionLow": "Una resolució de {{resolution}} pot ser massa baixa per a la detecció fiable d'objectes petits.",
|
||||
"noAudioWarning": "No s'ha detectat cap àudio per a aquest flux, els enregistraments no tindran àudio.",
|
||||
"audioCodecRecordError": "El còdec d'àudio AAC és necessari per a suportar l'àudio en els enregistraments.",
|
||||
"audioCodecRequired": "Es requereix un flux d'àudio per admetre la detecció d'àudio.",
|
||||
"restreamingWarning": "Reduir les connexions a la càmera per al flux de registre pot augmentar lleugerament l'ús de la CPU.",
|
||||
"brands": {
|
||||
"reolink-rtsp": "No és racomana utilitzar Reolink RSTP. Activeu HTTP a la configuració del microprogramari de la càmera i reinicieu l'assistent."
|
||||
},
|
||||
"dahua": {
|
||||
"substreamWarning": "El substream 1 està bloquejat a una resolució baixa. Moltes càmeres Dahua / Amcrest / EmpireTech suporten subfluxos addicionals que han d'estar habilitats a la configuració de la càmera. Es recomana comprovar i utilitzar aquests corrents si estan disponibles."
|
||||
},
|
||||
"hikvision": {
|
||||
"substreamWarning": "El substream 1 està bloquejat a una resolució baixa. Moltes càmeres Hikvision suporten subfluxos addicionals que han d'estar habilitats a la configuració de la càmera. Es recomana comprovar i utilitzar aquests corrents si estan disponibles."
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"cameraManagement": {
|
||||
|
||||
@ -76,7 +76,12 @@
|
||||
}
|
||||
},
|
||||
"npuUsage": "Ús de NPU",
|
||||
"npuMemory": "Memòria de NPU"
|
||||
"npuMemory": "Memòria de NPU",
|
||||
"intelGpuWarning": {
|
||||
"title": "Avís d'estadístiques de la GPU d'Intel",
|
||||
"message": "Estadístiques de GPU no disponibles",
|
||||
"description": "Aquest és un error conegut en les eines d'informació de les estadístiques de GPU d'Intel (intel.gpu.top) on es trencarà i retornarà repetidament un ús de GPU del 0% fins i tot en els casos en què l'acceleració del maquinari i la detecció d'objectes s'executen correctament a la (i)GPU. Això no és un error de fragata. Podeu reiniciar l'amfitrió per a corregir temporalment el problema i confirmar que la GPU funciona correctament. Això no afecta el rendiment."
|
||||
}
|
||||
},
|
||||
"otherProcesses": {
|
||||
"title": "Altres processos",
|
||||
@ -179,8 +184,15 @@
|
||||
"plate_recognition_speed": "Velocitat de reconeixement de matrícules",
|
||||
"text_embedding_speed": "Velocitat d'incrustació de text",
|
||||
"yolov9_plate_detection": "Detecció de matrícules YOLOv9",
|
||||
"yolov9_plate_detection_speed": "Velocitat de detecció de matrícules YOLOv9"
|
||||
"yolov9_plate_detection_speed": "Velocitat de detecció de matrícules YOLOv9",
|
||||
"review_description": "Descripció de la revisió",
|
||||
"review_description_speed": "Velocitat de la descripció de la revisió",
|
||||
"review_description_events_per_second": "Descripció de la revisió",
|
||||
"object_description": "Descripció de l'objecte",
|
||||
"object_description_speed": "Velocitat de la descripció de l'objecte",
|
||||
"object_description_events_per_second": "Descripció de l'objecte"
|
||||
},
|
||||
"infPerSecond": "Inferències per segon"
|
||||
"infPerSecond": "Inferències per segon",
|
||||
"averageInf": "Temps mitjà d'inferència"
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,7 +1,31 @@
|
||||
{
|
||||
"documentTitle": "Klasifikační modely",
|
||||
"button": {
|
||||
"deleteClassificationAttempts": "Odstranit Klasifikační obrazy",
|
||||
"renameCategory": "Přejmenovat třídu"
|
||||
"deleteClassificationAttempts": "Odstrániť Klasifikačné obrazy",
|
||||
"renameCategory": "Premenovať triedu",
|
||||
"deleteCategory": "Zmazať triedu",
|
||||
"deleteImages": "Zmazať obrázok",
|
||||
"trainModel": "Trenovací model",
|
||||
"addClassification": "Pridať klasifikáciu",
|
||||
"deleteModels": "Zmazať modeli",
|
||||
"editModel": "Upraviť model"
|
||||
},
|
||||
"details": {
|
||||
"scoreInfo": "Skóre predstavuje priemernú istotu klasifikácie naprieč detekciami tohoto objektu."
|
||||
},
|
||||
"tooltip": {
|
||||
"trainingInProgress": "Model se práve trénuje",
|
||||
"noNewImages": "Žiadne nové obrázky na trénovanie. Najskôr klasifikujte viac obrazkov v datasete.",
|
||||
"noChanges": "Od posledného treningu nedošlo k žiadnym zmenám v datasete.",
|
||||
"modelNotReady": "Model nieje pripravený na trénovanie."
|
||||
},
|
||||
"toast": {
|
||||
"success": {
|
||||
"deletedImage": "Zmazať obrazky",
|
||||
"deletedModel_one": "Úspešne odstranený {{count}} model",
|
||||
"deletedModel_few": "Úspešne odstranené {{count}} modely",
|
||||
"deletedModel_other": "Úspěšne ostranených {{count}} modelov",
|
||||
"deletedCategory": "Zmazať triedu"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -36,5 +36,11 @@
|
||||
"selected_one": "{{count}} vybráno",
|
||||
"selected_other": "{{count}} vybráno",
|
||||
"suspiciousActivity": "Podezřelá aktivita",
|
||||
"threateningActivity": "Ohrožující činnost"
|
||||
"threateningActivity": "Ohrožující činnost",
|
||||
"zoomIn": "Přiblížit",
|
||||
"zoomOut": "Oddálit",
|
||||
"detail": {
|
||||
"label": "Detail",
|
||||
"noDataFound": "Žádná detailní data k prohlédnutí"
|
||||
}
|
||||
}
|
||||
|
||||
@ -13,5 +13,11 @@
|
||||
"error": {
|
||||
"renameExportFailed": "Nepodařilo se přejmenovat export: {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"tooltip": {
|
||||
"shareExport": "Sdílet export",
|
||||
"downloadVideo": "Stáhnout video",
|
||||
"deleteExport": "Smazat export",
|
||||
"editName": "Upravit jméno"
|
||||
}
|
||||
}
|
||||
|
||||
@ -306,7 +306,8 @@
|
||||
"notifications": "Notifikace",
|
||||
"frigateplus": "Frigate+",
|
||||
"enrichments": "Obohacení",
|
||||
"triggers": "Spouštěče"
|
||||
"triggers": "Spouštěče",
|
||||
"cameraManagement": "Správa"
|
||||
},
|
||||
"dialog": {
|
||||
"unsavedChanges": {
|
||||
|
||||
@ -80,5 +80,9 @@
|
||||
"hammer": "Hammer",
|
||||
"drill": "Bore",
|
||||
"explosion": "Eksplosion",
|
||||
"fireworks": "Nytårskrudt"
|
||||
"fireworks": "Nytårskrudt",
|
||||
"babbling": "Pludren",
|
||||
"yell": "Råb",
|
||||
"whoop": "Jubel",
|
||||
"snicker": "Smålatter"
|
||||
}
|
||||
|
||||
@ -7,7 +7,9 @@
|
||||
"usernameRequired": "Brugernavn kræves",
|
||||
"passwordRequired": "Kodeord kræves",
|
||||
"loginFailed": "Login fejlede",
|
||||
"unknownError": "Ukendt fejl. Tjek logs."
|
||||
}
|
||||
"unknownError": "Ukendt fejl. Tjek logs.",
|
||||
"rateLimit": "Grænsen for forespørgsler er overskredet. Prøv igen senere."
|
||||
},
|
||||
"firstTimeLogin": "Forsøger du at logge ind for første gang? Loginoplysningerne står i Frigate-loggene."
|
||||
}
|
||||
}
|
||||
|
||||
@ -11,7 +11,11 @@
|
||||
}
|
||||
},
|
||||
"name": {
|
||||
"label": "Navn"
|
||||
"label": "Navn",
|
||||
"placeholder": "Indtast et navn…",
|
||||
"errorMessage": {
|
||||
"mustLeastCharacters": "Kameragruppens navn skal være mindst 2 tegn."
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -3,7 +3,23 @@
|
||||
"title": "Er du sikker på at du vil genstarte Frigate?",
|
||||
"button": "Genstart",
|
||||
"restarting": {
|
||||
"title": "Frigate genstarter"
|
||||
"title": "Frigate genstarter",
|
||||
"button": "Gennemtving genindlæsning nu",
|
||||
"content": "Denne side genindlæses om {{countdown}} sekunder."
|
||||
}
|
||||
},
|
||||
"explore": {
|
||||
"plus": {
|
||||
"submitToPlus": {
|
||||
"label": "Indsend til Frigate+",
|
||||
"desc": "Objekter på steder, du ønsker at undgå, er ikke falske positiver. Hvis du indsender dem som falske positiver, vil det forvirre modellen."
|
||||
},
|
||||
"review": {
|
||||
"question": {
|
||||
"label": "Bekræft denne etiket til Frigate Plus",
|
||||
"ask_a": "Er dette objekt et <code>{{label}}</code>?"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -10,8 +10,10 @@
|
||||
},
|
||||
"labels": {
|
||||
"all": {
|
||||
"short": "Labels"
|
||||
"short": "Labels",
|
||||
"title": "Alle etiketter"
|
||||
},
|
||||
"count_one": "{{count}} Label"
|
||||
"count_one": "{{count}} Label",
|
||||
"label": "Etiketter"
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,7 +1,10 @@
|
||||
{
|
||||
"button": {
|
||||
"downloadVideo": {
|
||||
"label": "Download Video"
|
||||
"label": "Download Video",
|
||||
"toast": {
|
||||
"success": "Din video til gennemgang er begyndt at blive downloadet."
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,5 +1,15 @@
|
||||
{
|
||||
"noRecordingsFoundForThisTime": "Ingen optagelser fundet i det angivet tidsrum",
|
||||
"noPreviewFound": "Ingen forhåndsvisning fundet",
|
||||
"cameraDisabled": "Kamera er deaktiveret"
|
||||
"cameraDisabled": "Kamera er deaktiveret",
|
||||
"noPreviewFoundFor": "Ingen forhåndsvisning fundet for {{cameraName}}",
|
||||
"submitFrigatePlus": {
|
||||
"title": "Indsend denne frame til Frigate+?",
|
||||
"submit": "Indsend"
|
||||
},
|
||||
"livePlayerRequiredIOSVersion": "iOS 17.1 eller nyere kræves for denne type livestream.",
|
||||
"streamOffline": {
|
||||
"title": "Stream offline",
|
||||
"desc": "Der er ikke modtaget nogen frames på {{cameraName}}-<code>detect</code>-streamen, tjek fejlloggene."
|
||||
}
|
||||
}
|
||||
|
||||
@ -1 +1,17 @@
|
||||
{}
|
||||
{
|
||||
"documentTitle": "Klassifikationsmodeller",
|
||||
"details": {
|
||||
"scoreInfo": "Scoren repræsenterer den gennemsnitlige klassifikationssikkerhed på tværs af alle registreringer af dette objekt."
|
||||
},
|
||||
"description": {
|
||||
"invalidName": "Ugyldigt navn. Navne må kun indeholde bogstaver, tal, mellemrum, apostroffer, understregninger og bindestreger."
|
||||
},
|
||||
"button": {
|
||||
"deleteClassificationAttempts": "Slet klassifikationsbilleder",
|
||||
"renameCategory": "Omdøb klasse",
|
||||
"deleteCategory": "Slet klasse",
|
||||
"deleteImages": "Slet billeder",
|
||||
"trainModel": "Træn model",
|
||||
"addClassification": "Tilføj klassifikation"
|
||||
}
|
||||
}
|
||||
|
||||
@ -2,5 +2,9 @@
|
||||
"documentTitle": "Konfigurationsstyring - Frigate",
|
||||
"copyConfig": "Kopiér konfiguration",
|
||||
"saveAndRestart": "Gem & Genstart",
|
||||
"saveOnly": "Kun gem"
|
||||
"saveOnly": "Kun gem",
|
||||
"configEditor": "Konfigurationseditor",
|
||||
"safeConfigEditor": "Konfigurationseditor (Sikker tilstand)",
|
||||
"safeModeDescription": "Frigate er i sikker tilstand på grund af en fejl ved validering af konfigurationen.",
|
||||
"confirm": "Afslut uden at gemme?"
|
||||
}
|
||||
|
||||
@ -7,5 +7,10 @@
|
||||
},
|
||||
"allCameras": "Alle kameraer",
|
||||
"timeline": "Tidslinje",
|
||||
"camera": "Kamera"
|
||||
"camera": "Kamera",
|
||||
"empty": {
|
||||
"alert": "Der er ingen advarsler at gennemgå",
|
||||
"detection": "Der er ingen registreringer at gennemgå",
|
||||
"motion": "Ingen bevægelsesdata fundet"
|
||||
}
|
||||
}
|
||||
|
||||
@ -13,7 +13,17 @@
|
||||
"exploreIsUnavailable": {
|
||||
"embeddingsReindexing": {
|
||||
"startingUp": "Starter…",
|
||||
"estimatedTime": "Estimeret tid tilbage:"
|
||||
}
|
||||
"estimatedTime": "Estimeret tid tilbage:",
|
||||
"context": "Udforsk kan bruges, når genindekseringen af de sporede objektindlejringer er fuldført.",
|
||||
"finishingShortly": "Afsluttes om lidt",
|
||||
"step": {
|
||||
"thumbnailsEmbedded": "Miniaturer indlejret: "
|
||||
}
|
||||
},
|
||||
"title": "Udforsk er ikke tilgængelig"
|
||||
},
|
||||
"exploreMore": "Udforsk flere {{label}}-objekter",
|
||||
"details": {
|
||||
"timestamp": "Tidsstempel"
|
||||
}
|
||||
}
|
||||
|
||||
@ -4,6 +4,9 @@
|
||||
"deleteExport.desc": "Er du sikker på at du vil slette {{exportName}}?",
|
||||
"editExport": {
|
||||
"title": "Omdøb Eksport",
|
||||
"saveExport": "Gem Eksport"
|
||||
}
|
||||
"saveExport": "Gem Eksport",
|
||||
"desc": "Indtast et nyt navn for denne eksport."
|
||||
},
|
||||
"noExports": "Ingen eksporter fundet",
|
||||
"deleteExport": "Slet eksport"
|
||||
}
|
||||
|
||||
@ -1,10 +1,19 @@
|
||||
{
|
||||
"selectItem": "Vælg {{item}}",
|
||||
"description": {
|
||||
"addFace": "Gennemgang af tilføjelse til ansigts bibliotek",
|
||||
"placeholder": "Angiv et navn for bibliotek"
|
||||
"addFace": "Tilføj en ny samling til ansigtsbiblioteket ved at uploade dit første billede.",
|
||||
"placeholder": "Angiv et navn for bibliotek",
|
||||
"invalidName": "Ugyldigt navn. Navne må kun indeholde bogstaver, tal, mellemrum, apostroffer, understregninger og bindestreger."
|
||||
},
|
||||
"details": {
|
||||
"person": "Person"
|
||||
"person": "Person",
|
||||
"timestamp": "Tidsstempel",
|
||||
"unknown": "Ukendt",
|
||||
"scoreInfo": "Scoren er et vægtet gennemsnit af alle ansigtsscorer, vægtet efter ansigtets størrelse på hvert billede."
|
||||
},
|
||||
"documentTitle": "Ansigtsbibliotek - Frigate",
|
||||
"uploadFaceImage": {
|
||||
"title": "Upload ansigtsbillede",
|
||||
"desc": "Upload et billede for at scanne efter ansigter og inkludere det for {{pageToggle}}"
|
||||
}
|
||||
}
|
||||
|
||||
@ -8,5 +8,14 @@
|
||||
"cameraAudio": {
|
||||
"enable": "Aktivér kameralyd",
|
||||
"disable": "Deaktivér kamera lyd"
|
||||
},
|
||||
"lowBandwidthMode": "Lavbåndbredde-tilstand",
|
||||
"ptz": {
|
||||
"move": {
|
||||
"clickMove": {
|
||||
"label": "Klik i billedrammen for at centrere kameraet",
|
||||
"enable": "Aktivér klik for at flytte"
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -5,7 +5,8 @@
|
||||
"filters": "Filtere",
|
||||
"toast": {
|
||||
"error": {
|
||||
"endTimeMustAfterStartTime": "Sluttidspunkt skal være efter starttidspunkt"
|
||||
"endTimeMustAfterStartTime": "Sluttidspunkt skal være efter starttidspunkt",
|
||||
"noValidTimeSelected": "Intet gyldigt tidsinterval valgt"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -6,6 +6,7 @@
|
||||
"save": "Gem søgning",
|
||||
"delete": "Slet gemt søgning",
|
||||
"filterInformation": "Filter information",
|
||||
"filterActive": "Filtre aktiv"
|
||||
"filterActive": "Filtre aktiv",
|
||||
"clear": "Ryd søgning"
|
||||
}
|
||||
}
|
||||
|
||||
@ -3,6 +3,12 @@
|
||||
"default": "Indstillinger - Frigate",
|
||||
"authentication": "Bruger Indstillinger - Frigate",
|
||||
"camera": "Kamera indstillinger - Frigate",
|
||||
"object": "Debug - Frigate"
|
||||
"object": "Debug - Frigate",
|
||||
"cameraManagement": "Administrér kameraer - Frigate",
|
||||
"cameraReview": "Indstillinger for kameragennemgang - Frigate",
|
||||
"enrichments": "Indstillinger for berigelser - Frigate",
|
||||
"masksAndZones": "Maske- og zoneeditor - Frigate",
|
||||
"motionTuner": "Bevægelsesjustering - Frigate",
|
||||
"general": "Brugergrænsefladeindstillinger - Frigate"
|
||||
}
|
||||
}
|
||||
|
||||
@ -6,7 +6,98 @@
|
||||
"frigate": "Frigate Logs - Frigate",
|
||||
"go2rtc": "Go2RTC Logs - Frigate",
|
||||
"nginx": "Nginx Logs - Frigate"
|
||||
},
|
||||
"general": "Generelle statistikker - Frigate",
|
||||
"enrichments": "Beredningsstatistikker - Frigate"
|
||||
},
|
||||
"title": "System",
|
||||
"logs": {
|
||||
"copy": {
|
||||
"label": "Kopier til udklipsholder",
|
||||
"success": "Logs er kopieret til udklipsholder",
|
||||
"error": "Kunne ikke kopiere logs til udklipsholder"
|
||||
},
|
||||
"type": {
|
||||
"label": "Type",
|
||||
"timestamp": "Tidsstempel",
|
||||
"message": "Besked",
|
||||
"tag": "Tag"
|
||||
},
|
||||
"tips": "Logs bliver streamet fra serveren",
|
||||
"toast": {
|
||||
"error": {
|
||||
"fetchingLogsFailed": "Fejl ved indhentning af logs: {{errorMessage}}",
|
||||
"whileStreamingLogs": "Fejl ved streaming af logs: {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"download": {
|
||||
"label": "Download logs"
|
||||
}
|
||||
},
|
||||
"title": "System"
|
||||
"general": {
|
||||
"title": "Generelt",
|
||||
"hardwareInfo": {
|
||||
"gpuUsage": "GPU forbrug",
|
||||
"gpuMemory": "GPU hukommelse",
|
||||
"gpuEncoder": "GPU indkoder",
|
||||
"gpuDecoder": "GPU afkoder",
|
||||
"title": "Hardware information",
|
||||
"gpuInfo": {
|
||||
"closeInfo": {
|
||||
"label": "Luk GPU information"
|
||||
},
|
||||
"copyInfo": {
|
||||
"label": "Kopier GPU information"
|
||||
},
|
||||
"toast": {
|
||||
"success": "Kopierede GPU information til udklipsholder"
|
||||
}
|
||||
},
|
||||
"npuUsage": "NPU forbrug",
|
||||
"npuMemory": "NPU hukommelse"
|
||||
},
|
||||
"detector": {
|
||||
"title": "Detektorer",
|
||||
"inferenceSpeed": "Detektorinferenshastighed",
|
||||
"temperature": "Detektor temperatur",
|
||||
"cpuUsage": "Detektor CPU forbrug",
|
||||
"cpuUsageInformation": "CPU brugt til at forberede input- og outputdata til/fra detektionsmodeller. Denne værdi måler ikke inferensforbrug, selvom der bruges en GPU eller accelerator.",
|
||||
"memoryUsage": "Detektorhummelsesforbrug"
|
||||
},
|
||||
"otherProcesses": {
|
||||
"title": "Andre processer",
|
||||
"processCpuUsage": "Proces CPU forbrug",
|
||||
"processMemoryUsage": "Proceshukommelsesforbrug"
|
||||
}
|
||||
},
|
||||
"metrics": "System metrikker",
|
||||
"storage": {
|
||||
"title": "Lagring",
|
||||
"overview": "Overblik",
|
||||
"recordings": {
|
||||
"title": "Optagelser",
|
||||
"tips": "Denne værdi repræsenterer den samlede lagerplads, der bruges af optagelserne i Frigates database. Frigate sporer ikke lagerpladsforbruget for alle filer på din disk.",
|
||||
"earliestRecording": "Tidligste optagelse til rådighed:"
|
||||
},
|
||||
"shm": {
|
||||
"title": "SHM (delt hukommelse) tildeling",
|
||||
"warning": "Den nuværende SHM størrelse af {{total}}MB er for lille. Øg den til minimum {{min_shm}}MB."
|
||||
},
|
||||
"cameraStorage": {
|
||||
"title": "Kamera lagring",
|
||||
"camera": "Kamera",
|
||||
"unusedStorageInformation": "Ubrugt lagringsinformation",
|
||||
"storageUsed": "Lagring",
|
||||
"percentageOfTotalUsed": "Procentandel af total",
|
||||
"bandwidth": "Båndbredde",
|
||||
"unused": {
|
||||
"title": "Ubrugt",
|
||||
"tips": "Denne værdi repræsenterer muligvis ikke nøjagtigt den ledige plads, der er tilgængelig for Frigate, hvis du har andre filer gemt på dit drev ud over Frigates optagelser. Frigate sporer ikke lagerforbrug ud over sine optagelser."
|
||||
}
|
||||
}
|
||||
},
|
||||
"cameras": {
|
||||
"title": "Kameraer",
|
||||
"overview": "Overblik"
|
||||
}
|
||||
}
|
||||
|
||||
@ -425,5 +425,21 @@
|
||||
"sanding": "Schleifen",
|
||||
"machine_gun": "Maschinengewehr",
|
||||
"boom": "Dröhnen",
|
||||
"field_recording": "Außenaufnahme"
|
||||
"field_recording": "Außenaufnahme",
|
||||
"liquid": "Flüssigkeit",
|
||||
"splash": "Spritzer",
|
||||
"slosh": "Schwenken",
|
||||
"squish": "Quetschen",
|
||||
"drip": "Tropfen",
|
||||
"pour": "Gießen",
|
||||
"trickle": "Tröpfeln",
|
||||
"fill": "Füllen",
|
||||
"spray": "Sprühen",
|
||||
"pump": "Pumpen",
|
||||
"stir": "Umrühren",
|
||||
"boiling": "Köchelnd",
|
||||
"arrow": "Pfeil",
|
||||
"electronic_tuner": "Elektronischer Tuner",
|
||||
"effects_unit": "Effekteinheit",
|
||||
"chorus_effect": "Chorus-Effekt"
|
||||
}
|
||||
|
||||
@ -121,7 +121,12 @@
|
||||
"unsuspended": "fortsetzen"
|
||||
},
|
||||
"label": {
|
||||
"back": "Zurück"
|
||||
"back": "Zurück",
|
||||
"hide": "Verstecke {{item}}",
|
||||
"show": "Zeige {{item}}",
|
||||
"ID": "ID",
|
||||
"none": "Nichts",
|
||||
"all": "Alle"
|
||||
},
|
||||
"menu": {
|
||||
"configurationEditor": "Konfigurationseditor",
|
||||
@ -284,5 +289,14 @@
|
||||
},
|
||||
"information": {
|
||||
"pixels": "{{area}}px"
|
||||
},
|
||||
"field": {
|
||||
"optional": "Optional",
|
||||
"internalID": "Die interne ID, die Frigate in der Konfiguration und Datenbank verwendet"
|
||||
},
|
||||
"list": {
|
||||
"two": "{{0}} und {{1}}",
|
||||
"many": "{{items}}, und {{last}}",
|
||||
"separatorWithSpace": ", "
|
||||
}
|
||||
}
|
||||
|
||||
@ -10,6 +10,7 @@
|
||||
"unknownError": "Unbekannter Fehler. Prüfe Logs."
|
||||
},
|
||||
"user": "Benutzername",
|
||||
"password": "Kennwort"
|
||||
"password": "Kennwort",
|
||||
"firstTimeLogin": "Versuchen Sie sich zum ersten Mal anzumelden? Die Anmeldedaten sind in den Frigate-Logs aufgeführt."
|
||||
}
|
||||
}
|
||||
|
||||
@ -66,7 +66,7 @@
|
||||
"failed": "Fehler beim Starten des Exports: {{error}}",
|
||||
"noVaildTimeSelected": "Kein gültiger Zeitraum ausgewählt"
|
||||
},
|
||||
"success": "Export erfolgreich gestartet. Die Datei befindet sich im Ordner /exports."
|
||||
"success": "Export erfolgreich gestartet. Die Datei befindet sich auf der Exportseite."
|
||||
},
|
||||
"fromTimeline": {
|
||||
"saveExport": "Export speichern",
|
||||
@ -126,6 +126,7 @@
|
||||
"search": {
|
||||
"placeholder": "Nach Label oder Unterlabel suchen..."
|
||||
},
|
||||
"noImages": "Kein Vorschaubild für diese Kamera gefunden"
|
||||
"noImages": "Kein Vorschaubild für diese Kamera gefunden",
|
||||
"unknownLabel": "Gespeichertes Triggerbild"
|
||||
}
|
||||
}
|
||||
|
||||
@ -1 +1,40 @@
|
||||
{}
|
||||
{
|
||||
"documentTitle": "Klassifizierungsmodelle",
|
||||
"details": {
|
||||
"scoreInfo": "Die Punktzahl gibt die durchschnittliche Klassifizierungssicherheit aller Erkennungen dieses Objekts wieder."
|
||||
},
|
||||
"button": {
|
||||
"deleteClassificationAttempts": "Lösche Klassifizierungs-Bilder",
|
||||
"renameCategory": "Klasse umbenennen",
|
||||
"deleteCategory": "Klasse löschen",
|
||||
"deleteImages": "Bilder löschen",
|
||||
"trainModel": "Modell trainieren",
|
||||
"addClassification": "Klassifizierung hinzufügen",
|
||||
"deleteModels": "Modell löschen",
|
||||
"editModel": "Modell bearbeiten"
|
||||
},
|
||||
"tooltip": {
|
||||
"trainingInProgress": "Modell wird gerade trainiert",
|
||||
"noNewImages": "Keine weiteren Bilder zum trainieren. Bitte klassifiziere weitere Bilder im Datensatz.",
|
||||
"noChanges": "Keine Veränderungen des Datensatzes seit dem letzten Training.",
|
||||
"modelNotReady": "Modell ist nicht bereit trainiert zu werden."
|
||||
},
|
||||
"toast": {
|
||||
"success": {
|
||||
"deletedCategory": "Klasse gelöscht",
|
||||
"deletedImage": "Gelöschte Bilder",
|
||||
"deletedModel_one": "{{count}} Model erfolgreich gelöscht",
|
||||
"deletedModel_other": "{{count}} Modelle erfolgreich gelöscht",
|
||||
"categorizedImage": "Bild erfolgreich klassifiziert",
|
||||
"trainedModel": "Modell erfolgreich trainiert.",
|
||||
"trainingModel": "Modelltraining erfolgreich gestartet.",
|
||||
"updatedModel": "Modellkonfiguration erfolgreich aktualisiert",
|
||||
"renamedCategory": "Klasse erfolgreich in {{name}} umbenannt"
|
||||
},
|
||||
"error": {
|
||||
"deleteImageFailed": "Löschen fehlgeschlagen: {{errorMessage}}",
|
||||
"deleteCategoryFailed": "Klasse konnte nicht gelöscht werden: {{errorMessage}}",
|
||||
"deleteModelFailed": "Model konnte nicht gelöscht werden: {{errorMessage}}"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -36,5 +36,22 @@
|
||||
"selected_other": "{{count}} ausgewählt",
|
||||
"detected": "erkannt",
|
||||
"suspiciousActivity": "Verdächtige Aktivität",
|
||||
"threateningActivity": "Bedrohliche Aktivität"
|
||||
"threateningActivity": "Bedrohliche Aktivität",
|
||||
"zoomIn": "Hereinzoomen",
|
||||
"zoomOut": "Herauszoomen",
|
||||
"detail": {
|
||||
"label": "Detail",
|
||||
"aria": "Detailansicht umschalten",
|
||||
"trackedObject_one": "{{count}} Objekt",
|
||||
"trackedObject_other": "{{count}} Objekte",
|
||||
"noObjectDetailData": "Keine detaillierten Daten des Objekt verfügbar.",
|
||||
"noDataFound": "Keine Detaildaten zur Überprüfung",
|
||||
"settings": "Detailansicht Einstellungen",
|
||||
"alwaysExpandActive": {
|
||||
"desc": "Immer die Objektdetails des aktiven Überprüfungselements erweitern, sofern verfügbar."
|
||||
}
|
||||
},
|
||||
"objectTrack": {
|
||||
"trackedPoint": "Verfolgter Punkt"
|
||||
}
|
||||
}
|
||||
|
||||
@ -158,7 +158,8 @@
|
||||
"details": "Details",
|
||||
"video": "Video",
|
||||
"object_lifecycle": "Objekt-Lebenszyklus",
|
||||
"snapshot": "Snapshot"
|
||||
"snapshot": "Snapshot",
|
||||
"thumbnail": "Vorschaubild"
|
||||
},
|
||||
"itemMenu": {
|
||||
"downloadSnapshot": {
|
||||
@ -195,12 +196,22 @@
|
||||
"addTrigger": {
|
||||
"aria": "Einen Trigger für dieses verfolgte Objekt hinzufügen",
|
||||
"label": "Trigger hinzufügen"
|
||||
},
|
||||
"viewTrackingDetails": {
|
||||
"label": "Details zum Verfolgen anzeigen",
|
||||
"aria": "Details zum Verfolgen anzeigen"
|
||||
},
|
||||
"showObjectDetails": {
|
||||
"label": "Objektpfad anzeigen"
|
||||
},
|
||||
"hideObjectDetails": {
|
||||
"label": "Objektpfad verbergen"
|
||||
}
|
||||
},
|
||||
"dialog": {
|
||||
"confirmDelete": {
|
||||
"title": "Löschen bestätigen",
|
||||
"desc": "Beim Löschen dieses verfolgten Objekts werden der Schnappschuss, alle gespeicherten Einbettungen und alle zugehörigen Objektlebenszykluseinträge entfernt. Aufgezeichnetes Filmmaterial dieses verfolgten Objekts in der Verlaufsansicht wird <em>NICHT</em> gelöscht. <br /><br />Sind Sie sicher, dass Sie fortfahren möchten?"
|
||||
"desc": "Beim Löschen dieses verfolgten Objekts werden der Schnappschuss, alle gespeicherten Einbettungen und alle zugehörigen Verfolgungsdetails entfernt. Aufgezeichnetes Filmmaterial dieses verfolgten Objekts in der Verlaufsansicht wird <em>NICHT</em> gelöscht. <br /><br />Sind Sie sicher, dass Sie fortfahren möchten?"
|
||||
}
|
||||
},
|
||||
"searchResult": {
|
||||
@ -210,7 +221,9 @@
|
||||
"error": "Das verfolgte Objekt konnte nicht gelöscht werden: {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"tooltip": "Entspricht {{type}} bei {{confidence}}%"
|
||||
"tooltip": "Entspricht {{type}} bei {{confidence}}%",
|
||||
"previousTrackedObject": "Vorheriges verfolgtes Objekt",
|
||||
"nextTrackedObject": "Nächstes verfolgtes Objekt"
|
||||
},
|
||||
"noTrackedObjects": "Keine verfolgten Objekte gefunden",
|
||||
"fetchingTrackedObjectsFailed": "Fehler beim Abrufen von verfolgten Objekten: {{errorMessage}}",
|
||||
@ -222,5 +235,49 @@
|
||||
},
|
||||
"concerns": {
|
||||
"label": "Bedenken"
|
||||
},
|
||||
"trackingDetails": {
|
||||
"noImageFound": "Kein Bild mit diesem Zeitstempel gefunden.",
|
||||
"createObjectMask": "Objekt-Maske erstellen",
|
||||
"scrollViewTips": "Klicke, um die relevanten Momente aus dem Lebenszyklus dieses Objektes zu sehen.",
|
||||
"lifecycleItemDesc": {
|
||||
"visible": "{{label}} erkannt",
|
||||
"entered_zone": "{{label}} betrat {{zones}}",
|
||||
"active": "{{label}} wurde aktiv",
|
||||
"stationary": "{{label}} wurde stationär",
|
||||
"attribute": {
|
||||
"faceOrLicense_plate": "{{attribute}} erkannt für {{label}}",
|
||||
"other": "{{label}} erkannt als {{attribute}}"
|
||||
},
|
||||
"gone": "{{label}} verließ",
|
||||
"heard": "{{label}} wurde gehört",
|
||||
"external": "{{label}} erkannt",
|
||||
"header": {
|
||||
"zones": "Zonen",
|
||||
"ratio": "Verhältnis",
|
||||
"area": "Bereich"
|
||||
}
|
||||
},
|
||||
"annotationSettings": {
|
||||
"title": "Anmerkungseinstellungen",
|
||||
"showAllZones": {
|
||||
"title": "Zeige alle Zonen",
|
||||
"desc": "Immer Zonen auf Rahmen anzeigen, in die Objekte eingetreten sind."
|
||||
},
|
||||
"offset": {
|
||||
"label": "Anmerkungen Versatz",
|
||||
"desc": "Diese Daten stammen aus dem Erkennungsfeed der Kamera, werden jedoch über Bilder aus dem Aufzeichnungsfeed gelegt. Es ist unwahrscheinlich, dass beide Streams perfekt synchron sind. Daher stimmen der Begrenzungsrahmen und das Filmmaterial nicht vollständig überein. Mit dieser Einstellung lassen sich die Anmerkungen zeitlich nach vorne oder hinten verschieben, um sie besser an das aufgezeichnete Filmmaterial anzupassen.",
|
||||
"millisecondsToOffset": "Millisekunden, um Erkennungs-Anmerkungen zu verschieben. <em>Standard: 0</em>",
|
||||
"tips": "Verringere den Wert, wenn die Videowiedergabe den Boxen und Wegpunkten voraus ist, und erhöhe den Wert, wenn die Videowiedergabe hinter ihnen zurückbleibt. Dieser Wert kann negativ sein.",
|
||||
"toast": {
|
||||
"success": "Der Anmerkungs-Offset für {{camera}} wurde in der Konfigurationsdatei gespeichert. Starte Frigate neu, um Ihre Änderungen zu übernehmen."
|
||||
}
|
||||
}
|
||||
},
|
||||
"carousel": {
|
||||
"previous": "Vorherige Anzeige",
|
||||
"next": "Nächste Anzeige"
|
||||
},
|
||||
"title": "Verfolgungsdetails"
|
||||
}
|
||||
}
|
||||
|
||||
@ -13,5 +13,11 @@
|
||||
"error": {
|
||||
"renameExportFailed": "Umbenennen des Exports fehlgeschlagen: {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"tooltip": {
|
||||
"shareExport": "Export teilen",
|
||||
"downloadVideo": "Video herunterladen",
|
||||
"editName": "Name ändern",
|
||||
"deleteExport": "Export löschen"
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,7 +1,7 @@
|
||||
{
|
||||
"description": {
|
||||
"placeholder": "Gib einen Name für diese Kollektion ein",
|
||||
"addFace": "Anleitung für das Hinzufügen einer neuen Kollektion zur Gesichtsbibliothek.",
|
||||
"addFace": "Füge der Gesichtsbibliothek eine neue Sammlung hinzu, indem ein erstes Bild hochgeladen wird.",
|
||||
"invalidName": "Ungültiger Name. Namen dürfen nur Buchstaben, Zahlen, Leerzeichen, Apostrophe, Unterstriche und Bindestriche enthalten."
|
||||
},
|
||||
"details": {
|
||||
@ -22,7 +22,7 @@
|
||||
"title": "Kollektion erstellen",
|
||||
"new": "Lege ein neues Gesicht an",
|
||||
"desc": "Erstelle eine neue Kollektion",
|
||||
"nextSteps": "Um eine solide Grundlage zu bilden: <li> Benutze den Trainieren Tab, um Bilder für jede erkannte Person auszuwählen und zu trainieren.</li> <li>Konzentriere dich für gute Ergebnisse auf Frontalfotos; vermeide Bilder zu Trainingszwecken, bei denen Gesichter aus einem Winkel erfasst wurden.</li></ul>"
|
||||
"nextSteps": "Um eine solide Grundlage zu bilden: <li> Benutze den \"Aktuelle Erkennungen\" Tab, um Bilder für jede erkannte Person auszuwählen und zu trainieren.</li> <li>Konzentriere dich für gute Ergebnisse auf Frontalfotos; vermeide Bilder zu Trainingszwecken, bei denen Gesichter aus einem Winkel erfasst wurden.</li></ul>"
|
||||
},
|
||||
"documentTitle": "Gesichtsbibliothek - Frigate",
|
||||
"selectItem": "Wähle {{item}}",
|
||||
@ -44,8 +44,8 @@
|
||||
"deleteFace": "Lösche Gesicht"
|
||||
},
|
||||
"train": {
|
||||
"title": "Trainiere",
|
||||
"aria": "Wähle Training",
|
||||
"title": "Aktuelle Erkennungen",
|
||||
"aria": "Wähle aktuelle Erkennungen",
|
||||
"empty": "Es gibt keine aktuellen Versuche zur Gesichtserkennung"
|
||||
},
|
||||
"deleteFaceLibrary": {
|
||||
|
||||
@ -5,7 +5,7 @@
|
||||
"camera": "Kameraeinstellungen - Frigate",
|
||||
"masksAndZones": "Masken- und Zonen-Editor – Frigate",
|
||||
"object": "Debug - Frigate",
|
||||
"general": "Allgemeine Einstellungen – Frigate",
|
||||
"general": "UI Einstellungen – Frigate",
|
||||
"frigatePlus": "Frigate+ Einstellungen – Frigate",
|
||||
"classification": "Klassifizierungseinstellungen – Frigate",
|
||||
"motionTuner": "Bewegungserkennungs-Optimierer – Frigate",
|
||||
|
||||
@ -10,6 +10,7 @@
|
||||
"loginFailed": "Αποτυχία σύνδεσης",
|
||||
"unknownError": "Άγνωστο σφάλμα. Ελέγξτε το αρχείο καταγραφής.",
|
||||
"webUnknownError": "Άγνωστο σφάλμα. Εξετάστε το αρχείο καταγραφής κονσόλας."
|
||||
}
|
||||
},
|
||||
"firstTimeLogin": "Προσπαθείτε να συνδεθείτε για πρώτη φορά; Τα διαπιστευτήρια είναι τυπωμένα στα logs του Frigate."
|
||||
}
|
||||
}
|
||||
|
||||
@ -53,6 +53,7 @@
|
||||
"selectOrExport": "Select or Export",
|
||||
"toast": {
|
||||
"success": "Successfully started export. View the file in the exports page.",
|
||||
"view": "View",
|
||||
"error": {
|
||||
"failed": "Failed to start export: {{error}}",
|
||||
"endTimeMustAfterStartTime": "End time must be after start time",
|
||||
|
||||
@ -61,7 +61,8 @@
|
||||
"header": {
|
||||
"zones": "Zones",
|
||||
"ratio": "Ratio",
|
||||
"area": "Area"
|
||||
"area": "Area",
|
||||
"score": "Score"
|
||||
}
|
||||
},
|
||||
"annotationSettings": {
|
||||
|
||||
@ -18,15 +18,19 @@
|
||||
"deletedModel_many": "Borrados con éxito {{count}} modelos",
|
||||
"deletedModel_other": "Borrados con éxito {{count}} modelos",
|
||||
"categorizedImage": "Imagen Clasificada Correctamente",
|
||||
"trainedModel": "Modelo entrenado correctamente."
|
||||
"trainedModel": "Modelo entrenado correctamente.",
|
||||
"trainingModel": "Entrenamiento del modelo iniciado correctamente.",
|
||||
"updatedModel": "Configuración del modelo actualizada correctamente",
|
||||
"renamedCategory": "Clase renombrada correctamente a {{name}}"
|
||||
},
|
||||
"error": {
|
||||
"deleteImageFailed": "Fallo al borrar: {{errorMessage}}",
|
||||
"deleteCategoryFailed": "Fallo al borrar clase: {{errorMessage}}",
|
||||
"deleteModelFailed": "Fallo al borrar modelo: {{errorMessage}}",
|
||||
"categorizeFailed": "Fallo al categorizar imagen: {{errorMessage}}",
|
||||
"trainingFailed": "Fallo al iniciar el entrenamiento del modelo: {{errorMessage}}",
|
||||
"updateModelFailed": "Fallo al actualizar modelo: {{errorMessage}}"
|
||||
"trainingFailed": "El entrenamiento del modelo ha fallado. Revisa los registros de Frigate para más detalles.",
|
||||
"updateModelFailed": "Fallo al actualizar modelo: {{errorMessage}}",
|
||||
"trainingFailedToStart": "No se pudo iniciar el entrenamiento del modelo: {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"deleteCategory": {
|
||||
@ -35,6 +39,21 @@
|
||||
},
|
||||
"deleteModel": {
|
||||
"title": "Borrar Modelo de Clasificación",
|
||||
"single": "¿Está seguro de que quiere eliminar {{name}}? Esto borrar permanentemente todos los datos asociados incluidas las imágenes y los datos de entrenamiento. Esta acción no se puede deshacer."
|
||||
"single": "¿Está seguro de que quiere eliminar {{name}}? Esto borrar permanentemente todos los datos asociados incluidas las imágenes y los datos de entrenamiento. Esta acción no se puede deshacer.",
|
||||
"desc_one": "¿Estas seguro de que quiere borrar {{count}} modelo? Esto borrara permanentemente todos los datos asociados, incluyendo imágenes y datos de entrenamiento. Esta acción no puede ser desehecha.",
|
||||
"desc_many": "¿Estas seguro de que quiere borrar {{count}} modelos? Esto borrara permanentemente todos los datos asociados, incluyendo imágenes y datos de entrenamiento. Esta acción no puede ser desehecha.",
|
||||
"desc_other": "¿Estas seguro de que quiere borrar {{count}} modelos? Esto borrara permanentemente todos los datos asociados, incluyendo imágenes y datos de entrenamiento. Esta acción no puede ser desehecha."
|
||||
},
|
||||
"edit": {
|
||||
"title": "Editar modelo de clasificación"
|
||||
},
|
||||
"tooltip": {
|
||||
"noChanges": "No se han realizado cambios en el conjunto de datos desde el último entrenamiento.",
|
||||
"modelNotReady": "El modelo no está listo para el entrenamiento",
|
||||
"trainingInProgress": "El modelo está entrenándose actualmente.",
|
||||
"noNewImages": "No hay imágenes nuevas para entrenar. Clasifica antes más imágenes del conjunto de datos."
|
||||
},
|
||||
"details": {
|
||||
"scoreInfo": "La puntuación representa la confianza media de clasificación en todas las detecciones de este objeto."
|
||||
}
|
||||
}
|
||||
|
||||
@ -42,12 +42,19 @@
|
||||
"zoomOut": "Alejar",
|
||||
"detail": {
|
||||
"label": "Detalle",
|
||||
"trackedObject_one": "objeto",
|
||||
"trackedObject_other": "objetos",
|
||||
"trackedObject_one": "{{count}} objeto",
|
||||
"trackedObject_other": "{{count}} objetos",
|
||||
"noObjectDetailData": "No hay datos detallados del objeto.",
|
||||
"settings": "Configuración de la Vista Detalle"
|
||||
"settings": "Configuración de la Vista Detalle",
|
||||
"noDataFound": "No hay datos detallados para revisar",
|
||||
"aria": "Alternar vista de detalles",
|
||||
"alwaysExpandActive": {
|
||||
"title": "Expandir siempre los activos",
|
||||
"desc": "Expandir siempre los detalles del objeto activo cuando esten disponibles."
|
||||
}
|
||||
},
|
||||
"objectTrack": {
|
||||
"clickToSeek": "Clic para ir a este momento"
|
||||
"clickToSeek": "Clic para ir a este momento",
|
||||
"trackedPoint": "Puntro trazado"
|
||||
}
|
||||
}
|
||||
|
||||
@ -111,7 +111,8 @@
|
||||
"video": "vídeo",
|
||||
"object_lifecycle": "ciclo de vida del objeto",
|
||||
"details": "detalles",
|
||||
"thumbnail": "miniatura"
|
||||
"thumbnail": "miniatura",
|
||||
"tracking_details": "detalles de seguimiento"
|
||||
},
|
||||
"objectLifecycle": {
|
||||
"title": "Ciclo de vida del objeto",
|
||||
@ -227,9 +228,14 @@
|
||||
"label": "Preocupaciones"
|
||||
},
|
||||
"trackingDetails": {
|
||||
"title": "Detalles del Seguimiento",
|
||||
"title": "Detalles del seguimiento",
|
||||
"noImageFound": "No se ha encontrado imagen en este momento.",
|
||||
"createObjectMask": "Crear Máscara de Objeto",
|
||||
"adjustAnnotationSettings": "Ajustar configuración de anotaciones"
|
||||
"createObjectMask": "Crear máscara de objeto",
|
||||
"adjustAnnotationSettings": "Ajustar configuración de anotaciones",
|
||||
"scrollViewTips": "Haz clic para ver los momentos relevantes del ciclo de vida de este objeto.",
|
||||
"count": "{{first}} de {{second}}",
|
||||
"lifecycleItemDesc": {
|
||||
"visible": "{{label}} detectado"
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -85,7 +85,7 @@
|
||||
"disable": "Ocultar estadísticas de transmisión"
|
||||
},
|
||||
"manualRecording": {
|
||||
"title": "Grabación bajo demanda",
|
||||
"title": "Bajo demanda",
|
||||
"tips": "Iniciar un evento manual basado en la configuración de retención de grabaciones de esta cámara.",
|
||||
"playInBackground": {
|
||||
"label": "Reproducir en segundo plano",
|
||||
|
||||
@ -7,7 +7,7 @@
|
||||
"camera": "Configuración de cámara - Frigate",
|
||||
"motionTuner": "Ajuste de movimiento - Frigate",
|
||||
"classification": "Configuración de clasificación - Frigate",
|
||||
"general": "Configuración General - Frigate",
|
||||
"general": "Configuración de Interfaz de Usuario - Frigate",
|
||||
"frigatePlus": "Configuración de Frigate+ - Frigate",
|
||||
"notifications": "Configuración de Notificaciones - Frigate",
|
||||
"enrichments": "Configuración de Análisis Avanzado - Frigate",
|
||||
@ -78,7 +78,7 @@
|
||||
"title": "Diseños guardados",
|
||||
"clearAll": "Borrar todos los diseños"
|
||||
},
|
||||
"title": "Configuración general",
|
||||
"title": "Ajustes de Interfaz de Usuario",
|
||||
"toast": {
|
||||
"success": {
|
||||
"clearStoredLayout": "Diseño almacenado eliminado para {{cameraName}}",
|
||||
|
||||
@ -87,7 +87,10 @@
|
||||
"formattedTimestampMonthDayYear": {
|
||||
"12hour": "d MMM, yyyy",
|
||||
"24hour": "d MMM,yyyy"
|
||||
}
|
||||
},
|
||||
"inProgress": "En cours",
|
||||
"invalidStartTime": "Heure de début invalide",
|
||||
"invalidEndTime": "Heure de fin invalide"
|
||||
},
|
||||
"button": {
|
||||
"apply": "Appliquer",
|
||||
@ -124,7 +127,8 @@
|
||||
"export": "Exporter",
|
||||
"deleteNow": "Supprimer maintenant",
|
||||
"download": "Télécharger",
|
||||
"done": "Terminé"
|
||||
"done": "Terminé",
|
||||
"continue": "Continuer"
|
||||
},
|
||||
"menu": {
|
||||
"configuration": "Configuration",
|
||||
@ -226,7 +230,8 @@
|
||||
},
|
||||
"uiPlayground": "Bac à sable de l'interface",
|
||||
"faceLibrary": "Bibliothèque de visages",
|
||||
"languages": "Langues"
|
||||
"languages": "Langues",
|
||||
"classification": "Classification"
|
||||
},
|
||||
"toast": {
|
||||
"save": {
|
||||
@ -272,7 +277,9 @@
|
||||
"back": "Retour",
|
||||
"hide": "Masquer {{item}}",
|
||||
"show": "Afficher {{item}}",
|
||||
"ID": "ID"
|
||||
"ID": "ID",
|
||||
"none": "Aucun",
|
||||
"all": "Tous"
|
||||
},
|
||||
"unit": {
|
||||
"speed": {
|
||||
|
||||
@ -20,28 +20,37 @@
|
||||
"deletedModel_one": "{{count}} modèle supprimé avec succès",
|
||||
"deletedModel_many": "{{count}} modèles supprimés avec succès",
|
||||
"deletedModel_other": "{{count}} modèles supprimés avec succès",
|
||||
"updatedModel": "Configuration du modèle mise à jour avec succès"
|
||||
"updatedModel": "Configuration du modèle mise à jour avec succès",
|
||||
"renamedCategory": "Classe renommée en {{name}} avec succès"
|
||||
},
|
||||
"error": {
|
||||
"deleteImageFailed": "Échec de la suppression : {{errorMessage}}",
|
||||
"deleteCategoryFailed": "Échec de la suppression de la classe : {{errorMessage}}",
|
||||
"categorizeFailed": "Échec de la catégorisation de l'image : {{errorMessage}}",
|
||||
"trainingFailed": "Échec du démarrage de l'entraînement du modèle : {{errorMessage}}",
|
||||
"trainingFailed": "L'entraînement du modèle a échoué. Consultez les journaux de Frigate pour plus de détails.",
|
||||
"deleteModelFailed": "Impossible de supprimer le modèle : {{errorMessage}}",
|
||||
"updateModelFailed": "Impossible de mettre à jour le modèle : {{errorMessage}}"
|
||||
"updateModelFailed": "Impossible de mettre à jour le modèle : {{errorMessage}}",
|
||||
"renameCategoryFailed": "Impossible de renommer la classe : {{errorMessage}}",
|
||||
"trainingFailedToStart": "Impossible de démarrer l'entraînement du modèle : {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"deleteCategory": {
|
||||
"title": "Supprimer la classe",
|
||||
"desc": "Êtes-vous sûr de vouloir supprimer la classe {{name}} ? Cette action supprimera définitivement toutes les images associées et nécessitera un réentraînement du modèle."
|
||||
"desc": "Êtes-vous sûr de vouloir supprimer la classe {{name}} ? Cette action supprimera définitivement toutes les images associées et nécessitera un réentraînement du modèle.",
|
||||
"minClassesTitle": "Impossible de supprimer la classe",
|
||||
"minClassesDesc": "Un modèle de classification doit avoir au moins 2 classes. Ajoutez une autre classe avant de supprimer celle-ci."
|
||||
},
|
||||
"deleteDatasetImages": {
|
||||
"title": "Supprimer les images du jeu de données",
|
||||
"desc": "Êtes-vous sûr de vouloir supprimer {{count}} images du jeu de données {{dataset}} ? Cette action est irréversible et nécessitera un réentraînement du modèle."
|
||||
"desc_one": "Êtes-vous sûr de vouloir supprimer {{count}} image du jeu de données {{dataset}} ? Cette action est irréversible et nécessitera un réentraînement du modèle.",
|
||||
"desc_many": "Êtes-vous sûr de vouloir supprimer {{count}} images du jeu de données {{dataset}} ? Cette action est irréversible et nécessitera un réentraînement du modèle.",
|
||||
"desc_other": "Êtes-vous sûr de vouloir supprimer {{count}} images du jeu de données {{dataset}} ? Cette action est irréversible et nécessitera un réentraînement du modèle."
|
||||
},
|
||||
"deleteTrainImages": {
|
||||
"title": "Supprimer les images d'entraînement",
|
||||
"desc": "Êtes-vous sûr de vouloir supprimer {{count}} images ? Cette action est irréversible."
|
||||
"desc_one": "Êtes-vous sûr de vouloir supprimer {{count}} image ? Cette action est irréversible.",
|
||||
"desc_many": "Êtes-vous sûr de vouloir supprimer {{count}} images ? Cette action est irréversible.",
|
||||
"desc_other": "Êtes-vous sûr de vouloir supprimer {{count}} images ? Cette action est irréversible."
|
||||
},
|
||||
"renameCategory": {
|
||||
"title": "Renommer la classe",
|
||||
@ -140,13 +149,18 @@
|
||||
"generationFailed": "Échec de la génération. Veuillez réessayer.",
|
||||
"classifyFailed": "Échec de la classification des images : {{error}}"
|
||||
},
|
||||
"generateSuccess": "Génération des images d'exemple réussie"
|
||||
"generateSuccess": "Génération des images d'exemple réussie",
|
||||
"allImagesRequired_one": "Veuillez classifier toutes les images. {{count}} image restante.",
|
||||
"allImagesRequired_many": "Veuillez classifier toutes les images. {{count}} images restantes.",
|
||||
"allImagesRequired_other": "Veuillez classifier toutes les images. {{count}} images restantes."
|
||||
}
|
||||
},
|
||||
"deleteModel": {
|
||||
"title": "Supprimer le modèle de classification",
|
||||
"single": "Voulez-vous vraiment supprimer {{name}} ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible.",
|
||||
"desc": "Voulez-vous vraiment supprimer {{count}} modèle(s) ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible."
|
||||
"desc_one": "Voulez-vous vraiment supprimer {{count}} modèle ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible.",
|
||||
"desc_many": "Voulez-vous vraiment supprimer {{count}} modèles ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible.",
|
||||
"desc_other": "Voulez-vous vraiment supprimer {{count}} modèles ? Cela supprimera définitivement toutes les données associées, y compris les images et les données d'entraînement. Cette action est irréversible."
|
||||
},
|
||||
"menu": {
|
||||
"objects": "Objets",
|
||||
@ -160,5 +174,11 @@
|
||||
"descriptionState": "Modifier les classes pour ce modèle de classification d'état. Les modifications nécessiteront un réentraînement du modèle.",
|
||||
"descriptionObject": "Modifier le type d'objet et le type de classification pour ce modèle de classification d'objet",
|
||||
"stateClassesInfo": "Note : La modification des classes d'état nécessite un réentraînement du modèle avec les classes mises à jour."
|
||||
},
|
||||
"tooltip": {
|
||||
"trainingInProgress": "Modèle en cours d'entraînement",
|
||||
"noNewImages": "Aucune nouvelle image pour l'entraînement. Veuillez d'abord classifier plus d'images dans le jeu de données.",
|
||||
"modelNotReady": "Le modèle n'est pas prêt pour l'entraînement.",
|
||||
"noChanges": "Aucune modification du jeu de données depuis le dernier entraînement"
|
||||
}
|
||||
}
|
||||
|
||||
@ -41,8 +41,8 @@
|
||||
"detail": {
|
||||
"noDataFound": "Aucun détail à examiner",
|
||||
"aria": "Activer/désactiver la vue détaillée",
|
||||
"trackedObject_one": "objet",
|
||||
"trackedObject_other": "objets",
|
||||
"trackedObject_one": "{{count}} objet",
|
||||
"trackedObject_other": "{{count}} objets",
|
||||
"noObjectDetailData": "Aucun détail d'objet disponible",
|
||||
"label": "Détail",
|
||||
"settings": "Paramètres de la vue Détail",
|
||||
|
||||
@ -42,7 +42,7 @@
|
||||
"regenerate": "Une nouvelle description a été demandée à {{provider}}. Selon la vitesse de votre fournisseur, la régénération de la nouvelle description peut prendre un certain temps.",
|
||||
"updatedSublabel": "Sous-étiquette mise à jour avec succès",
|
||||
"updatedLPR": "Plaque d'immatriculation mise à jour avec succès",
|
||||
"audioTranscription": "Transcription audio demandée avec succès"
|
||||
"audioTranscription": "Transcription audio demandée avec succès. Selon la vitesse de votre serveur Frigate, la transcription peut prendre un certain temps."
|
||||
},
|
||||
"error": {
|
||||
"regenerate": "Échec de l'appel de {{provider}} pour une nouvelle description : {{errorMessage}}",
|
||||
@ -110,7 +110,8 @@
|
||||
"video": "vidéo",
|
||||
"object_lifecycle": "cycle de vie de l'objet",
|
||||
"snapshot": "instantané",
|
||||
"thumbnail": "Miniature"
|
||||
"thumbnail": "Miniature",
|
||||
"tracking_details": "Détails du suivi"
|
||||
},
|
||||
"objectLifecycle": {
|
||||
"title": "Cycle de vie de l'objet",
|
||||
@ -227,7 +228,9 @@
|
||||
"error": "Échec de la suppression de l'objet suivi : {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"tooltip": "Correspondance : {{type}} à {{confidence}}%"
|
||||
"tooltip": "Correspondance : {{type}} à {{confidence}}%",
|
||||
"previousTrackedObject": "Objet suivi précédent",
|
||||
"nextTrackedObject": "Objet suivi suivant"
|
||||
},
|
||||
"exploreMore": "Explorer plus d'objets {{label}}",
|
||||
"aiAnalysis": {
|
||||
@ -267,7 +270,7 @@
|
||||
"offset": {
|
||||
"desc": "Ces données proviennent du flux de détection de votre caméra, mais elles sont superposées aux images du flux d'enregistrement. Il est peu probable que les deux flux soient parfaitement synchronisés. Par conséquent, le cadre de délimitation et la vidéo ne s'aligneront pas parfaitement. Vous pouvez utiliser ce paramètre pour décaler les annotations vers l'avant ou vers l'arrière dans le temps afin de mieux les aligner avec la vidéo enregistrée.",
|
||||
"millisecondsToOffset": "Millisecondes de décalage pour les annotations de détection. <em>Par défaut : 0</em>",
|
||||
"tips": "ASTUCE : Imaginez une séquence d'événement avec une personne marchant de gauche à droite. Si le cadre de détection sur la chronologie de l'événement est constamment à gauche de la personne, la valeur doit être diminuée. De même, si une personne marche de gauche à droite et que le cadre de détection est constamment devant la personne, la valeur doit être augmentée.",
|
||||
"tips": "Diminuez la valeur si la lecture vidéo est en avance sur les cadres de détection et les points de tracé, et augmentez-la si la lecture vidéo est en retard sur ceux-ci. Cette valeur peut être négative.",
|
||||
"toast": {
|
||||
"success": "Le décalage des annotations pour {{camera}} a été sauvegardé dans le fichier de configuration. Redémarrez Frigate pour appliquer vos modifications."
|
||||
},
|
||||
|
||||
@ -60,7 +60,7 @@
|
||||
"deletedName_other": "{{count}} visages ont été supprimés avec succès.",
|
||||
"uploadedImage": "Image téléversée avec succès",
|
||||
"addFaceLibrary": "{{name}} a été ajouté avec succès à la bibliothèque de visages !",
|
||||
"updatedFaceScore": "Score du visage mis à jour avec succès",
|
||||
"updatedFaceScore": "Score du visage ({{score}}) de {{name}} mis à jour avec succès",
|
||||
"deletedFace_one": "{{count}} visage supprimé avec succès",
|
||||
"deletedFace_many": "{{count}} visages supprimés avec succès",
|
||||
"deletedFace_other": "{{count}} visages supprimés avec succès",
|
||||
|
||||
@ -174,7 +174,11 @@
|
||||
"noCameras": {
|
||||
"title": "Aucune caméra n'est configurée",
|
||||
"description": "Pour commencer, connectez une caméra à Frigate.",
|
||||
"buttonText": "Ajouter une caméra"
|
||||
"buttonText": "Ajouter une caméra",
|
||||
"restricted": {
|
||||
"title": "Aucune caméra disponible",
|
||||
"description": "Vous n'avez pas la permission de visionner les caméras de ce groupe."
|
||||
}
|
||||
},
|
||||
"snapshot": {
|
||||
"takeSnapshot": "Télécharger un instantané",
|
||||
|
||||
@ -5,7 +5,7 @@
|
||||
"camera": "Paramètres des caméras - Frigate",
|
||||
"classification": "Paramètres de classification - Frigate",
|
||||
"motionTuner": "Réglage de la détection de mouvement - Frigate",
|
||||
"general": "Paramètres généraux - Frigate",
|
||||
"general": "Paramètres de l'interface utilisateur - Frigate",
|
||||
"masksAndZones": "Éditeur de masques et de zones - Frigate",
|
||||
"object": "Débogage - Frigate",
|
||||
"frigatePlus": "Paramètres Frigate+ - Frigate",
|
||||
@ -41,7 +41,7 @@
|
||||
"noCamera": "Aucune caméra"
|
||||
},
|
||||
"general": {
|
||||
"title": "Paramètres généraux",
|
||||
"title": "Paramètres de l'interface utilisateur",
|
||||
"liveDashboard": {
|
||||
"title": "Tableau de bord en direct",
|
||||
"automaticLiveView": {
|
||||
@ -55,6 +55,10 @@
|
||||
"displayCameraNames": {
|
||||
"label": "Toujours afficher les noms des caméras",
|
||||
"desc": "Toujours afficher les noms des caméras dans une puce sur le tableau de bord de la vue en direct multi-caméras"
|
||||
},
|
||||
"liveFallbackTimeout": {
|
||||
"label": "Délai d'attente avant repli (Lecteur en direct)",
|
||||
"desc": "Lorsque le flux en direct haute qualité d'une caméra est indisponible, le lecteur bascule en mode faible bande passante après ce nombre de secondes. Par défaut : 3."
|
||||
}
|
||||
},
|
||||
"storedLayouts": {
|
||||
@ -893,9 +897,9 @@
|
||||
"createRole": "Rôle {{role}} créé avec succès",
|
||||
"updateCameras": "Caméras mis à jour pour le rôle {{role}}",
|
||||
"deleteRole": "Rôle {{role}} supprimé avec succès",
|
||||
"userRolesUpdated_one": "{{count}} utilisateurs affectés à ce rôle ont été mis à jour avec des droits \"Observateur\", et ont accès à toutes les caméras.",
|
||||
"userRolesUpdated_many": "",
|
||||
"userRolesUpdated_other": ""
|
||||
"userRolesUpdated_one": "{{count}} utilisateur affecté à ce rôle a été mis à jour avec des droits \"Observateur\", et a accès à toutes les caméras.",
|
||||
"userRolesUpdated_many": "{{count}} utilisateurs affectés à ce rôle ont été mis à jour avec des droits \"Observateur\", et ont accès à toutes les caméras.",
|
||||
"userRolesUpdated_other": "{{count}} utilisateurs affectés à ce rôle ont été mis à jour avec des droits \"Observateur\", et ont accès à toutes les caméras."
|
||||
},
|
||||
"error": {
|
||||
"createRoleFailed": "Échec dans la création du rôle : {{errorMessage}}",
|
||||
@ -942,7 +946,8 @@
|
||||
"steps": {
|
||||
"nameAndConnection": "Nom et connexion",
|
||||
"streamConfiguration": "Configuration du flux",
|
||||
"validationAndTesting": "Validation et tests"
|
||||
"validationAndTesting": "Validation et tests",
|
||||
"probeOrSnapshot": "Sondage ou Instantané"
|
||||
},
|
||||
"save": {
|
||||
"success": "Nouvelle caméra {{cameraName}} enregistrée avec succès",
|
||||
@ -959,7 +964,7 @@
|
||||
"testFailed": "Échec du test de flux : {{error}}"
|
||||
},
|
||||
"step1": {
|
||||
"description": "Saisissez les détails de votre caméra et testez la connexion.",
|
||||
"description": "Saisissez les détails de votre caméra et choisissez d'interroger la caméra ou de sélectionner manuellement la marque.",
|
||||
"cameraName": "Nom de la caméra",
|
||||
"cameraNamePlaceholder": "par ex., porte_entree ou apercu_cour_arriere",
|
||||
"host": "Hôte / Adresse IP",
|
||||
@ -999,10 +1004,19 @@
|
||||
"testing": {
|
||||
"probingMetadata": "Vérification des métadonnées de la caméra en cours...",
|
||||
"fetchingSnapshot": "Récupération de l'instantané de la caméra en cours..."
|
||||
}
|
||||
},
|
||||
"connectionSettings": "Paramètres de connexion",
|
||||
"detectionMethod": "Méthode de détection du flux",
|
||||
"onvifPort": "Port ONVIF",
|
||||
"probeMode": "Interroger la caméra",
|
||||
"manualMode": "Sélection manuelle",
|
||||
"detectionMethodDescription": "Interrogez la caméra avec ONVIF (si pris en charge) pour trouver les URL de flux de la caméra, ou sélectionnez manuellement la marque de la caméra pour utiliser des URL prédéfinies. Pour saisir une URL RTSP personnalisée, choisissez la méthode manuelle et sélectionnez \"Autre\".",
|
||||
"onvifPortDescription": "Pour les caméras prenant en charge ONVIF, il s'agit généralement de 80 ou 8080.",
|
||||
"useDigestAuth": "Utiliser l'authentification Digest",
|
||||
"useDigestAuthDescription": "Utilisez l'authentification Digest HTTP pour ONVIF. Certaines caméras peuvent nécessiter un nom d'utilisateur/mot de passe ONVIF dédié au lieu de l'utilisateur administrateur standard."
|
||||
},
|
||||
"step2": {
|
||||
"description": "Définissez les rôles du flux et ajoutez des flux supplémentaires pour votre caméra.",
|
||||
"description": "Interrogez la caméra pour les flux disponibles ou configurez des paramètres manuels en fonction de la méthode de détection sélectionnée.",
|
||||
"streamsTitle": "Flux de caméra",
|
||||
"addStream": "Ajouter un flux",
|
||||
"addAnotherStream": "Ajouter un autre flux",
|
||||
@ -1021,8 +1035,8 @@
|
||||
"detect": "Détection d'objets"
|
||||
},
|
||||
"testStream": "Tester la connexion",
|
||||
"testSuccess": "Test du flux réussi !",
|
||||
"testFailed": "Échec du test du flux",
|
||||
"testSuccess": "Test de connexion réussi !",
|
||||
"testFailed": "Échec du test de connexion. Veuillez vérifier votre saisie et réessayer.",
|
||||
"testFailedTitle": "Échec du test",
|
||||
"connected": "Connecté",
|
||||
"notConnected": "Non connecté",
|
||||
@ -1038,10 +1052,42 @@
|
||||
"featuresPopover": {
|
||||
"title": "Fonctionnalités du flux",
|
||||
"description": "Utilisez la rediffusion du flux go2rtc pour réduire le nombre de connexions à votre caméra."
|
||||
},
|
||||
"streamDetails": "Détails du flux",
|
||||
"probing": "Interrogation de la caméra en cours...",
|
||||
"retry": "Réessayer",
|
||||
"testing": {
|
||||
"probingMetadata": "Interrogation des métadonnées de la caméra en cours...",
|
||||
"fetchingSnapshot": "Récupération de l'instantané de la caméra en cours..."
|
||||
},
|
||||
"probeFailed": "Impossible d'interroger la caméra : {{error}}",
|
||||
"probingDevice": "Interrogation de l'appareil en cours...",
|
||||
"probeSuccessful": "Interrogation réussie",
|
||||
"probeError": "Erreur d'interrogation",
|
||||
"probeNoSuccess": "Échec de l'interrogation",
|
||||
"deviceInfo": "Informations sur l'appareil",
|
||||
"manufacturer": "Fabricant",
|
||||
"model": "Modèle",
|
||||
"firmware": "Micrologiciel",
|
||||
"profiles": "Profils",
|
||||
"ptzSupport": "Prise en charge PTZ",
|
||||
"autotrackingSupport": "Prise en charge du suivi automatique",
|
||||
"presets": "Préréglages",
|
||||
"rtspCandidates": "Candidats RTSP",
|
||||
"rtspCandidatesDescription": "Les URL RTSP suivantes ont été trouvées lors de l'interrogation de la caméra. Testez la connexion pour afficher les métadonnées du flux.",
|
||||
"noRtspCandidates": "Aucune URL RTSP n'a été trouvée sur la caméra. Vos identifiants sont peut-être incorrects, ou la caméra ne prend peut-être pas en charge ONVIF ou la méthode utilisée pour récupérer les URL RTSP. Revenez en arrière et saisissez l'URL RTSP manuellement.",
|
||||
"candidateStreamTitle": "Candidat {{number}}",
|
||||
"useCandidate": "Utiliser",
|
||||
"uriCopy": "Copier",
|
||||
"uriCopied": "URI copiée dans le presse-papiers",
|
||||
"testConnection": "Tester la connexion",
|
||||
"toggleUriView": "Cliquer pour basculer l'affichage de l'URI complet",
|
||||
"errors": {
|
||||
"hostRequired": "L'hôte/adresse IP est requis."
|
||||
}
|
||||
},
|
||||
"step3": {
|
||||
"description": "Validation et analyse finales avant l'enregistrement de votre nouvelle caméra. Connectez chaque flux avant d'enregistrer.",
|
||||
"description": "Configurez les rôles des flux et ajoutez des flux supplémentaires pour votre caméra.",
|
||||
"validationTitle": "Validation du flux",
|
||||
"connectAllStreams": "Connecter tous les flux",
|
||||
"reconnectionSuccess": "Reconnexion réussie.",
|
||||
@ -1082,7 +1128,91 @@
|
||||
},
|
||||
"valid": "Valide",
|
||||
"ffmpegModule": "Utiliser le mode de compatibilité du flux",
|
||||
"ffmpegModuleDescription": "Si le flux ne se charge pas après plusieurs tentatives, essayez d'activer cette option. Lorsqu'elle est activée, Frigate utilisera le module ffmpeg avec go2rtc. Cela peut offrir une meilleure compatibilité avec certains flux de caméra."
|
||||
"ffmpegModuleDescription": "Si le flux ne se charge pas après plusieurs tentatives, essayez d'activer cette option. Lorsqu'elle est activée, Frigate utilisera le module ffmpeg avec go2rtc. Cela peut offrir une meilleure compatibilité avec certains flux de caméra.",
|
||||
"streamsTitle": "Flux de la caméra",
|
||||
"addStream": "Ajouter un flux",
|
||||
"addAnotherStream": "Ajouter un autre flux",
|
||||
"streamUrl": "URL du flux",
|
||||
"streamUrlPlaceholder": "rtsp://nomdutilisateur:motdepasse@hote:port/chemin",
|
||||
"selectStream": "Sélectionner un flux",
|
||||
"searchCandidates": "Rechercher des candidats",
|
||||
"noStreamFound": "Aucun flux trouvé",
|
||||
"url": "URL",
|
||||
"resolution": "Résolution",
|
||||
"selectResolution": "Sélectionner la résolution",
|
||||
"quality": "Qualité",
|
||||
"selectQuality": "Sélectionner la qualité",
|
||||
"roleLabels": {
|
||||
"detect": "Détection d'objet",
|
||||
"record": "Enregistrement",
|
||||
"audio": "Audio"
|
||||
},
|
||||
"testStream": "Tester la connexion",
|
||||
"testSuccess": "Test du flux réussi !",
|
||||
"testFailed": "Échec du test du flux",
|
||||
"testFailedTitle": "Échec du test",
|
||||
"connected": "Connecté",
|
||||
"notConnected": "Non connecté",
|
||||
"featuresTitle": "Fonctionnalités",
|
||||
"go2rtc": "Réduire les connexions à la caméra",
|
||||
"detectRoleWarning": "Au moins un flux doit avoir le rôle 'détection' pour continuer.",
|
||||
"rolesPopover": {
|
||||
"title": "Rôles du flux",
|
||||
"detect": "Flux principal pour la détection d'objet",
|
||||
"record": "Enregistre des segments du flux vidéo en fonction des paramètres de configuration",
|
||||
"audio": "Flux pour la détection basée sur l'audio"
|
||||
},
|
||||
"featuresPopover": {
|
||||
"title": "Fonctionnalités du flux",
|
||||
"description": "Utiliser la rediffusion go2rtc pour réduire les connexions à votre caméra"
|
||||
}
|
||||
},
|
||||
"step4": {
|
||||
"description": "Validation et analyse finales avant d'enregistrer votre nouvelle caméra. Connectez chaque flux avant d'enregistrer.",
|
||||
"validationTitle": "Validation du flux",
|
||||
"connectAllStreams": "Connecter tous les flux",
|
||||
"reconnectionSuccess": "Reconnexion réussie",
|
||||
"reconnectionPartial": "Certains flux n'ont pas réussi à se reconnecter.",
|
||||
"streamUnavailable": "Aperçu du flux non disponible",
|
||||
"reload": "Recharger",
|
||||
"connecting": "En cours de connexion...",
|
||||
"streamTitle": "Flux {{number}}",
|
||||
"valid": "Valide",
|
||||
"failed": "Échec",
|
||||
"notTested": "Non testé",
|
||||
"connectStream": "Connecter",
|
||||
"connectingStream": "En cours de connexion",
|
||||
"disconnectStream": "Déconnecter",
|
||||
"estimatedBandwidth": "Bande passante estimée",
|
||||
"roles": "Rôles",
|
||||
"ffmpegModule": "Utiliser le mode de compatibilité du flux",
|
||||
"ffmpegModuleDescription": "Si le flux ne se charge pas après plusieurs tentatives, essayez d'activer cette option. Lorsqu'elle est activée, Frigate utilisera le module ffmpeg avec go2rtc. Cela peut offrir une meilleure compatibilité avec certains flux de caméra.",
|
||||
"none": "Aucun",
|
||||
"error": "Erreur",
|
||||
"streamValidated": "Flux {{number}} validé avec succès",
|
||||
"streamValidationFailed": "Échec de la validation du flux {{number}}",
|
||||
"saveAndApply": "Enregistrer la nouvelle caméra",
|
||||
"saveError": "Configuration invalide. Veuillez vérifier vos paramètres.",
|
||||
"issues": {
|
||||
"title": "Validation du flux",
|
||||
"videoCodecGood": "Le codec vidéo est {{codec}}.",
|
||||
"audioCodecGood": "Le codec audio est {{codec}}.",
|
||||
"resolutionHigh": "Une résolution de {{resolution}} peut entraîner une utilisation accrue des ressources.",
|
||||
"resolutionLow": "Une résolution de {{resolution}} peut être trop faible pour une détection fiable des petits objets.",
|
||||
"noAudioWarning": "Aucun audio détecté pour ce flux, les enregistrements n'auront pas de son.",
|
||||
"audioCodecRecordError": "Le codec audio AAC est requis pour prendre en charge l'audio dans les enregistrements.",
|
||||
"audioCodecRequired": "Un flux audio est requis pour prendre en charge la détection audio.",
|
||||
"restreamingWarning": "Réduire les connexions à la caméra pour le flux d'enregistrement peut légèrement augmenter l'utilisation du processeur.",
|
||||
"brands": {
|
||||
"reolink-rtsp": "Le RTSP Reolink n'est pas recommandé. Activez HTTP dans les paramètres du micrologiciel de la caméra et redémarrez l'assistant."
|
||||
},
|
||||
"dahua": {
|
||||
"substreamWarning": "Le sous-flux 1 est limité à une basse résolution. De nombreuses caméras Dahua / Amcrest / EmpireTech prennent en charge des sous-flux supplémentaires qui doivent être activés dans les paramètres de la caméra. Il est recommandé de vérifier et d'utiliser ces flux s'ils sont disponibles."
|
||||
},
|
||||
"hikvision": {
|
||||
"substreamWarning": "Le sous-flux 1 est limité à une basse résolution. De nombreuses caméras Hikvision prennent en charge des sous-flux supplémentaires qui doivent être activés dans les paramètres de la caméra. Il est recommandé de vérifier et d'utiliser ces flux s'ils sont disponibles."
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
"cameraManagement": {
|
||||
|
||||
@ -76,7 +76,12 @@
|
||||
}
|
||||
},
|
||||
"npuUsage": "Utilisation NPU",
|
||||
"npuMemory": "Mémoire NPU"
|
||||
"npuMemory": "Mémoire NPU",
|
||||
"intelGpuWarning": {
|
||||
"title": "Avertissement relatif aux statistiques du GPU Intel",
|
||||
"message": "Statistiques du GPU non disponibles",
|
||||
"description": "Il s'agit d'un bug connu de l'outil de statistiques GPU d'Intel (intel_gpu_top) : il peut afficher à tort une utilisation de 0 %, même lorsque l'accélération matérielle et la détection d'objets fonctionnent correctement sur l'iGPU. Ce problème ne vient pas de Frigate. Vous pouvez redémarrer l'hôte pour rétablir temporairement l'affichage et confirmer le fonctionnement du GPU. Les performances ne sont pas affectées."
|
||||
}
|
||||
},
|
||||
"otherProcesses": {
|
||||
"title": "Autres processus",
|
||||
@ -151,7 +156,7 @@
|
||||
"copyToClipboard": "Données de la sonde copiées dans le presse-papiers"
|
||||
},
|
||||
"error": {
|
||||
"unableToProbeCamera": "Impossible d'inspecter la caméra : {{errorMessage}}"
|
||||
"unableToProbeCamera": "Impossible d'interroger la caméra : {{errorMessage}}"
|
||||
}
|
||||
}
|
||||
},
|
||||
@ -180,7 +185,14 @@
|
||||
"yolov9_plate_detection": "Détection de plaques d'immatriculation YOLOv9",
|
||||
"face_recognition": "Reconnaissance faciale",
|
||||
"text_embedding": "Vitesse d'embedding de visage",
|
||||
"yolov9_plate_detection_speed": "Vitesse de détection de plaques d'immatriculation YOLOv9"
|
||||
}
|
||||
"yolov9_plate_detection_speed": "Vitesse de détection de plaques d'immatriculation YOLOv9",
|
||||
"review_description": "Description de la revue",
|
||||
"review_description_speed": "Vitesse de la description de la revue",
|
||||
"review_description_events_per_second": "Description de la revue",
|
||||
"object_description": "Description de l'objet",
|
||||
"object_description_speed": "Vitesse de la description d'objet",
|
||||
"object_description_events_per_second": "Description de l'objet"
|
||||
},
|
||||
"averageInf": "Temps d'inférence moyen"
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,5 +1,5 @@
|
||||
{
|
||||
"filter": "Filtar",
|
||||
"filter": "Filter",
|
||||
"classes": {
|
||||
"label": "Klase"
|
||||
}
|
||||
|
||||
@ -1,5 +1,28 @@
|
||||
{
|
||||
"description": {
|
||||
"addFace": "Vodič za dodavanje nove kolekcije u Biblioteku lica."
|
||||
},
|
||||
"steps": {
|
||||
"faceName": "Unesi Ime Lica",
|
||||
"uploadFace": "Prenesi Sliku Lica",
|
||||
"nextSteps": "Sljedeći Koraci",
|
||||
"description": {
|
||||
"uploadFace": "Prenesite sliku {{name}} koja prikazuje njezino lice iz prednjeg kuta. Slika ne mora biti obrezana samo na njezino lice."
|
||||
}
|
||||
},
|
||||
"train": {
|
||||
"title": "Nedavna Prepoznavanja",
|
||||
"aria": "Odaberite nedavna prepoznavanja",
|
||||
"empty": "Nema nedavnih pokušaja prepoznavanja lica"
|
||||
},
|
||||
"deleteFaceLibrary": {
|
||||
"title": "Izbriši Ime",
|
||||
"desc": "Jeste li sigurni da želite izbrisati kolekciju {{name}}? Ovim će se trajno izbrisati sva povezana lica."
|
||||
},
|
||||
"deleteFaceAttempts": {
|
||||
"title": "Izbriši Lica",
|
||||
"desc_one": "Jeste li sigurni da želite izbrisati {{count}} lice? Ova se radnja ne može poništiti.",
|
||||
"desc_few": "Jeste li sigurni da želite izbrisati {{count}} lica? Ova se radnja ne može poništiti.",
|
||||
"desc_other": "Jeste li sigurni da želite izbrisati {{count}} lica? Ova se radnja ne može poništiti."
|
||||
}
|
||||
}
|
||||
|
||||
@ -1,4 +1,4 @@
|
||||
{
|
||||
"filter": "Filtar",
|
||||
"filter": "Filter",
|
||||
"export": "Izvoz"
|
||||
}
|
||||
|
||||
@ -4,7 +4,8 @@
|
||||
"deleteClassificationAttempts": "Osztályozási képek törlése",
|
||||
"deleteImages": "Képek törlése",
|
||||
"trainModel": "Modell betanítása",
|
||||
"deleteModels": "Modellek törlése"
|
||||
"deleteModels": "Modellek törlése",
|
||||
"editModel": "Modell szerkesztése"
|
||||
},
|
||||
"toast": {
|
||||
"success": {
|
||||
|
||||
@ -399,7 +399,7 @@
|
||||
"mechanical_fan": "Ventilatore meccanico",
|
||||
"air_conditioning": "Aria condizionata",
|
||||
"cash_register": "Registratore di cassa",
|
||||
"single-lens_reflex_camera": "Fotocamera reflex a obiettivo singolo",
|
||||
"single-lens_reflex_camera": "Telecamera reflex a obiettivo singolo",
|
||||
"tools": "Utensili",
|
||||
"jackhammer": "Martello pneumatico",
|
||||
"sawing": "Segare",
|
||||
|
||||
@ -87,7 +87,10 @@
|
||||
"formattedTimestampMonthDayYear": {
|
||||
"12hour": "d MMM, yyyy",
|
||||
"24hour": "d MMM, yyyy"
|
||||
}
|
||||
},
|
||||
"inProgress": "In corso",
|
||||
"invalidStartTime": "Ora di inizio non valida",
|
||||
"invalidEndTime": "Ora di fine non valida"
|
||||
},
|
||||
"button": {
|
||||
"cancel": "Annulla",
|
||||
@ -124,7 +127,8 @@
|
||||
"back": "Indietro",
|
||||
"pictureInPicture": "Immagine nell'immagine",
|
||||
"twoWayTalk": "Comunicazione bidirezionale",
|
||||
"cameraAudio": "Audio della telecamera"
|
||||
"cameraAudio": "Audio della telecamera",
|
||||
"continue": "Continua"
|
||||
},
|
||||
"unit": {
|
||||
"speed": {
|
||||
@ -148,7 +152,9 @@
|
||||
"back": "Vai indietro",
|
||||
"hide": "Nascondi {{item}}",
|
||||
"show": "Mostra {{item}}",
|
||||
"ID": "ID"
|
||||
"ID": "ID",
|
||||
"none": "Nessuna",
|
||||
"all": "Tutte"
|
||||
},
|
||||
"menu": {
|
||||
"configuration": "Configurazione",
|
||||
@ -250,7 +256,8 @@
|
||||
"setPassword": "Imposta password"
|
||||
},
|
||||
"withSystem": "Sistema",
|
||||
"faceLibrary": "Raccolta volti"
|
||||
"faceLibrary": "Raccolta volti",
|
||||
"classification": "Classificazione"
|
||||
},
|
||||
"pagination": {
|
||||
"next": {
|
||||
|
||||
@ -129,7 +129,7 @@
|
||||
"search": {
|
||||
"placeholder": "Cerca per etichetta o sottoetichetta..."
|
||||
},
|
||||
"noImages": "Nessuna miniatura trovata per questa fotocamera",
|
||||
"noImages": "Nessuna miniatura trovata per questa telecamera",
|
||||
"unknownLabel": "Immagine di attivazione salvata"
|
||||
}
|
||||
}
|
||||
|
||||
@ -20,28 +20,37 @@
|
||||
"deletedModel_one": "Eliminato con successo {{count}} modello",
|
||||
"deletedModel_many": "Eliminati con successo {{count}} modelli",
|
||||
"deletedModel_other": "Eliminati con successo {{count}} modelli",
|
||||
"updatedModel": "Configurazione del modello aggiornata correttamente"
|
||||
"updatedModel": "Configurazione del modello aggiornata correttamente",
|
||||
"renamedCategory": "Classe rinominata correttamente in {{name}}"
|
||||
},
|
||||
"error": {
|
||||
"deleteImageFailed": "Impossibile eliminare: {{errorMessage}}",
|
||||
"deleteCategoryFailed": "Impossibile eliminare la classe: {{errorMessage}}",
|
||||
"categorizeFailed": "Impossibile categorizzare l'immagine: {{errorMessage}}",
|
||||
"trainingFailed": "Impossibile avviare l'addestramento del modello: {{errorMessage}}",
|
||||
"trainingFailed": "Addestramento del modello fallito. Controlla i registri di Frigate per i dettagli.",
|
||||
"deleteModelFailed": "Impossibile eliminare il modello: {{errorMessage}}",
|
||||
"updateModelFailed": "Impossibile aggiornare il modello: {{errorMessage}}"
|
||||
"updateModelFailed": "Impossibile aggiornare il modello: {{errorMessage}}",
|
||||
"trainingFailedToStart": "Impossibile avviare l'addestramento del modello: {{errorMessage}}",
|
||||
"renameCategoryFailed": "Impossibile rinominare la classe: {{errorMessage}}"
|
||||
}
|
||||
},
|
||||
"deleteCategory": {
|
||||
"title": "Elimina classe",
|
||||
"desc": "Vuoi davvero eliminare la classe {{name}}? Questa operazione eliminerà definitivamente tutte le immagini associate e richiederà un nuovo addestramento del modello."
|
||||
"desc": "Vuoi davvero eliminare la classe {{name}}? Questa operazione eliminerà definitivamente tutte le immagini associate e richiederà un nuovo addestramento del modello.",
|
||||
"minClassesTitle": "Impossibile eliminare la classe",
|
||||
"minClassesDesc": "Un modello di classificazione deve avere almeno 2 classi. Aggiungi un'altra classe prima di eliminare questa."
|
||||
},
|
||||
"deleteDatasetImages": {
|
||||
"title": "Elimina immagini della base dati",
|
||||
"desc": "Vuoi davvero eliminare {{count}} immagini da {{dataset}}? Questa azione non può essere annullata e richiederà un nuovo addestramento del modello."
|
||||
"desc_one": "Vuoi davvero eliminare {{count}} immagine da {{dataset}}? Questa azione non può essere annullata e richiederà un nuovo addestramento del modello.",
|
||||
"desc_many": "Vuoi davvero eliminare {{count}} immagini da {{dataset}}? Questa azione non può essere annullata e richiederà un nuovo addestramento del modello.",
|
||||
"desc_other": "Vuoi davvero eliminare {{count}} immagini da {{dataset}}? Questa azione non può essere annullata e richiederà un nuovo addestramento del modello."
|
||||
},
|
||||
"deleteTrainImages": {
|
||||
"title": "Elimina le immagini di addestramento",
|
||||
"desc": "Vuoi davvero eliminare {{count}} immagini? Questa azione non può essere annullata."
|
||||
"desc_one": "Vuoi davvero eliminare {{count}} immagine? Questa azione non può essere annullata.",
|
||||
"desc_many": "Vuoi davvero eliminare {{count}} immagini? Questa azione non può essere annullata.",
|
||||
"desc_other": "Vuoi davvero eliminare {{count}} immagini? Questa azione non può essere annullata."
|
||||
},
|
||||
"renameCategory": {
|
||||
"title": "Rinomina classe",
|
||||
@ -140,13 +149,18 @@
|
||||
"generationFailed": "Generazione fallita. Per favore riprova.",
|
||||
"classifyFailed": "Impossibile classificare le immagini: {{error}}"
|
||||
},
|
||||
"generateSuccess": "Immagini campione generate correttamente"
|
||||
"generateSuccess": "Immagini campione generate correttamente",
|
||||
"allImagesRequired_one": "Classifica tutte le immagini. Rimane {{count}} immagine.",
|
||||
"allImagesRequired_many": "Classifica tutte le immagini. Rimangono {{count}} immagini.",
|
||||
"allImagesRequired_other": "Classifica tutte le immagini. Rimangono {{count}} immagini."
|
||||
}
|
||||
},
|
||||
"deleteModel": {
|
||||
"title": "Elimina modello di classificazione",
|
||||
"single": "Vuoi davvero eliminare {{name}}? Questa operazione eliminerà definitivamente tutti i dati associati, comprese le immagini e i dati di allenamento. Questa azione non può essere annullata.",
|
||||
"desc": "Vuoi davvero eliminare {{count}} modello/i? Questa operazione eliminerà definitivamente tutti i dati associati, comprese le immagini e i dati di addestramento. Questa azione non può essere annullata."
|
||||
"desc_one": "Vuoi davvero eliminare {{count}} modello? Questa operazione eliminerà definitivamente tutti i dati associati, comprese le immagini e i dati di addestramento. Questa azione non può essere annullata.",
|
||||
"desc_many": "Vuoi davvero eliminare {{count}} modelli? Questa operazione eliminerà definitivamente tutti i dati associati, comprese le immagini e i dati di addestramento. Questa azione non può essere annullata.",
|
||||
"desc_other": "Vuoi davvero eliminare {{count}} modelli? Questa operazione eliminerà definitivamente tutti i dati associati, comprese le immagini e i dati di addestramento. Questa azione non può essere annullata."
|
||||
},
|
||||
"menu": {
|
||||
"objects": "Oggetti",
|
||||
@ -160,5 +174,11 @@
|
||||
"descriptionState": "Modifica le classi per questo modello di classificazione dello stato. Le modifiche richiederanno un nuovo addestramento del modello.",
|
||||
"descriptionObject": "Modifica il tipo di oggetto e il tipo di classificazione per questo modello di classificazione degli oggetti.",
|
||||
"stateClassesInfo": "Nota: la modifica delle classi di stato richiede il riaddestramento del modello con le classi aggiornate."
|
||||
},
|
||||
"tooltip": {
|
||||
"trainingInProgress": "Il modello è attualmente in addestramento",
|
||||
"modelNotReady": "Il modello non è pronto per l'addestramento",
|
||||
"noNewImages": "Nessuna nuova immagine da addestrare. Classifica prima più immagini nel database.",
|
||||
"noChanges": "Nessuna modifica al database dall'ultimo addestramento."
|
||||
}
|
||||
}
|
||||
|
||||
@ -41,8 +41,8 @@
|
||||
"detail": {
|
||||
"noDataFound": "Nessun dato dettagliato da rivedere",
|
||||
"aria": "Attiva/disattiva la visualizzazione dettagliata",
|
||||
"trackedObject_one": "oggetto",
|
||||
"trackedObject_other": "oggetti",
|
||||
"trackedObject_one": "{{count}} oggetto",
|
||||
"trackedObject_other": "{{count}} oggetti",
|
||||
"noObjectDetailData": "Non sono disponibili dati dettagliati sull'oggetto.",
|
||||
"label": "Dettaglio",
|
||||
"settings": "Impostazioni di visualizzazione dettagliata",
|
||||
|
||||
@ -53,7 +53,7 @@
|
||||
"regenerate": "È stata richiesta una nuova descrizione a {{provider}}. A seconda della velocità del tuo provider, la rigenerazione della nuova descrizione potrebbe richiedere del tempo.",
|
||||
"updatedSublabel": "Sottoetichetta aggiornata correttamente.",
|
||||
"updatedLPR": "Targa aggiornata con successo.",
|
||||
"audioTranscription": "Trascrizione audio richiesta con successo."
|
||||
"audioTranscription": "Trascrizione audio richiesta con successo. A seconda della velocità del server Frigate, la trascrizione potrebbe richiedere del tempo."
|
||||
},
|
||||
"error": {
|
||||
"regenerate": "Impossibile chiamare {{provider}} per una nuova descrizione: {{errorMessage}}",
|
||||
@ -159,7 +159,8 @@
|
||||
"object_lifecycle": "ciclo di vita dell'oggetto",
|
||||
"details": "dettagli",
|
||||
"video": "video",
|
||||
"thumbnail": "miniatura"
|
||||
"thumbnail": "miniatura",
|
||||
"tracking_details": "dettagli di tracciamento"
|
||||
},
|
||||
"itemMenu": {
|
||||
"downloadSnapshot": {
|
||||
@ -222,7 +223,9 @@
|
||||
"success": "Oggetto tracciato eliminato correttamente."
|
||||
}
|
||||
},
|
||||
"tooltip": "Corrispondenza {{type}} al {{confidence}}%"
|
||||
"tooltip": "Corrispondenza {{type}} al {{confidence}}%",
|
||||
"previousTrackedObject": "Oggetto tracciato in precedenza",
|
||||
"nextTrackedObject": "Prossimo oggetto tracciato"
|
||||
},
|
||||
"trackedObjectsCount_one": "{{count}} oggetto tracciato ",
|
||||
"trackedObjectsCount_many": "{{count}} oggetti tracciati ",
|
||||
@ -273,7 +276,7 @@
|
||||
"label": "Differenza annotazione",
|
||||
"desc": "Questi dati provengono dal flusso di rilevamento della telecamera, ma vengono sovrapposti alle immagini del flusso di registrazione. È improbabile che i due flussi siano perfettamente sincronizzati. Di conseguenza, il riquadro di delimitazione e il filmato non saranno perfettamente allineati. È possibile utilizzare questa impostazione per spostare le annotazioni in avanti o indietro nel tempo per allinearle meglio al filmato registrato.",
|
||||
"millisecondsToOffset": "Millisecondi per compensare il rilevamento delle annotazioni. <em>Predefinito: 0</em>",
|
||||
"tips": "SUGGERIMENTO: Immagina un video evento con una persona che cammina da sinistra a destra. Se il riquadro di delimitazione della cronologia dell'evento si trova costantemente a sinistra della persona, il valore dovrebbe essere diminuito. Allo stesso modo, se una persona cammina da sinistra a destra e il riquadro di delimitazione si trova costantemente davanti alla persona, il valore dovrebbe essere aumentato.",
|
||||
"tips": "Ridurre il valore se la riproduzione video è in anticipo rispetto ai riquadri e ai punti del percorso, e aumentarlo se la riproduzione video è in ritardo rispetto ad essi. Questo valore può essere negativo.",
|
||||
"toast": {
|
||||
"success": "La differenza dell'annotazione per {{camera}} è stato salvato nel file di configurazione. Riavvia Frigate per applicare le modifiche."
|
||||
}
|
||||
|
||||
@ -38,7 +38,7 @@
|
||||
"deletedFace_one": "Eliminato con successo {{count}} volto.",
|
||||
"deletedFace_many": "Eliminati con successo {{count}} volti.",
|
||||
"deletedFace_other": "Eliminati con successo {{count}} volti.",
|
||||
"updatedFaceScore": "Punteggio del volto aggiornato con successo.",
|
||||
"updatedFaceScore": "Punteggio del volto aggiornato con successo a {{name}} ({{score}}).",
|
||||
"uploadedImage": "Immagine caricata correttamente.",
|
||||
"addFaceLibrary": "{{name}} è stato aggiunto con successo alla Libreria dei Volti!",
|
||||
"renamedFace": "Rinominato correttamente il volto in {{name}}"
|
||||
|
||||
@ -174,7 +174,11 @@
|
||||
"noCameras": {
|
||||
"buttonText": "Aggiungi telecamera",
|
||||
"title": "Nessuna telecamera configurata",
|
||||
"description": "Per iniziare, collega una telecamera a Frigate."
|
||||
"description": "Per iniziare, collega una telecamera a Frigate.",
|
||||
"restricted": {
|
||||
"title": "Nessuna telecamera disponibile",
|
||||
"description": "Non hai l'autorizzazione per visualizzare alcuna telecamera in questo gruppo."
|
||||
}
|
||||
},
|
||||
"snapshot": {
|
||||
"takeSnapshot": "Scarica l'istantanea attuale",
|
||||
|
||||
@ -7,7 +7,7 @@
|
||||
"masksAndZones": "Editor di maschere e zone - Frigate",
|
||||
"motionTuner": "Regolatore di movimento - Frigate",
|
||||
"object": "Correzioni - Frigate",
|
||||
"general": "Impostazioni generali - Frigate",
|
||||
"general": "Impostazioni interfaccia - Frigate",
|
||||
"frigatePlus": "Impostazioni Frigate+ - Frigate",
|
||||
"notifications": "Impostazioni di notifiche - Frigate",
|
||||
"enrichments": "Impostazioni di miglioramento - Frigate",
|
||||
@ -498,9 +498,13 @@
|
||||
"displayCameraNames": {
|
||||
"label": "Mostra sempre i nomi delle telecamere",
|
||||
"desc": "Mostra sempre i nomi delle telecamere in una scheda nel cruscotto della visualizzazione dal vivo multi telecamera."
|
||||
},
|
||||
"liveFallbackTimeout": {
|
||||
"label": "Scadenza attesa lettore dal vivo",
|
||||
"desc": "Quando la trasmissione dal vivo ad alta qualità di una telecamera non è disponibile, dopo questo numero di secondi torna alla modalità a bassa larghezza di banda. Valore predefinito: 3."
|
||||
}
|
||||
},
|
||||
"title": "Impostazioni generali",
|
||||
"title": "Impostazioni interfaccia",
|
||||
"storedLayouts": {
|
||||
"title": "Formati memorizzati",
|
||||
"desc": "La disposizione delle telecamere in un gruppo può essere trascinata/ridimensionata. Le posizioni vengono salvate nella memoria locale del browser.",
|
||||
@ -892,9 +896,9 @@
|
||||
"createRole": "Ruolo {{role}} creato con successo",
|
||||
"updateCameras": "Telecamere aggiornate per il ruolo {{role}}",
|
||||
"deleteRole": "Ruolo {{role}} eliminato con successo",
|
||||
"userRolesUpdated_one": "{{count}} utenti assegnati a questo ruolo sono stati aggiornati a \"spettatore\", che ha accesso a tutte le telecamere.",
|
||||
"userRolesUpdated_many": "",
|
||||
"userRolesUpdated_other": ""
|
||||
"userRolesUpdated_one": "{{count}} utente assegnato a questo ruolo è stato aggiornato a \"spettatore\", che ha accesso a tutte le telecamere.",
|
||||
"userRolesUpdated_many": "{{count}} utenti assegnati a questo ruolo sono stati aggiornati a \"spettatore\", che ha accesso a tutte le telecamere.",
|
||||
"userRolesUpdated_other": "{{count}} utenti assegnati a questo ruolo sono stati aggiornati a \"spettatore\", che ha accesso a tutte le telecamere."
|
||||
},
|
||||
"error": {
|
||||
"createRoleFailed": "Impossibile creare il ruolo: {{errorMessage}}",
|
||||
@ -975,7 +979,7 @@
|
||||
"cameraWizard": {
|
||||
"step3": {
|
||||
"streamUnavailable": "Anteprima trasmissione non disponibile",
|
||||
"description": "Convalida e analisi finale prima di salvare la nuova telecamera. Connetti ogni flusso prima di salvare.",
|
||||
"description": "Configura i ruoli del flusso e aggiungi altri flussi alla tua telecamera.",
|
||||
"validationTitle": "Convalida del flusso",
|
||||
"connectAllStreams": "Connetti tutti i flussi",
|
||||
"reconnectionSuccess": "Riconnessione riuscita.",
|
||||
@ -1015,14 +1019,52 @@
|
||||
"resolutionLow": "Una risoluzione di {{resolution}} potrebbe essere troppo bassa per un rilevamento affidabile di oggetti di piccole dimensioni."
|
||||
},
|
||||
"ffmpegModule": "Utilizza la modalità di compatibilità della trasmissione",
|
||||
"ffmpegModuleDescription": "Se il flusso non si carica dopo diversi tentativi, prova ad abilitare questa opzione. Se abilitata, Frigate utilizzerà il modulo ffmpeg con go2rtc. Questo potrebbe garantire una migliore compatibilità con alcuni flussi di telecamere."
|
||||
"ffmpegModuleDescription": "Se il flusso non si carica dopo diversi tentativi, prova ad abilitare questa opzione. Se abilitata, Frigate utilizzerà il modulo ffmpeg con go2rtc. Questo potrebbe garantire una migliore compatibilità con alcuni flussi di telecamere.",
|
||||
"streamsTitle": "Flussi della telecamera",
|
||||
"addStream": "Aggiungi flusso",
|
||||
"addAnotherStream": "Aggiungi un altro flusso",
|
||||
"streamUrl": "URL del flusso",
|
||||
"streamUrlPlaceholder": "rtsp://nomeutente:password@sistema:porta/percorso",
|
||||
"selectStream": "Seleziona un flusso",
|
||||
"searchCandidates": "Ricerca candidati in corso...",
|
||||
"noStreamFound": "Nessun flusso trovato",
|
||||
"url": "URL",
|
||||
"resolution": "Risoluzione",
|
||||
"selectResolution": "Seleziona la risoluzione",
|
||||
"quality": "Qualità",
|
||||
"selectQuality": "Seleziona la qualità",
|
||||
"roleLabels": {
|
||||
"detect": "Rilevamento di oggetti",
|
||||
"record": "Registrazione",
|
||||
"audio": "Audio"
|
||||
},
|
||||
"testStream": "Prova di connessione",
|
||||
"testSuccess": "Prova del flusso riuscita!",
|
||||
"testFailed": "Prova del flusso fallita",
|
||||
"testFailedTitle": "Prova fallita",
|
||||
"connected": "Connesso",
|
||||
"notConnected": "Non connesso",
|
||||
"featuresTitle": "Caratteristiche",
|
||||
"go2rtc": "Riduci le connessioni alla telecamera",
|
||||
"detectRoleWarning": "Per procedere, almeno un flusso deve avere il ruolo \"rilevamento\".",
|
||||
"rolesPopover": {
|
||||
"title": "Ruoli del flusso",
|
||||
"detect": "Flusso principale per il rilevamento degli oggetti.",
|
||||
"record": "Salva segmenti del flusso video in base alle impostazioni di configurazione.",
|
||||
"audio": "Flusso per il rilevamento basato sull'audio."
|
||||
},
|
||||
"featuresPopover": {
|
||||
"title": "Caratteristiche del flusso",
|
||||
"description": "Utilizza la ritrasmissione go2rtc per ridurre le connessioni alla tua telecamera."
|
||||
}
|
||||
},
|
||||
"title": "Aggiungi telecamera",
|
||||
"description": "Per aggiungere una nuova telecamera alla tua installazione Frigate, segui i passaggi indicati di seguito.",
|
||||
"steps": {
|
||||
"nameAndConnection": "Nome e connessione",
|
||||
"streamConfiguration": "Configurazione flusso",
|
||||
"validationAndTesting": "Validazione e prova"
|
||||
"validationAndTesting": "Validazione e prova",
|
||||
"probeOrSnapshot": "Analisi o istantanea"
|
||||
},
|
||||
"save": {
|
||||
"success": "Nuova telecamera {{cameraName}} salvata correttamente.",
|
||||
@ -1035,11 +1077,11 @@
|
||||
"fps": "FPS"
|
||||
},
|
||||
"commonErrors": {
|
||||
"noUrl": "Si prega di fornire un URL di flusso valido",
|
||||
"noUrl": "Fornisci un URL di flusso valido",
|
||||
"testFailed": "Prova del flusso fallita: {{error}}"
|
||||
},
|
||||
"step1": {
|
||||
"description": "Inserisci i dettagli della tua telecamera e verifica la connessione.",
|
||||
"description": "Inserisci i dettagli della tua telecamera e scegli se analizzarla o selezionarne manualmente la marca.",
|
||||
"cameraName": "Nome telecamera",
|
||||
"cameraNamePlaceholder": "ad esempio, porta_anteriore o Panoramica cortile",
|
||||
"host": "Indirizzo sistema/IP",
|
||||
@ -1079,10 +1121,19 @@
|
||||
"testing": {
|
||||
"probingMetadata": "Analisi dei metadati della telecamera in corso...",
|
||||
"fetchingSnapshot": "Recupero istantanea della telecamera in corso..."
|
||||
}
|
||||
},
|
||||
"probeMode": "Analisi telecamera",
|
||||
"detectionMethodDescription": "Analizza la telecamera con ONVIF (se supportato) per trovare gli URL dei flussi video della telecamera oppure seleziona manualmente la marca della telecamera per utilizzare URL predefiniti. Per inserire un URL RTSP personalizzato, scegli il metodo manuale e seleziona \"Altro\".",
|
||||
"connectionSettings": "Impostazioni di connessione",
|
||||
"detectionMethod": "Metodo di rilevamento del flusso",
|
||||
"onvifPort": "Porta ONVIF",
|
||||
"manualMode": "Selezione manuale",
|
||||
"onvifPortDescription": "Per le telecamere che supportano ONVIF, in genere è 80 o 8080.",
|
||||
"useDigestAuth": "Utilizza l'autenticazione digest",
|
||||
"useDigestAuthDescription": "Utilizza l'autenticazione HTTP digest per ONVIF. Alcune telecamere potrebbero richiedere un nome utente e una password ONVIF dedicati, anziché l'utente amministratore classico."
|
||||
},
|
||||
"step2": {
|
||||
"description": "Configura i ruoli del flusso e aggiungi altri flussi per la tua telecamera.",
|
||||
"description": "Analizza la telecamera per individuare i flussi disponibili oppure configura le impostazioni manuali in base al metodo di rilevamento selezionato.",
|
||||
"streamsTitle": "Flussi della telecamera",
|
||||
"addStream": "Aggiungi flusso",
|
||||
"addAnotherStream": "Aggiungi un altro flusso",
|
||||
@ -1101,8 +1152,8 @@
|
||||
"audio": "Audio"
|
||||
},
|
||||
"testStream": "Prova connessione",
|
||||
"testSuccess": "Prova del flusso riuscita!",
|
||||
"testFailed": "Prova del flusso fallita",
|
||||
"testSuccess": "Prova di connessione riuscita!",
|
||||
"testFailed": "Prova di connessione fallita. Controlla i dati inseriti e riprova.",
|
||||
"testFailedTitle": "Prova fallita",
|
||||
"connected": "Connessa",
|
||||
"notConnected": "Non connessa",
|
||||
@ -1118,6 +1169,85 @@
|
||||
"featuresPopover": {
|
||||
"title": "Caratteristiche del flusso",
|
||||
"description": "Utilizza la ritrasmissione go2rtc per ridurre le connessioni alla tua telecamera."
|
||||
},
|
||||
"probeFailed": "Impossibile analizzare la telecamera: {{error}}",
|
||||
"probeSuccessful": "Analisi riuscita",
|
||||
"probeError": "Errore analisi",
|
||||
"probeNoSuccess": "Analisi non riuscita",
|
||||
"rtspCandidatesDescription": "I seguenti URL RTSP sono stati trovati dall'analisi della telecamera. Prova la connessione per visualizzare i metadati della trasmissione.",
|
||||
"streamDetails": "Dettagli del flusso",
|
||||
"probing": "Analisi telecamera in corso...",
|
||||
"retry": "Riprova",
|
||||
"testing": {
|
||||
"probingMetadata": "Analisi dei metadati della telecamera in corso...",
|
||||
"fetchingSnapshot": "Recupero dell'istantanea della telecamera in corso..."
|
||||
},
|
||||
"probingDevice": "Analisi del dispositivo in corso...",
|
||||
"deviceInfo": "Informazioni sul dispositivo",
|
||||
"manufacturer": "Produttore",
|
||||
"model": "Modello",
|
||||
"firmware": "Firmware",
|
||||
"profiles": "Profili",
|
||||
"ptzSupport": "Supporto PTZ",
|
||||
"autotrackingSupport": "Supporto per il tracciamento automatico",
|
||||
"presets": "Preimpostazioni",
|
||||
"rtspCandidates": "Candidati RTSP",
|
||||
"noRtspCandidates": "Nessun URL RTSP trovato dalla telecamera. Le credenziali potrebbero essere errate oppure la telecamera potrebbe non supportare ONVIF o il metodo utilizzato per recuperare gli URL RTSP. Torna indietro e inserisci manualmente l'URL RTSP.",
|
||||
"candidateStreamTitle": "Candidato {{number}}}}",
|
||||
"useCandidate": "Utilizza",
|
||||
"uriCopy": "Copia",
|
||||
"uriCopied": "URI copiato negli appunti",
|
||||
"testConnection": "Prova di connessione",
|
||||
"toggleUriView": "Fai clic per attivare/disattivare la visualizzazione completa dell'URI",
|
||||
"errors": {
|
||||
"hostRequired": "È richiesto il nome sistema/indirizzo IP"
|
||||
}
|
||||
},
|
||||
"step4": {
|
||||
"description": "Convalida e analisi finale prima di salvare la nuova telecamera. Collega ogni flusso prima di salvare.",
|
||||
"validationTitle": "Validazione del flusso",
|
||||
"connectAllStreams": "Connetti tutti i flussi",
|
||||
"reconnectionSuccess": "Riconnessione riuscita.",
|
||||
"reconnectionPartial": "Alcuni flussi non sono riusciti a riconnettersi.",
|
||||
"streamUnavailable": "Anteprima del flusso non disponibile",
|
||||
"reload": "Ricarica",
|
||||
"connecting": "Connessione in corso...",
|
||||
"streamTitle": "Flusso {{number}}",
|
||||
"valid": "Valida",
|
||||
"failed": "Fallito",
|
||||
"notTested": "Non verificato",
|
||||
"connectStream": "Connetti",
|
||||
"connectingStream": "Connessione in corso",
|
||||
"disconnectStream": "Disconnetti",
|
||||
"estimatedBandwidth": "Larghezza di banda stimata",
|
||||
"roles": "Ruoli",
|
||||
"ffmpegModule": "Utilizza la modalità di compatibilità del flusso",
|
||||
"ffmpegModuleDescription": "Se il flusso non si carica dopo diversi tentativi, prova ad abilitare questa opzione. Se abilitata, Frigate utilizzerà il modulo ffmpeg con go2rtc. Questo potrebbe garantire una migliore compatibilità con alcuni flussi di telecamere.",
|
||||
"none": "Nessuno",
|
||||
"error": "Errore",
|
||||
"streamValidated": "Flusso {{number}} convalidato con successo",
|
||||
"streamValidationFailed": "Convalida del flusso {{number}} non riuscita",
|
||||
"saveAndApply": "Salva nuova telecamera",
|
||||
"saveError": "Configurazione non valida. Controlla le impostazioni.",
|
||||
"issues": {
|
||||
"title": "Validazione del flusso",
|
||||
"videoCodecGood": "Il codec video è {{codec}}.",
|
||||
"audioCodecGood": "Il codec audio è {{codec}}.",
|
||||
"resolutionHigh": "Una risoluzione di {{resolution}} potrebbe causare un aumento dell'utilizzo delle risorse.",
|
||||
"resolutionLow": "Una risoluzione di {{resolution}} potrebbe essere troppo bassa per un rilevamento affidabile di oggetti di piccole dimensioni.",
|
||||
"noAudioWarning": "Nessun audio rilevato per questo flusso, le registrazioni non avranno audio.",
|
||||
"audioCodecRecordError": "Per supportare l'audio nelle registrazioni è necessario il codec audio AAC.",
|
||||
"audioCodecRequired": "Per supportare il rilevamento audio è necessario un flusso audio.",
|
||||
"restreamingWarning": "Riducendo le connessioni alla telecamera per il flusso di registrazione l'utilizzo della CPU potrebbe aumentare leggermente.",
|
||||
"brands": {
|
||||
"reolink-rtsp": "Reolink RTSP non è consigliato. Abilita HTTP nelle impostazioni del firmware della telecamera e riavvia la procedura guidata."
|
||||
},
|
||||
"dahua": {
|
||||
"substreamWarning": "Il sottoflusso 1 è bloccato a bassa risoluzione. Molte telecamere Dahua/Amcrest/EmpireTech supportano sottoflussi aggiuntivi che devono essere abilitati nelle impostazioni della telecamera. Si consiglia di controllare e utilizzare tali flussi, se disponibili."
|
||||
},
|
||||
"hikvision": {
|
||||
"substreamWarning": "Il sottoflusso 1 è bloccato a bassa risoluzione. Molte telecamere Hikvision supportano sottoflussi aggiuntivi che devono essere abilitati nelle impostazioni della telecamera. Si consiglia di controllare e utilizzare tali flussi, se disponibili."
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
@ -65,7 +65,12 @@
|
||||
"gpuUsage": "Utilizzo GPU",
|
||||
"gpuMemory": "Memoria GPU",
|
||||
"npuUsage": "Utilizzo NPU",
|
||||
"npuMemory": "Memoria NPU"
|
||||
"npuMemory": "Memoria NPU",
|
||||
"intelGpuWarning": {
|
||||
"title": "Avviso statistiche GPU Intel",
|
||||
"message": "Statistiche GPU non disponibili",
|
||||
"description": "Si tratta di un problema noto negli strumenti di reportistica delle statistiche GPU di Intel (intel_gpu_top), che si interrompe e restituisce ripetutamente un utilizzo della GPU pari a 0% anche nei casi in cui l'accelerazione hardware e il rilevamento degli oggetti funzionano correttamente sulla (i)GPU. Non si tratta di un problema di Frigate. È possibile riavviare il sistema per risolvere temporaneamente il problema e verificare che la GPU funzioni correttamente. Ciò non influisce sulle prestazioni."
|
||||
}
|
||||
},
|
||||
"detector": {
|
||||
"inferenceSpeed": "Velocità inferenza rilevatore",
|
||||
@ -94,16 +99,23 @@
|
||||
"yolov9_plate_detection_speed": "Velocità di rilevamento della targa con YOLOv9",
|
||||
"yolov9_plate_detection": "Rilevamento della targa con YOLOv9",
|
||||
"image_embedding": "Incorporamento di immagini",
|
||||
"text_embedding": "Incorporamento di testo"
|
||||
"text_embedding": "Incorporamento di testo",
|
||||
"review_description": "Descrizione della revisione",
|
||||
"review_description_speed": "Velocità della descrizione di revisione",
|
||||
"review_description_events_per_second": "Descrizione della revisione",
|
||||
"object_description": "Descrizione dell'oggetto",
|
||||
"object_description_speed": "Velocità della descrizione dell'oggetto",
|
||||
"object_description_events_per_second": "Descrizione dell'oggetto"
|
||||
},
|
||||
"title": "Miglioramenti",
|
||||
"infPerSecond": "Inferenze al secondo"
|
||||
"infPerSecond": "Inferenze al secondo",
|
||||
"averageInf": "Tempo medio di inferenza"
|
||||
},
|
||||
"cameras": {
|
||||
"info": {
|
||||
"fetching": "Recupero dati della telecamera",
|
||||
"streamDataFromFFPROBE": "I dati del flusso vengono ottenuti con <code>ffprobe</code>.",
|
||||
"cameraProbeInfo": "Informazioni flussi telecamera {{camera}}",
|
||||
"cameraProbeInfo": "Informazioni analisi telecamera {{camera}}",
|
||||
"stream": "Flusso {{idx}}",
|
||||
"video": "Video:",
|
||||
"codec": "Codec:",
|
||||
@ -113,7 +125,7 @@
|
||||
"audio": "Audio:",
|
||||
"error": "Errore: {{error}}",
|
||||
"tips": {
|
||||
"title": "Informazioni flussi telecamera"
|
||||
"title": "Informazioni analisi telecamera"
|
||||
},
|
||||
"aspectRatio": "rapporto d'aspetto"
|
||||
},
|
||||
|
||||
@ -28,11 +28,15 @@
|
||||
},
|
||||
"deleteDatasetImages": {
|
||||
"title": "Ištrinti Imties Nuotraukas",
|
||||
"desc": "Esate įsitikinę norite ištrinti {{count}} nautraukas iš {{dataset}}? Šis veiksmas negrįžtamas ir reikės iš naujo apmokinti modelį."
|
||||
"desc_one": "Esate įsitikinę norite ištrinti {{count}} nautraukas iš {{dataset}}? Šis veiksmas negrįžtamas ir reikės iš naujo apmokinti modelį.",
|
||||
"desc_few": "",
|
||||
"desc_other": ""
|
||||
},
|
||||
"deleteTrainImages": {
|
||||
"title": "Ištrinti Apmokymo Nuotraukas",
|
||||
"desc": "Ar esate įsitikinę, kad norite ištrinti {{count}} nuotraukas? Šis veiksmas negrįžtamas."
|
||||
"desc_one": "Ar esate įsitikinę, kad norite ištrinti {{count}} nuotraukas? Šis veiksmas negrįžtamas.",
|
||||
"desc_few": "",
|
||||
"desc_other": ""
|
||||
},
|
||||
"renameCategory": {
|
||||
"title": "Pervadinti Klasę",
|
||||
|
||||
1
web/public/locales/lv/audio.json
Normal file
1
web/public/locales/lv/audio.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/common.json
Normal file
1
web/public/locales/lv/common.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/components/auth.json
Normal file
1
web/public/locales/lv/components/auth.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/components/camera.json
Normal file
1
web/public/locales/lv/components/camera.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/components/dialog.json
Normal file
1
web/public/locales/lv/components/dialog.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/components/filter.json
Normal file
1
web/public/locales/lv/components/filter.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/components/icons.json
Normal file
1
web/public/locales/lv/components/icons.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/components/input.json
Normal file
1
web/public/locales/lv/components/input.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/components/player.json
Normal file
1
web/public/locales/lv/components/player.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/objects.json
Normal file
1
web/public/locales/lv/objects.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
1
web/public/locales/lv/views/classificationModel.json
Normal file
1
web/public/locales/lv/views/classificationModel.json
Normal file
@ -0,0 +1 @@
|
||||
{}
|
||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user