mirror of
https://github.com/blakeblackshear/frigate.git
synced 2025-12-06 05:24:11 +03:00
Compare commits
21 Commits
84105be5e9
...
4cbbb5d9dd
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
4cbbb5d9dd | ||
|
|
5be4b7c427 | ||
|
|
bdaad6b889 | ||
|
|
a406df037b | ||
|
|
549445a916 | ||
|
|
fd4934301d | ||
|
|
13a8f8c8ba | ||
|
|
4236a4218c | ||
|
|
487c1a56ba | ||
|
|
ed08e892f1 | ||
|
|
375a6580fd | ||
|
|
2a10a1ce80 | ||
|
|
3fa15cd67b | ||
|
|
fb2b937703 | ||
|
|
d97aebef17 | ||
|
|
c6646f4360 | ||
|
|
4ef293e81c | ||
|
|
ec326e8d6e | ||
|
|
23a13ce016 | ||
|
|
b15bb4c646 | ||
|
|
c136e5e8bd |
@ -111,3 +111,9 @@ review:
|
|||||||
## Review Reports
|
## Review Reports
|
||||||
|
|
||||||
Along with individual review item summaries, Generative AI provides the ability to request a report of a given time period. For example, you can get a daily report while on a vacation of any suspicious activity or other concerns that may require review.
|
Along with individual review item summaries, Generative AI provides the ability to request a report of a given time period. For example, you can get a daily report while on a vacation of any suspicious activity or other concerns that may require review.
|
||||||
|
|
||||||
|
### Requesting Reports Programmatically
|
||||||
|
|
||||||
|
Review reports can be requested via the [API](/integrations/api#review-summarization) by sending a POST request to `/api/review/summarize/start/{start_ts}/end/{end_ts}` with Unix timestamps.
|
||||||
|
|
||||||
|
For Home Assistant users, there is a built-in service (`frigate.generate_review_summary`) that makes it easy to request review reports as part of automations or scripts. This allows you to automatically generate daily summaries, vacation reports, or custom time period reports based on your specific needs.
|
||||||
|
|||||||
@ -107,7 +107,7 @@ Fine-tune the LPR feature using these optional parameters at the global level of
|
|||||||
|
|
||||||
### Normalization Rules
|
### Normalization Rules
|
||||||
|
|
||||||
- **`replace_rules`**: List of regex replacement rules to normalize detected plates. These rules are applied sequentially. Each rule must have a `pattern` (which can be a string or a regex, prepended by `r`) and `replacement` (a string, which also supports [backrefs](https://docs.python.org/3/library/re.html#re.sub) like `\1`). These rules are useful for dealing with common OCR issues like noise characters, separators, or confusions (e.g., 'O'→'0').
|
- **`replace_rules`**: List of regex replacement rules to normalize detected plates. These rules are applied sequentially and are applied _before_ the `format` regex, if specified. Each rule must have a `pattern` (which can be a string or a regex, prepended by `r`) and `replacement` (a string, which also supports [backrefs](https://docs.python.org/3/library/re.html#re.sub) like `\1`). These rules are useful for dealing with common OCR issues like noise characters, separators, or confusions (e.g., 'O'→'0').
|
||||||
|
|
||||||
These rules must be defined at the global level of your `lpr` config.
|
These rules must be defined at the global level of your `lpr` config.
|
||||||
|
|
||||||
|
|||||||
@ -164,12 +164,6 @@ A Tensorflow Lite is provided in the container at `/openvino-model/ssdlite_mobil
|
|||||||
<details>
|
<details>
|
||||||
<summary>YOLOv9 Setup & Config</summary>
|
<summary>YOLOv9 Setup & Config</summary>
|
||||||
|
|
||||||
:::warning
|
|
||||||
|
|
||||||
If you are using a Frigate+ YOLOv9 model, you should not define any of the below `model` parameters in your config except for `path`. See [the Frigate+ model docs](/plus/first_model#step-3-set-your-model-id-in-the-config) for more information on setting up your model.
|
|
||||||
|
|
||||||
:::
|
|
||||||
|
|
||||||
After placing the downloaded files for the tflite model and labels in your config folder, you can use the following configuration:
|
After placing the downloaded files for the tflite model and labels in your config folder, you can use the following configuration:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
@ -408,7 +402,7 @@ The YOLO detector has been designed to support YOLOv3, YOLOv4, YOLOv7, and YOLOv
|
|||||||
|
|
||||||
:::warning
|
:::warning
|
||||||
|
|
||||||
If you are using a Frigate+ YOLOv9 model, you should not define any of the below `model` parameters in your config except for `path`. See [the Frigate+ model docs](/plus/first_model#step-3-set-your-model-id-in-the-config) for more information on setting up your model.
|
If you are using a Frigate+ model, you should not define any of the below `model` parameters in your config except for `path`. See [the Frigate+ model docs](/plus/first_model#step-3-set-your-model-id-in-the-config) for more information on setting up your model.
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
@ -748,7 +742,7 @@ The YOLO detector has been designed to support YOLOv3, YOLOv4, YOLOv7, and YOLOv
|
|||||||
|
|
||||||
:::warning
|
:::warning
|
||||||
|
|
||||||
If you are using a Frigate+ YOLOv9 model, you should not define any of the below `model` parameters in your config except for `path`. See [the Frigate+ model docs](/plus/first_model#step-3-set-your-model-id-in-the-config) for more information on setting up your model.
|
If you are using a Frigate+ model, you should not define any of the below `model` parameters in your config except for `path`. See [the Frigate+ model docs](/plus/first_model#step-3-set-your-model-id-in-the-config) for more information on setting up your model.
|
||||||
|
|
||||||
:::
|
:::
|
||||||
|
|
||||||
|
|||||||
1135
docs/static/frigate-api.yaml
vendored
1135
docs/static/frigate-api.yaml
vendored
File diff suppressed because it is too large
Load Diff
@ -29,7 +29,6 @@ class EventsDescriptionBody(BaseModel):
|
|||||||
|
|
||||||
|
|
||||||
class EventsCreateBody(BaseModel):
|
class EventsCreateBody(BaseModel):
|
||||||
source_type: Optional[str] = "api"
|
|
||||||
sub_label: Optional[str] = None
|
sub_label: Optional[str] = None
|
||||||
score: Optional[float] = 0
|
score: Optional[float] = 0
|
||||||
duration: Optional[int] = 30
|
duration: Optional[int] = 30
|
||||||
|
|||||||
@ -346,7 +346,7 @@ def events(
|
|||||||
"/events/explore",
|
"/events/explore",
|
||||||
response_model=list[EventResponse],
|
response_model=list[EventResponse],
|
||||||
dependencies=[Depends(allow_any_authenticated())],
|
dependencies=[Depends(allow_any_authenticated())],
|
||||||
summary="Get summary of objects.",
|
summary="Get summary of objects",
|
||||||
description="""Gets a summary of objects from the database.
|
description="""Gets a summary of objects from the database.
|
||||||
Returns a list of objects with a max of `limit` objects for each label.
|
Returns a list of objects with a max of `limit` objects for each label.
|
||||||
""",
|
""",
|
||||||
@ -439,7 +439,7 @@ def events_explore(
|
|||||||
"/event_ids",
|
"/event_ids",
|
||||||
response_model=list[EventResponse],
|
response_model=list[EventResponse],
|
||||||
dependencies=[Depends(allow_any_authenticated())],
|
dependencies=[Depends(allow_any_authenticated())],
|
||||||
summary="Get events by ids.",
|
summary="Get events by ids",
|
||||||
description="""Gets events by a list of ids.
|
description="""Gets events by a list of ids.
|
||||||
Returns a list of events.
|
Returns a list of events.
|
||||||
""",
|
""",
|
||||||
@ -473,7 +473,7 @@ async def event_ids(ids: str, request: Request):
|
|||||||
@router.get(
|
@router.get(
|
||||||
"/events/search",
|
"/events/search",
|
||||||
dependencies=[Depends(allow_any_authenticated())],
|
dependencies=[Depends(allow_any_authenticated())],
|
||||||
summary="Search events.",
|
summary="Search events",
|
||||||
description="""Searches for events in the database.
|
description="""Searches for events in the database.
|
||||||
Returns a list of events.
|
Returns a list of events.
|
||||||
""",
|
""",
|
||||||
@ -924,7 +924,7 @@ def events_summary(
|
|||||||
"/events/{event_id}",
|
"/events/{event_id}",
|
||||||
response_model=EventResponse,
|
response_model=EventResponse,
|
||||||
dependencies=[Depends(allow_any_authenticated())],
|
dependencies=[Depends(allow_any_authenticated())],
|
||||||
summary="Get event by id.",
|
summary="Get event by id",
|
||||||
description="Gets an event by its id.",
|
description="Gets an event by its id.",
|
||||||
)
|
)
|
||||||
async def event(event_id: str, request: Request):
|
async def event(event_id: str, request: Request):
|
||||||
@ -968,7 +968,7 @@ def set_retain(event_id: str):
|
|||||||
"/events/{event_id}/plus",
|
"/events/{event_id}/plus",
|
||||||
response_model=EventUploadPlusResponse,
|
response_model=EventUploadPlusResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Send event to Frigate+.",
|
summary="Send event to Frigate+",
|
||||||
description="""Sends an event to Frigate+.
|
description="""Sends an event to Frigate+.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
""",
|
""",
|
||||||
@ -1207,7 +1207,7 @@ async def false_positive(request: Request, event_id: str):
|
|||||||
"/events/{event_id}/retain",
|
"/events/{event_id}/retain",
|
||||||
response_model=GenericResponse,
|
response_model=GenericResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Stop event from being retained indefinitely.",
|
summary="Stop event from being retained indefinitely",
|
||||||
description="""Stops an event from being retained indefinitely.
|
description="""Stops an event from being retained indefinitely.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
NOTE: This is a legacy endpoint and is not supported in the frontend.
|
NOTE: This is a legacy endpoint and is not supported in the frontend.
|
||||||
@ -1236,7 +1236,7 @@ async def delete_retain(event_id: str, request: Request):
|
|||||||
"/events/{event_id}/sub_label",
|
"/events/{event_id}/sub_label",
|
||||||
response_model=GenericResponse,
|
response_model=GenericResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Set event sub label.",
|
summary="Set event sub label",
|
||||||
description="""Sets an event's sub label.
|
description="""Sets an event's sub label.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
""",
|
""",
|
||||||
@ -1295,7 +1295,7 @@ async def set_sub_label(
|
|||||||
"/events/{event_id}/recognized_license_plate",
|
"/events/{event_id}/recognized_license_plate",
|
||||||
response_model=GenericResponse,
|
response_model=GenericResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Set event license plate.",
|
summary="Set event license plate",
|
||||||
description="""Sets an event's license plate.
|
description="""Sets an event's license plate.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
""",
|
""",
|
||||||
@ -1355,7 +1355,7 @@ async def set_plate(
|
|||||||
"/events/{event_id}/description",
|
"/events/{event_id}/description",
|
||||||
response_model=GenericResponse,
|
response_model=GenericResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Set event description.",
|
summary="Set event description",
|
||||||
description="""Sets an event's description.
|
description="""Sets an event's description.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
""",
|
""",
|
||||||
@ -1411,7 +1411,7 @@ async def set_description(
|
|||||||
"/events/{event_id}/description/regenerate",
|
"/events/{event_id}/description/regenerate",
|
||||||
response_model=GenericResponse,
|
response_model=GenericResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Regenerate event description.",
|
summary="Regenerate event description",
|
||||||
description="""Regenerates an event's description.
|
description="""Regenerates an event's description.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
""",
|
""",
|
||||||
@ -1463,8 +1463,8 @@ async def regenerate_description(
|
|||||||
@router.post(
|
@router.post(
|
||||||
"/description/generate",
|
"/description/generate",
|
||||||
response_model=GenericResponse,
|
response_model=GenericResponse,
|
||||||
# dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Generate description embedding.",
|
summary="Generate description embedding",
|
||||||
description="""Generates an embedding for an event's description.
|
description="""Generates an embedding for an event's description.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
""",
|
""",
|
||||||
@ -1529,7 +1529,7 @@ async def delete_single_event(event_id: str, request: Request) -> dict:
|
|||||||
"/events/{event_id}",
|
"/events/{event_id}",
|
||||||
response_model=GenericResponse,
|
response_model=GenericResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Delete event.",
|
summary="Delete event",
|
||||||
description="""Deletes an event from the database.
|
description="""Deletes an event from the database.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
""",
|
""",
|
||||||
@ -1544,7 +1544,7 @@ async def delete_event(request: Request, event_id: str):
|
|||||||
"/events/",
|
"/events/",
|
||||||
response_model=EventMultiDeleteResponse,
|
response_model=EventMultiDeleteResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Delete events.",
|
summary="Delete events",
|
||||||
description="""Deletes a list of events from the database.
|
description="""Deletes a list of events from the database.
|
||||||
Returns a success message or an error if the events are not found.
|
Returns a success message or an error if the events are not found.
|
||||||
""",
|
""",
|
||||||
@ -1578,7 +1578,7 @@ async def delete_events(request: Request, body: EventsDeleteBody):
|
|||||||
"/events/{camera_name}/{label}/create",
|
"/events/{camera_name}/{label}/create",
|
||||||
response_model=EventCreateResponse,
|
response_model=EventCreateResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Create manual event.",
|
summary="Create manual event",
|
||||||
description="""Creates a manual event in the database.
|
description="""Creates a manual event in the database.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
NOTES:
|
NOTES:
|
||||||
@ -1620,7 +1620,7 @@ def create_event(
|
|||||||
body.score,
|
body.score,
|
||||||
body.sub_label,
|
body.sub_label,
|
||||||
body.duration,
|
body.duration,
|
||||||
body.source_type,
|
"api",
|
||||||
body.draw,
|
body.draw,
|
||||||
),
|
),
|
||||||
EventMetadataTypeEnum.manual_event_create.value,
|
EventMetadataTypeEnum.manual_event_create.value,
|
||||||
@ -1642,7 +1642,7 @@ def create_event(
|
|||||||
"/events/{event_id}/end",
|
"/events/{event_id}/end",
|
||||||
response_model=GenericResponse,
|
response_model=GenericResponse,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="End manual event.",
|
summary="End manual event",
|
||||||
description="""Ends a manual event.
|
description="""Ends a manual event.
|
||||||
Returns a success message or an error if the event is not found.
|
Returns a success message or an error if the event is not found.
|
||||||
NOTE: This should only be used for manual events.
|
NOTE: This should only be used for manual events.
|
||||||
@ -1652,10 +1652,27 @@ async def end_event(request: Request, event_id: str, body: EventsEndBody):
|
|||||||
try:
|
try:
|
||||||
event: Event = Event.get(Event.id == event_id)
|
event: Event = Event.get(Event.id == event_id)
|
||||||
await require_camera_access(event.camera, request=request)
|
await require_camera_access(event.camera, request=request)
|
||||||
|
|
||||||
|
if body.end_time is not None and body.end_time < event.start_time:
|
||||||
|
return JSONResponse(
|
||||||
|
content=(
|
||||||
|
{
|
||||||
|
"success": False,
|
||||||
|
"message": f"end_time ({body.end_time}) cannot be before start_time ({event.start_time}).",
|
||||||
|
}
|
||||||
|
),
|
||||||
|
status_code=400,
|
||||||
|
)
|
||||||
|
|
||||||
end_time = body.end_time or datetime.datetime.now().timestamp()
|
end_time = body.end_time or datetime.datetime.now().timestamp()
|
||||||
request.app.event_metadata_updater.publish(
|
request.app.event_metadata_updater.publish(
|
||||||
(event_id, end_time), EventMetadataTypeEnum.manual_event_end.value
|
(event_id, end_time), EventMetadataTypeEnum.manual_event_end.value
|
||||||
)
|
)
|
||||||
|
except DoesNotExist:
|
||||||
|
return JSONResponse(
|
||||||
|
content=({"success": False, "message": f"Event {event_id} not found."}),
|
||||||
|
status_code=404,
|
||||||
|
)
|
||||||
except Exception:
|
except Exception:
|
||||||
return JSONResponse(
|
return JSONResponse(
|
||||||
content=(
|
content=(
|
||||||
@ -1674,7 +1691,7 @@ async def end_event(request: Request, event_id: str, body: EventsEndBody):
|
|||||||
"/trigger/embedding",
|
"/trigger/embedding",
|
||||||
response_model=dict,
|
response_model=dict,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Create trigger embedding.",
|
summary="Create trigger embedding",
|
||||||
description="""Creates a trigger embedding for a specific trigger.
|
description="""Creates a trigger embedding for a specific trigger.
|
||||||
Returns a success message or an error if the trigger is not found.
|
Returns a success message or an error if the trigger is not found.
|
||||||
""",
|
""",
|
||||||
@ -1832,7 +1849,7 @@ def create_trigger_embedding(
|
|||||||
"/trigger/embedding/{camera_name}/{name}",
|
"/trigger/embedding/{camera_name}/{name}",
|
||||||
response_model=dict,
|
response_model=dict,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Update trigger embedding.",
|
summary="Update trigger embedding",
|
||||||
description="""Updates a trigger embedding for a specific trigger.
|
description="""Updates a trigger embedding for a specific trigger.
|
||||||
Returns a success message or an error if the trigger is not found.
|
Returns a success message or an error if the trigger is not found.
|
||||||
""",
|
""",
|
||||||
@ -1997,7 +2014,7 @@ def update_trigger_embedding(
|
|||||||
"/trigger/embedding/{camera_name}/{name}",
|
"/trigger/embedding/{camera_name}/{name}",
|
||||||
response_model=dict,
|
response_model=dict,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Delete trigger embedding.",
|
summary="Delete trigger embedding",
|
||||||
description="""Deletes a trigger embedding for a specific trigger.
|
description="""Deletes a trigger embedding for a specific trigger.
|
||||||
Returns a success message or an error if the trigger is not found.
|
Returns a success message or an error if the trigger is not found.
|
||||||
""",
|
""",
|
||||||
@ -2071,7 +2088,7 @@ def delete_trigger_embedding(
|
|||||||
"/triggers/status/{camera_name}",
|
"/triggers/status/{camera_name}",
|
||||||
response_model=dict,
|
response_model=dict,
|
||||||
dependencies=[Depends(require_role(["admin"]))],
|
dependencies=[Depends(require_role(["admin"]))],
|
||||||
summary="Get triggers status.",
|
summary="Get triggers status",
|
||||||
description="""Gets the status of all triggers for a specific camera.
|
description="""Gets the status of all triggers for a specific camera.
|
||||||
Returns a success message or an error if the camera is not found.
|
Returns a success message or an error if the camera is not found.
|
||||||
""",
|
""",
|
||||||
|
|||||||
@ -209,10 +209,22 @@ class ReviewDescriptionProcessor(PostProcessorApi):
|
|||||||
logger.debug(
|
logger.debug(
|
||||||
f"Found GenAI Review Summary request for {start_ts} to {end_ts}"
|
f"Found GenAI Review Summary request for {start_ts} to {end_ts}"
|
||||||
)
|
)
|
||||||
items: list[dict[str, Any]] = [
|
|
||||||
r["data"]["metadata"]
|
# Query all review segments with camera and time information
|
||||||
|
segments: list[dict[str, Any]] = [
|
||||||
|
{
|
||||||
|
"camera": r["camera"].replace("_", " ").title(),
|
||||||
|
"start_time": r["start_time"],
|
||||||
|
"end_time": r["end_time"],
|
||||||
|
"metadata": r["data"]["metadata"],
|
||||||
|
}
|
||||||
for r in (
|
for r in (
|
||||||
ReviewSegment.select(ReviewSegment.data)
|
ReviewSegment.select(
|
||||||
|
ReviewSegment.camera,
|
||||||
|
ReviewSegment.start_time,
|
||||||
|
ReviewSegment.end_time,
|
||||||
|
ReviewSegment.data,
|
||||||
|
)
|
||||||
.where(
|
.where(
|
||||||
(ReviewSegment.data["metadata"].is_null(False))
|
(ReviewSegment.data["metadata"].is_null(False))
|
||||||
& (ReviewSegment.start_time < end_ts)
|
& (ReviewSegment.start_time < end_ts)
|
||||||
@ -224,21 +236,66 @@ class ReviewDescriptionProcessor(PostProcessorApi):
|
|||||||
)
|
)
|
||||||
]
|
]
|
||||||
|
|
||||||
if len(items) == 0:
|
if len(segments) == 0:
|
||||||
logger.debug("No review items with metadata found during time period")
|
logger.debug("No review items with metadata found during time period")
|
||||||
return "No activity was found during this time."
|
return "No activity was found during this time period."
|
||||||
|
|
||||||
important_items = list(
|
# Identify primary items (important items that need review)
|
||||||
filter(
|
primary_segments = [
|
||||||
lambda item: item.get("potential_threat_level", 0) > 0
|
seg
|
||||||
or item.get("other_concerns"),
|
for seg in segments
|
||||||
items,
|
if seg["metadata"].get("potential_threat_level", 0) > 0
|
||||||
)
|
or seg["metadata"].get("other_concerns")
|
||||||
)
|
]
|
||||||
|
|
||||||
if not important_items:
|
if not primary_segments:
|
||||||
return "No concerns were found during this time period."
|
return "No concerns were found during this time period."
|
||||||
|
|
||||||
|
# For each primary segment, find overlapping contextual items from other cameras
|
||||||
|
all_items_for_summary = []
|
||||||
|
|
||||||
|
for primary_seg in primary_segments:
|
||||||
|
# Add the primary item with marker
|
||||||
|
primary_item = copy.deepcopy(primary_seg["metadata"])
|
||||||
|
primary_item["_is_primary"] = True
|
||||||
|
primary_item["_camera"] = primary_seg["camera"]
|
||||||
|
all_items_for_summary.append(primary_item)
|
||||||
|
|
||||||
|
# Find overlapping contextual items from other cameras
|
||||||
|
primary_start = primary_seg["start_time"]
|
||||||
|
primary_end = primary_seg["end_time"]
|
||||||
|
primary_camera = primary_seg["camera"]
|
||||||
|
|
||||||
|
for seg in segments:
|
||||||
|
seg_camera = seg["camera"]
|
||||||
|
|
||||||
|
if seg_camera == primary_camera:
|
||||||
|
continue
|
||||||
|
|
||||||
|
if seg in primary_segments:
|
||||||
|
continue
|
||||||
|
|
||||||
|
seg_start = seg["start_time"]
|
||||||
|
seg_end = seg["end_time"]
|
||||||
|
|
||||||
|
if seg_start < primary_end and primary_start < seg_end:
|
||||||
|
contextual_item = copy.deepcopy(seg["metadata"])
|
||||||
|
contextual_item["_is_primary"] = False
|
||||||
|
contextual_item["_camera"] = seg_camera
|
||||||
|
contextual_item["_related_to_camera"] = primary_camera
|
||||||
|
|
||||||
|
if not any(
|
||||||
|
item.get("_camera") == seg_camera
|
||||||
|
and item.get("time") == contextual_item.get("time")
|
||||||
|
for item in all_items_for_summary
|
||||||
|
):
|
||||||
|
all_items_for_summary.append(contextual_item)
|
||||||
|
|
||||||
|
logger.debug(
|
||||||
|
f"Summary includes {len(primary_segments)} primary items and "
|
||||||
|
f"{len(all_items_for_summary) - len(primary_segments)} contextual items"
|
||||||
|
)
|
||||||
|
|
||||||
if self.config.review.genai.debug_save_thumbnails:
|
if self.config.review.genai.debug_save_thumbnails:
|
||||||
Path(
|
Path(
|
||||||
os.path.join(CLIPS_DIR, "genai-requests", f"{start_ts}-{end_ts}")
|
os.path.join(CLIPS_DIR, "genai-requests", f"{start_ts}-{end_ts}")
|
||||||
@ -247,7 +304,7 @@ class ReviewDescriptionProcessor(PostProcessorApi):
|
|||||||
return self.genai_client.generate_review_summary(
|
return self.genai_client.generate_review_summary(
|
||||||
start_ts,
|
start_ts,
|
||||||
end_ts,
|
end_ts,
|
||||||
important_items,
|
all_items_for_summary,
|
||||||
self.config.review.genai.debug_save_thumbnails,
|
self.config.review.genai.debug_save_thumbnails,
|
||||||
)
|
)
|
||||||
else:
|
else:
|
||||||
|
|||||||
@ -185,44 +185,66 @@ Each line represents a detection state, not necessarily unique individuals. Pare
|
|||||||
timeline_summary_prompt = f"""
|
timeline_summary_prompt = f"""
|
||||||
You are a security officer.
|
You are a security officer.
|
||||||
Time range: {time_range}.
|
Time range: {time_range}.
|
||||||
Input: JSON list with "title", "scene", "confidence", "potential_threat_level" (1-2), "other_concerns".
|
Input: JSON list with "title", "scene", "confidence", "potential_threat_level" (0-2), "other_concerns", "_is_primary", "_camera".
|
||||||
|
|
||||||
Task: Write a concise, human-presentable security report in markdown format.
|
Task: Write a concise, human-presentable security report in markdown format.
|
||||||
|
|
||||||
|
CRITICAL - Understanding Primary vs Contextual Items:
|
||||||
|
- Items with "_is_primary": true are events that REQUIRE REVIEW and MUST be included in the report
|
||||||
|
- Items with "_is_primary": false are additional context from other camera perspectives that overlap in time
|
||||||
|
- **DO NOT create separate bullet points or sections for contextual items**
|
||||||
|
- **ONLY use contextual items to enrich and inform the description of primary items**
|
||||||
|
- The "_camera" field indicates which camera captured each event
|
||||||
|
- **When a contextual item provides relevant background, you MUST incorporate it directly into the primary event's bullet point**
|
||||||
|
- Contextual information often explains or de-escalates seemingly suspicious primary events
|
||||||
|
|
||||||
Rules for the report:
|
Rules for the report:
|
||||||
|
|
||||||
- Title & overview
|
- Title & overview
|
||||||
- Start with:
|
- Start with:
|
||||||
# Security Summary - {time_range}
|
# Security Summary - {time_range}
|
||||||
- Write a 1-2 sentence situational overview capturing the general pattern of the period.
|
- Write a 1-2 sentence situational overview capturing the general pattern of the period.
|
||||||
|
- Keep the overview high-level; specific details will be in the event bullets below.
|
||||||
|
|
||||||
- Event details
|
- Event details
|
||||||
- Present events in chronological order as a bullet list.
|
- **ONLY create bullet points for PRIMARY items (_is_primary: true)**
|
||||||
- **If multiple events occur within the same minute or overlapping time range, COMBINE them into a single bullet.**
|
- **Do NOT create sections or bullets for events that don't exist**
|
||||||
- Summarize the distinct activities as sub-points under the shared timestamp.
|
- Do NOT create separate bullets for contextual items
|
||||||
- If no timestamp is given, preserve order but label as “Time not specified.”
|
- Present primary events in chronological order as a bullet list.
|
||||||
|
- **CRITICAL: When contextual items overlap with a primary event, you MUST weave that information directly into the same bullet point**
|
||||||
|
- Format: **[Timestamp]** - [Description incorporating any contextual information]. [Camera info]. (threat level: X)
|
||||||
|
- If contextual information provides an explanation (e.g., delivery truck → person is likely delivery driver), reflect this understanding in your description and potentially adjust the perceived threat level
|
||||||
|
- If multiple PRIMARY events occur within the same minute, combine them into a single bullet with sub-points.
|
||||||
- Use bold timestamps for clarity.
|
- Use bold timestamps for clarity.
|
||||||
- Group bullets under subheadings when multiple events fall into the same category (e.g., Vehicle Activity, Porch Activity, Unusual Behavior).
|
- Camera format: "Camera: [camera name]" or mention contextual cameras inline when relevant
|
||||||
|
- Group bullets under subheadings ONLY when you have actual PRIMARY events to list (e.g., Porch Activity, Unusual Behavior).
|
||||||
|
|
||||||
- Threat levels
|
- Threat levels
|
||||||
- Always show the threat level for each event using these labels:
|
- Show the threat level for PRIMARY events using these labels:
|
||||||
- Threat level 0: "Normal"
|
- Threat level 0: "Normal"
|
||||||
- Threat level 1: "Needs review"
|
- Threat level 1: "Needs review"
|
||||||
- Threat level 2: "Security concern"
|
- Threat level 2: "Security concern"
|
||||||
- Format as (threat level: Normal), (threat level: Needs review), or (threat level: Security concern).
|
- Format as (threat level: Normal), (threat level: Needs review), or (threat level: Security concern).
|
||||||
- If multiple events at the same time share the same threat level, only state it once.
|
- **When contextual items clearly explain a primary event (e.g., delivery truck explains person at door), you should describe it as normal activity and note the explanation**
|
||||||
|
- **Your description and tone should reflect the fuller understanding provided by contextual information**
|
||||||
|
- Example: Primary event says "unidentified person with face covering" but context shows delivery truck → describe as "delivery person (truck visible on Front Driveway Cam)" rather than emphasizing suspicious elements
|
||||||
|
- The stored threat level remains as originally classified, but your narrative should reflect the contextual understanding
|
||||||
|
- If multiple PRIMARY events at the same time share the same threat level, only state it once.
|
||||||
|
|
||||||
- Final assessment
|
- Final assessment
|
||||||
- End with a Final Assessment section.
|
- End with a Final Assessment section.
|
||||||
- If all events are threat level 0:
|
- If all primary events are threat level 0 or explained by contextual items:
|
||||||
Final assessment: Only normal residential activity observed during this period.
|
Final assessment: Only normal residential activity observed during this period.
|
||||||
- If threat level 1 events are present:
|
- If threat level 1 events are present:
|
||||||
Final assessment: Some activity requires review but no security concerns identified.
|
Final assessment: Some activity requires review but no security concerns identified.
|
||||||
- If threat level 2 events are present, clearly summarize them as Security concerns requiring immediate attention.
|
- If threat level 2 events are present, clearly summarize them as Security concerns requiring immediate attention.
|
||||||
|
- Keep this section brief - do not repeat details from the event descriptions above.
|
||||||
|
|
||||||
- Conciseness
|
- Conciseness
|
||||||
- Do not repeat benign clothing/appearance details unless they distinguish individuals.
|
- Do not repeat benign clothing/appearance details unless they distinguish individuals.
|
||||||
- Summarize similar routine events instead of restating full scene descriptions.
|
- Summarize similar routine events instead of restating full scene descriptions.
|
||||||
|
- When incorporating contextual information, do so briefly and naturally within the primary event description.
|
||||||
|
- Avoid lengthy explanatory notes - integrate context seamlessly into the narrative.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
for item in segments:
|
for item in segments:
|
||||||
|
|||||||
@ -1,5 +1,6 @@
|
|||||||
{
|
{
|
||||||
"form": {
|
"form": {
|
||||||
"user": "Потребителско име"
|
"user": "Потребителско име",
|
||||||
|
"password": "Парола"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -10,6 +10,7 @@
|
|||||||
"select": "Избери"
|
"select": "Избери"
|
||||||
},
|
},
|
||||||
"restart": {
|
"restart": {
|
||||||
"title": "Сигурен ли сте, че искате да рестартирате Frigate?"
|
"title": "Сигурен ли сте, че искате да рестартирате Frigate?",
|
||||||
|
"button": "Рестартирай"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,8 @@
|
|||||||
{
|
{
|
||||||
"iconPicker": {
|
"iconPicker": {
|
||||||
"selectIcon": "Изберете иконка"
|
"selectIcon": "Изберете иконка",
|
||||||
|
"search": {
|
||||||
|
"placeholder": "Потърси за икона…"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,7 +1,10 @@
|
|||||||
{
|
{
|
||||||
"button": {
|
"button": {
|
||||||
"downloadVideo": {
|
"downloadVideo": {
|
||||||
"label": "Свали видео"
|
"label": "Свали видео",
|
||||||
|
"toast": {
|
||||||
|
"success": "Вашето видео за преглеждане почна да се изтегля."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1 +1,3 @@
|
|||||||
{}
|
{
|
||||||
|
"documentTitle": "Модели за класификация"
|
||||||
|
}
|
||||||
|
|||||||
@ -1 +1,4 @@
|
|||||||
{}
|
{
|
||||||
|
"documentTitle": "Настройки на конфигурацията - Фригейт",
|
||||||
|
"configEditor": "Настройки на конфигурацията"
|
||||||
|
}
|
||||||
|
|||||||
@ -9,5 +9,7 @@
|
|||||||
"aria": "Избери събития",
|
"aria": "Избери събития",
|
||||||
"noFoundForTimePeriod": "Няма намерени събития за този времеви период."
|
"noFoundForTimePeriod": "Няма намерени събития за този времеви период."
|
||||||
},
|
},
|
||||||
"allCameras": "Всички камери"
|
"allCameras": "Всички камери",
|
||||||
|
"alerts": "Известия",
|
||||||
|
"detections": "Засичания"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -8,5 +8,7 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"trackedObjectsCount_one": "{{count}} проследен обект ",
|
"trackedObjectsCount_one": "{{count}} проследен обект ",
|
||||||
"trackedObjectsCount_other": "{{count}} проследени обекта "
|
"trackedObjectsCount_other": "{{count}} проследени обекта ",
|
||||||
|
"documentTitle": "Разгледай - Фригейт",
|
||||||
|
"generativeAI": "Генериращ Изкъствен Интелект"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,3 +1,4 @@
|
|||||||
{
|
{
|
||||||
"documentTitle": "Експорт - Frigate"
|
"documentTitle": "Експорт - Frigate",
|
||||||
|
"search": "Търси"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -10,5 +10,9 @@
|
|||||||
"deletedName_one": "{{count}} лице бе изтрито успешно.",
|
"deletedName_one": "{{count}} лице бе изтрито успешно.",
|
||||||
"deletedName_other": "{{count}} лица бяха изтрити успешно."
|
"deletedName_other": "{{count}} лица бяха изтрити успешно."
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"description": {
|
||||||
|
"addFace": "Добавете нова колекция във библиотеката за лица при качването на първата ви снимка.",
|
||||||
|
"placeholder": "Напишете име за тази колекция"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -64,5 +64,6 @@
|
|||||||
"cameraSettings": {
|
"cameraSettings": {
|
||||||
"cameraEnabled": "Камерата е включена"
|
"cameraEnabled": "Камерата е включена"
|
||||||
},
|
},
|
||||||
"documentTitle": "Наживо - Frigate"
|
"documentTitle": "Наживо - Frigate",
|
||||||
|
"documentTitle.withCamera": "{{camera}} - На живо - Фригейт"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,7 @@
|
|||||||
{
|
{
|
||||||
"button": {
|
"button": {
|
||||||
"save": "Запазване на търсенето"
|
"save": "Запазване на търсенето"
|
||||||
}
|
},
|
||||||
|
"search": "Търси",
|
||||||
|
"savedSearches": "Запазени търсения"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -12,5 +12,9 @@
|
|||||||
"point_one": "{{count}} точка",
|
"point_one": "{{count}} точка",
|
||||||
"point_other": "{{count}} точки"
|
"point_other": "{{count}} точки"
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"documentTitle": {
|
||||||
|
"default": "Настройки - Фригейт",
|
||||||
|
"authentication": "Настройки за сигурността - Фругейт"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -1,5 +1,9 @@
|
|||||||
{
|
{
|
||||||
"stats": {
|
"stats": {
|
||||||
"healthy": "Системата е изправна"
|
"healthy": "Системата е изправна"
|
||||||
|
},
|
||||||
|
"documentTitle": {
|
||||||
|
"cameras": "Статистики за Камери - Фригейт",
|
||||||
|
"storage": "Статистика за паметта - Фригейт"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -58,7 +58,8 @@
|
|||||||
"endTimeMustAfterStartTime": "L'hora de finalització ha de ser posterior a l'hora d'inici",
|
"endTimeMustAfterStartTime": "L'hora de finalització ha de ser posterior a l'hora d'inici",
|
||||||
"noVaildTimeSelected": "No s'ha seleccionat un rang de temps vàlid",
|
"noVaildTimeSelected": "No s'ha seleccionat un rang de temps vàlid",
|
||||||
"failed": "No s'ha pogut inciar l'exportació: {{error}}"
|
"failed": "No s'ha pogut inciar l'exportació: {{error}}"
|
||||||
}
|
},
|
||||||
|
"view": "Vista"
|
||||||
},
|
},
|
||||||
"fromTimeline": {
|
"fromTimeline": {
|
||||||
"saveExport": "Guardar exportació",
|
"saveExport": "Guardar exportació",
|
||||||
|
|||||||
@ -152,7 +152,12 @@
|
|||||||
"generateSuccess": "Imatges de mostra generades amb èxit",
|
"generateSuccess": "Imatges de mostra generades amb èxit",
|
||||||
"allImagesRequired_one": "Classifiqueu totes les imatges. Queda {{count}} imatge.",
|
"allImagesRequired_one": "Classifiqueu totes les imatges. Queda {{count}} imatge.",
|
||||||
"allImagesRequired_many": "Classifiqueu totes les imatges. Queden {{count}} imatges.",
|
"allImagesRequired_many": "Classifiqueu totes les imatges. Queden {{count}} imatges.",
|
||||||
"allImagesRequired_other": "Classifiqueu totes les imatges. Queden {{count}} imatges."
|
"allImagesRequired_other": "Classifiqueu totes les imatges. Queden {{count}} imatges.",
|
||||||
|
"modelCreated": "El model s'ha creat correctament. Utilitzeu la vista Classificacions recents per a afegir imatges per als estats que falten i, a continuació, entrenar el model.",
|
||||||
|
"missingStatesWarning": {
|
||||||
|
"title": "Falten exemples d'estat",
|
||||||
|
"description": "Es recomana seleccionar exemples per a tots els estats per obtenir els millors resultats. Podeu continuar sense seleccionar tots els estats, però el model no serà entrenat fins que tots els estats tinguin imatges. Després de continuar, utilitzeu la vista Classificacions recents per classificar imatges per als estats que falten, i després entrenar el model."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deleteModel": {
|
"deleteModel": {
|
||||||
|
|||||||
@ -55,5 +55,8 @@
|
|||||||
"trackedPoint": "Punt de seguiment"
|
"trackedPoint": "Punt de seguiment"
|
||||||
},
|
},
|
||||||
"zoomIn": "Amplia",
|
"zoomIn": "Amplia",
|
||||||
"zoomOut": "Redueix"
|
"zoomOut": "Redueix",
|
||||||
|
"normalActivity": "Normal",
|
||||||
|
"needsReview": "Necessita revisió",
|
||||||
|
"securityConcern": "Preocupació per la seguretat"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -220,6 +220,10 @@
|
|||||||
"viewTrackingDetails": {
|
"viewTrackingDetails": {
|
||||||
"label": "Veure detalls de seguiment",
|
"label": "Veure detalls de seguiment",
|
||||||
"aria": "Mostra els detalls de seguiment"
|
"aria": "Mostra els detalls de seguiment"
|
||||||
|
},
|
||||||
|
"downloadCleanSnapshot": {
|
||||||
|
"label": "Descarrega la instantània neta",
|
||||||
|
"aria": "Descarrega la instantània neta"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"noTrackedObjects": "No s'han trobat objectes rastrejats",
|
"noTrackedObjects": "No s'han trobat objectes rastrejats",
|
||||||
@ -263,7 +267,8 @@
|
|||||||
"header": {
|
"header": {
|
||||||
"zones": "Zones",
|
"zones": "Zones",
|
||||||
"ratio": "Ràtio",
|
"ratio": "Ràtio",
|
||||||
"area": "Àrea"
|
"area": "Àrea",
|
||||||
|
"score": "Puntuació"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"annotationSettings": {
|
"annotationSettings": {
|
||||||
|
|||||||
@ -172,7 +172,7 @@
|
|||||||
"name": {
|
"name": {
|
||||||
"inputPlaceHolder": "Introduïu un nom…",
|
"inputPlaceHolder": "Introduïu un nom…",
|
||||||
"title": "Nom",
|
"title": "Nom",
|
||||||
"tips": "El nom ha de tenir almenys 2 caràcters, ha de tenir almenys una lletra, i no ha de ser el nom d'una càmera o una altra zona."
|
"tips": "El nom ha de tenir almenys 2 caràcters, ha de tenir almenys una lletra, i no ha de ser el nom d'una càmera o una altra zona en aquesta càmera."
|
||||||
},
|
},
|
||||||
"label": "Zones",
|
"label": "Zones",
|
||||||
"desc": {
|
"desc": {
|
||||||
|
|||||||
@ -25,7 +25,10 @@
|
|||||||
"deletedModel_one": "Úspešne odstranený {{count}} model",
|
"deletedModel_one": "Úspešne odstranený {{count}} model",
|
||||||
"deletedModel_few": "Úspešne odstranené {{count}} modely",
|
"deletedModel_few": "Úspešne odstranené {{count}} modely",
|
||||||
"deletedModel_other": "Úspěšne ostranených {{count}} modelov",
|
"deletedModel_other": "Úspěšne ostranených {{count}} modelov",
|
||||||
"deletedCategory": "Zmazať triedu"
|
"deletedCategory": "Zmazať triedu",
|
||||||
|
"categorizedImage": "Obrázek úspěšně klasifikován",
|
||||||
|
"trainedModel": "Úspěšně vytrénovaný model.",
|
||||||
|
"trainingModel": "Trénování modelu bylo úspěšně zahájeno."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -41,6 +41,8 @@
|
|||||||
"zoomOut": "Oddálit",
|
"zoomOut": "Oddálit",
|
||||||
"detail": {
|
"detail": {
|
||||||
"label": "Detail",
|
"label": "Detail",
|
||||||
"noDataFound": "Žádná detailní data k prohlédnutí"
|
"noDataFound": "Žádná detailní data k prohlédnutí",
|
||||||
|
"aria": "Přepnout detailní zobrazení",
|
||||||
|
"trackedObject_other": "{{count}} objektů"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -36,7 +36,7 @@
|
|||||||
"desc": "Skutečně chcete vymazat kolekci {{name}}? Toto trvale vymaže všechny přiřazené obličeje."
|
"desc": "Skutečně chcete vymazat kolekci {{name}}? Toto trvale vymaže všechny přiřazené obličeje."
|
||||||
},
|
},
|
||||||
"train": {
|
"train": {
|
||||||
"title": "Trénovat",
|
"title": "Nedávná rozpoznání",
|
||||||
"empty": "Nejsou zde žádné předchozí pokusy o rozpoznání obličeje",
|
"empty": "Nejsou zde žádné předchozí pokusy o rozpoznání obličeje",
|
||||||
"aria": "Vybrat trénink"
|
"aria": "Vybrat trénink"
|
||||||
},
|
},
|
||||||
|
|||||||
@ -8,7 +8,7 @@
|
|||||||
"masksAndZones": "Editor masky a zón - Frigate",
|
"masksAndZones": "Editor masky a zón - Frigate",
|
||||||
"motionTuner": "Ladění detekce pohybu - Frigate",
|
"motionTuner": "Ladění detekce pohybu - Frigate",
|
||||||
"object": "Ladění - Frigate",
|
"object": "Ladění - Frigate",
|
||||||
"general": "Obecné nastavení - Frigate",
|
"general": "Nastavení rozhraní- Frigate",
|
||||||
"frigatePlus": "Frigate+ nastavení - Frigate",
|
"frigatePlus": "Frigate+ nastavení - Frigate",
|
||||||
"enrichments": "Nastavení obohacení - Frigate",
|
"enrichments": "Nastavení obohacení - Frigate",
|
||||||
"cameraManagement": "Správa kamer - Frigate",
|
"cameraManagement": "Správa kamer - Frigate",
|
||||||
@ -307,7 +307,9 @@
|
|||||||
"frigateplus": "Frigate+",
|
"frigateplus": "Frigate+",
|
||||||
"enrichments": "Obohacení",
|
"enrichments": "Obohacení",
|
||||||
"triggers": "Spouštěče",
|
"triggers": "Spouštěče",
|
||||||
"cameraManagement": "Správa"
|
"cameraManagement": "Správa",
|
||||||
|
"cameraReview": "Kontrola",
|
||||||
|
"roles": "Role"
|
||||||
},
|
},
|
||||||
"dialog": {
|
"dialog": {
|
||||||
"unsavedChanges": {
|
"unsavedChanges": {
|
||||||
|
|||||||
@ -15,5 +15,36 @@
|
|||||||
},
|
},
|
||||||
"count_one": "{{count}} Label",
|
"count_one": "{{count}} Label",
|
||||||
"label": "Etiketter"
|
"label": "Etiketter"
|
||||||
|
},
|
||||||
|
"zones": {
|
||||||
|
"label": "Zoner",
|
||||||
|
"all": {
|
||||||
|
"title": "Alle zoner",
|
||||||
|
"short": "Zoner"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"more": "Flere filtre",
|
||||||
|
"sort": {
|
||||||
|
"label": "Sortér",
|
||||||
|
"dateAsc": "Dato (Stigende)",
|
||||||
|
"dateDesc": "Dato (Faldende)",
|
||||||
|
"speedAsc": "Anslået hastighed (Stigende)",
|
||||||
|
"speedDesc": "Anslået hastighed (Faldende)",
|
||||||
|
"relevance": "Relevans"
|
||||||
|
},
|
||||||
|
"dates": {
|
||||||
|
"selectPreset": "Vælg en forudindstilling…",
|
||||||
|
"all": {
|
||||||
|
"title": "Alle datoer",
|
||||||
|
"short": "Datoer"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"reset": {
|
||||||
|
"label": "Nulstille filtre til standardværdier"
|
||||||
|
},
|
||||||
|
"timeRange": "Tidsinterval",
|
||||||
|
"estimatedSpeed": "Anslået hastighed ({{unit}})",
|
||||||
|
"features": {
|
||||||
|
"hasVideoClip": "Har et videoklip"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -296,7 +296,7 @@
|
|||||||
"doorbell": "Türklingel",
|
"doorbell": "Türklingel",
|
||||||
"ding-dong": "BimBam",
|
"ding-dong": "BimBam",
|
||||||
"sliding_door": "Schiebetür",
|
"sliding_door": "Schiebetür",
|
||||||
"slam": "Knall",
|
"slam": "zuknallen",
|
||||||
"knock": "Klopfen",
|
"knock": "Klopfen",
|
||||||
"tap": "Schlag",
|
"tap": "Schlag",
|
||||||
"squeak": "Quietschen",
|
"squeak": "Quietschen",
|
||||||
@ -355,7 +355,7 @@
|
|||||||
"shatter": "Zerspringen",
|
"shatter": "Zerspringen",
|
||||||
"silence": "Stille",
|
"silence": "Stille",
|
||||||
"environmental_noise": "Umgebungsgeräusch",
|
"environmental_noise": "Umgebungsgeräusch",
|
||||||
"static": "Rauschen",
|
"static": "Statisch",
|
||||||
"pink_noise": "Rosa Rauschen",
|
"pink_noise": "Rosa Rauschen",
|
||||||
"television": "Fernsehgerät",
|
"television": "Fernsehgerät",
|
||||||
"radio": "Radio",
|
"radio": "Radio",
|
||||||
@ -441,5 +441,63 @@
|
|||||||
"arrow": "Pfeil",
|
"arrow": "Pfeil",
|
||||||
"electronic_tuner": "Elektronischer Tuner",
|
"electronic_tuner": "Elektronischer Tuner",
|
||||||
"effects_unit": "Effekteinheit",
|
"effects_unit": "Effekteinheit",
|
||||||
"chorus_effect": "Chorus-Effekt"
|
"chorus_effect": "Chorus-Effekt",
|
||||||
|
"sodeling": "Verfilzen",
|
||||||
|
"chird": "Akkord",
|
||||||
|
"change_ringing": "Wechsle RingRing",
|
||||||
|
"shofar": "Schofar",
|
||||||
|
"gush": "sprudeln",
|
||||||
|
"sonar": "Sonar",
|
||||||
|
"whoosh": "Rauschen",
|
||||||
|
"thump": "Ruck",
|
||||||
|
"basketball_bounce": "Basketball Abbraller",
|
||||||
|
"bang": "Knall",
|
||||||
|
"slap": "Ohrfeige",
|
||||||
|
"whack": "verhauen",
|
||||||
|
"smash": "zerschlagen",
|
||||||
|
"breaking": "zerbrechen",
|
||||||
|
"bouncing": "Abbraller",
|
||||||
|
"whip": "Peitsche",
|
||||||
|
"flap": "Lasche",
|
||||||
|
"scratch": "Kratzer",
|
||||||
|
"scrape": "Abfall",
|
||||||
|
"rub": "scheuern",
|
||||||
|
"roll": "rollen",
|
||||||
|
"crushing": "Stauchen",
|
||||||
|
"crumpling": "zerknüllen",
|
||||||
|
"tearing": "Reißen",
|
||||||
|
"beep": "Piep",
|
||||||
|
"ping": "Ping",
|
||||||
|
"ding": "klingeln",
|
||||||
|
"thunk": "dumpfes Geräusch",
|
||||||
|
"clang": "Geklirr",
|
||||||
|
"squeal": "Ausruf",
|
||||||
|
"creak": "Knarren",
|
||||||
|
"rustle": "Geknister",
|
||||||
|
"whir": "schwirren",
|
||||||
|
"clatter": "Geratter",
|
||||||
|
"sizzle": "brutzeln",
|
||||||
|
"clicking": "Klicken",
|
||||||
|
"clickety_clack": "Klappergeräuschen",
|
||||||
|
"rumble": "Grollen",
|
||||||
|
"plop": "plumpsen",
|
||||||
|
"hum": "Brummen",
|
||||||
|
"zing": "Schwung",
|
||||||
|
"boing": "ferderndes Geräusch",
|
||||||
|
"crunch": "knirschendes",
|
||||||
|
"sine_wave": "Sinus Kurve",
|
||||||
|
"harmonic": "harmonisch",
|
||||||
|
"chirp_tone": "Frequenzwobbelung",
|
||||||
|
"pulse": "Takt",
|
||||||
|
"inside": "drinnen",
|
||||||
|
"outside": "draußen",
|
||||||
|
"reverberation": "Widerhall",
|
||||||
|
"echo": "Echo",
|
||||||
|
"noise": "Lärm",
|
||||||
|
"mains_hum": "Netzbrummen",
|
||||||
|
"distortion": "Verzerrung",
|
||||||
|
"sidetone": "Nebengeräusch",
|
||||||
|
"cacophony": "Dissonanz",
|
||||||
|
"throbbing": "Pochen",
|
||||||
|
"vibration": "Vibration"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -81,7 +81,10 @@
|
|||||||
"formattedTimestampMonthDayYear": {
|
"formattedTimestampMonthDayYear": {
|
||||||
"12hour": "d. MMM yyyy",
|
"12hour": "d. MMM yyyy",
|
||||||
"24hour": "d. MMM yyyy"
|
"24hour": "d. MMM yyyy"
|
||||||
}
|
},
|
||||||
|
"inProgress": "In Bearbeitung",
|
||||||
|
"invalidStartTime": "Ungültige Startzeit",
|
||||||
|
"invalidEndTime": "Ungültige Endzeit"
|
||||||
},
|
},
|
||||||
"button": {
|
"button": {
|
||||||
"save": "Speichern",
|
"save": "Speichern",
|
||||||
@ -118,7 +121,8 @@
|
|||||||
"pictureInPicture": "Bild in Bild",
|
"pictureInPicture": "Bild in Bild",
|
||||||
"on": "AN",
|
"on": "AN",
|
||||||
"suspended": "Pausierte",
|
"suspended": "Pausierte",
|
||||||
"unsuspended": "fortsetzen"
|
"unsuspended": "fortsetzen",
|
||||||
|
"continue": "Weiter"
|
||||||
},
|
},
|
||||||
"label": {
|
"label": {
|
||||||
"back": "Zurück",
|
"back": "Zurück",
|
||||||
@ -227,7 +231,8 @@
|
|||||||
"logout": "Abmelden"
|
"logout": "Abmelden"
|
||||||
},
|
},
|
||||||
"uiPlayground": "Testgebiet für Benutzeroberfläche",
|
"uiPlayground": "Testgebiet für Benutzeroberfläche",
|
||||||
"export": "Exportieren"
|
"export": "Exportieren",
|
||||||
|
"classification": "Klassifizierung"
|
||||||
},
|
},
|
||||||
"unit": {
|
"unit": {
|
||||||
"speed": {
|
"speed": {
|
||||||
|
|||||||
@ -11,6 +11,6 @@
|
|||||||
},
|
},
|
||||||
"user": "Benutzername",
|
"user": "Benutzername",
|
||||||
"password": "Kennwort",
|
"password": "Kennwort",
|
||||||
"firstTimeLogin": "Versuchen Sie sich zum ersten Mal anzumelden? Die Anmeldedaten sind in den Frigate-Logs aufgeführt."
|
"firstTimeLogin": "Ist dies der erste Loginversuch? Die Zugangsdaten werden in den Frigate Logs angezeigt."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -66,7 +66,8 @@
|
|||||||
"failed": "Fehler beim Starten des Exports: {{error}}",
|
"failed": "Fehler beim Starten des Exports: {{error}}",
|
||||||
"noVaildTimeSelected": "Kein gültiger Zeitraum ausgewählt"
|
"noVaildTimeSelected": "Kein gültiger Zeitraum ausgewählt"
|
||||||
},
|
},
|
||||||
"success": "Export erfolgreich gestartet. Die Datei befindet sich auf der Exportseite."
|
"success": "Export erfolgreich gestartet. Die Datei befindet sich auf der Exportseite.",
|
||||||
|
"view": "Ansicht"
|
||||||
},
|
},
|
||||||
"fromTimeline": {
|
"fromTimeline": {
|
||||||
"saveExport": "Export speichern",
|
"saveExport": "Export speichern",
|
||||||
|
|||||||
@ -1,10 +1,10 @@
|
|||||||
{
|
{
|
||||||
"documentTitle": "Klassifizierungsmodelle",
|
"documentTitle": "Klassifikationsmodelle",
|
||||||
"details": {
|
"details": {
|
||||||
"scoreInfo": "Die Punktzahl gibt die durchschnittliche Klassifizierungssicherheit aller Erkennungen dieses Objekts wieder."
|
"scoreInfo": "Die Punktzahl gibt die durchschnittliche Konfidenz aller Erkennungen dieses Objekts wieder."
|
||||||
},
|
},
|
||||||
"button": {
|
"button": {
|
||||||
"deleteClassificationAttempts": "Lösche Klassifizierungs-Bilder",
|
"deleteClassificationAttempts": "Lösche klassifizierte Bilder",
|
||||||
"renameCategory": "Klasse umbenennen",
|
"renameCategory": "Klasse umbenennen",
|
||||||
"deleteCategory": "Klasse löschen",
|
"deleteCategory": "Klasse löschen",
|
||||||
"deleteImages": "Bilder löschen",
|
"deleteImages": "Bilder löschen",
|
||||||
@ -17,15 +17,15 @@
|
|||||||
"trainingInProgress": "Modell wird gerade trainiert",
|
"trainingInProgress": "Modell wird gerade trainiert",
|
||||||
"noNewImages": "Keine weiteren Bilder zum trainieren. Bitte klassifiziere weitere Bilder im Datensatz.",
|
"noNewImages": "Keine weiteren Bilder zum trainieren. Bitte klassifiziere weitere Bilder im Datensatz.",
|
||||||
"noChanges": "Keine Veränderungen des Datensatzes seit dem letzten Training.",
|
"noChanges": "Keine Veränderungen des Datensatzes seit dem letzten Training.",
|
||||||
"modelNotReady": "Modell ist nicht bereit trainiert zu werden."
|
"modelNotReady": "Modell ist nicht bereit zum Training"
|
||||||
},
|
},
|
||||||
"toast": {
|
"toast": {
|
||||||
"success": {
|
"success": {
|
||||||
"deletedCategory": "Klasse gelöscht",
|
"deletedCategory": "Klasse gelöscht",
|
||||||
"deletedImage": "Gelöschte Bilder",
|
"deletedImage": "Bilder gelöscht",
|
||||||
"deletedModel_one": "{{count}} Model erfolgreich gelöscht",
|
"deletedModel_one": "{{count}} Modell erfolgreich gelöscht",
|
||||||
"deletedModel_other": "{{count}} Modelle erfolgreich gelöscht",
|
"deletedModel_other": "{{count}} Modelle erfolgreich gelöscht",
|
||||||
"categorizedImage": "Bild erfolgreich klassifiziert",
|
"categorizedImage": "Erfolgreich klassifizierte Bilder",
|
||||||
"trainedModel": "Modell erfolgreich trainiert.",
|
"trainedModel": "Modell erfolgreich trainiert.",
|
||||||
"trainingModel": "Modelltraining erfolgreich gestartet.",
|
"trainingModel": "Modelltraining erfolgreich gestartet.",
|
||||||
"updatedModel": "Modellkonfiguration erfolgreich aktualisiert",
|
"updatedModel": "Modellkonfiguration erfolgreich aktualisiert",
|
||||||
@ -33,8 +33,152 @@
|
|||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"deleteImageFailed": "Löschen fehlgeschlagen: {{errorMessage}}",
|
"deleteImageFailed": "Löschen fehlgeschlagen: {{errorMessage}}",
|
||||||
"deleteCategoryFailed": "Klasse konnte nicht gelöscht werden: {{errorMessage}}",
|
"deleteCategoryFailed": "Löschen der Klasse fehlgeschlagen: {{errorMessage}}",
|
||||||
"deleteModelFailed": "Model konnte nicht gelöscht werden: {{errorMessage}}"
|
"deleteModelFailed": "Model konnte nicht gelöscht werden: {{errorMessage}}",
|
||||||
|
"trainingFailedToStart": "Modelltraining konnte nicht gestartet werden: {{errorMessage}}",
|
||||||
|
"updateModelFailed": "Aktualisierung des Modells fehlgeschlagen: {{errorMessage}}",
|
||||||
|
"renameCategoryFailed": "Umbenennung der Klasse fehlgeschlagen: {{errorMessage}}",
|
||||||
|
"categorizeFailed": "Bildkategorisierung fehlgeschlagen: {{errorMessage}}",
|
||||||
|
"trainingFailed": "Modelltraining fehlgeschlagen. Details sind in den Frigate-Protokollen zu finden."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"deleteCategory": {
|
||||||
|
"title": "Klasse löschen",
|
||||||
|
"desc": "Möchten Sie die Klasse {{name}} wirklich löschen? Dadurch werden alle zugehörigen Bilder dauerhaft gelöscht und das Modell muss neu trainiert werden.",
|
||||||
|
"minClassesTitle": "Klasse kann nicht gelöscht werden",
|
||||||
|
"minClassesDesc": "Ein Klassifizierungsmodell benötigt mindestens zwei Klassen. Fügen Sie eine weitere Klasse hinzu, bevor Sie diese löschen."
|
||||||
|
},
|
||||||
|
"deleteModel": {
|
||||||
|
"title": "Klassifizierungsmodell löschen",
|
||||||
|
"single": "Möchten Sie {{name}} wirklich löschen? Dadurch werden alle zugehörigen Daten, einschließlich Bilder und Trainingsdaten, dauerhaft gelöscht. Diese Aktion kann nicht rückgängig gemacht werden.",
|
||||||
|
"desc_one": "Möchtest du {{count}} Modell wirklich löschen? Dadurch werden alle zugehörigen Daten, einschließlich Bilder und Trainingsdaten, dauerhaft gelöscht. Diese Aktion kann nicht rückgängig gemacht werden.",
|
||||||
|
"desc_other": "Möchtest du {{count}} Modelle wirklich löschen? Dadurch werden alle zugehörigen Daten, einschließlich Bilder und Trainingsdaten, dauerhaft gelöscht. Diese Aktion kann nicht rückgängig gemacht werden."
|
||||||
|
},
|
||||||
|
"edit": {
|
||||||
|
"title": "Klassifikationsmodell bearbeiten",
|
||||||
|
"descriptionState": "Bearbeite die Klassen für dieses Zustandsklassifikationsmodell. Änderungen erfordern erneutes Trainieren des Modells.",
|
||||||
|
"descriptionObject": "Bearbeite den Objekttyp und Klassifizierungstyp für dieses Objektklassifikationsmodell.",
|
||||||
|
"stateClassesInfo": "Hinweis: Die Änderung der Statusklassen erfordert ein erneutes Trainieren des Modells mit den aktualisierten Klassen."
|
||||||
|
},
|
||||||
|
"deleteDatasetImages": {
|
||||||
|
"title": "Datensatz Bilder löschen",
|
||||||
|
"desc_one": "Bist du sicher, dass {{count}} Bild von {{dataset}} gelöscht werden sollen? Diese Aktion kann nicht rückgängig gemacht werden und erfordert ein erneutes Trainieren des Modells.",
|
||||||
|
"desc_other": "Bist du sicher, dass {{count}} Bilder von {{dataset}} gelöscht werden sollen? Diese Aktion kann nicht rückgängig gemacht werden und erfordert ein erneutes Trainieren des Modells."
|
||||||
|
},
|
||||||
|
"deleteTrainImages": {
|
||||||
|
"title": "Trainingsbilder löschen",
|
||||||
|
"desc_one": "Bist du sicher, dass du {{count}} Bild löschen möchten? Diese Aktion kann nicht rückgängig gemacht werden.",
|
||||||
|
"desc_other": "Bist du sicher, dass du {{count}} Bilder löschen möchten? Diese Aktion kann nicht rückgängig gemacht werden."
|
||||||
|
},
|
||||||
|
"renameCategory": {
|
||||||
|
"title": "Klasse umbenennen",
|
||||||
|
"desc": "Neuen Namen für {{name}} eingeben. Das Modell muss neu trainiert werden, damit die Änderungen wirksam werden."
|
||||||
|
},
|
||||||
|
"description": {
|
||||||
|
"invalidName": "Ungültiger Name. Namen dürfen nur Buchstaben, Zahlen, Leerzeichen, Apostrophe, Unterstriche und Bindestriche enthalten."
|
||||||
|
},
|
||||||
|
"train": {
|
||||||
|
"title": "Neue Klassifizierungen",
|
||||||
|
"titleShort": "kürzlich",
|
||||||
|
"aria": "Neue Klassifizierungen auswählen"
|
||||||
|
},
|
||||||
|
"categories": "Klassen",
|
||||||
|
"createCategory": {
|
||||||
|
"new": "Neue Klasse erstellen"
|
||||||
|
},
|
||||||
|
"categorizeImageAs": "Bild klassifizieren als:",
|
||||||
|
"categorizeImage": "Bild klassifizieren",
|
||||||
|
"menu": {
|
||||||
|
"objects": "Objekte",
|
||||||
|
"states": "Zustände"
|
||||||
|
},
|
||||||
|
"noModels": {
|
||||||
|
"object": {
|
||||||
|
"title": "Keine Objektklassifikationsmodelle",
|
||||||
|
"description": "Erstelle ein benutzerdefiniertes Modell, um erkannte Objekte zu klassifizieren.",
|
||||||
|
"buttonText": "Objektmodell erstellen"
|
||||||
|
},
|
||||||
|
"state": {
|
||||||
|
"title": "Keine Statusklassifizierungsmodelle",
|
||||||
|
"description": "Erstellen Sie ein benutzerdefiniertes Modell, um Zustandsänderungen in bestimmten Kamerabereichen zu überwachen und zu klassifizieren.",
|
||||||
|
"buttonText": "Zustandsmodell erstellen"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"wizard": {
|
||||||
|
"title": "Neue Klassifizierung erstellen",
|
||||||
|
"steps": {
|
||||||
|
"nameAndDefine": "Benennen und definieren",
|
||||||
|
"stateArea": "Gebiet",
|
||||||
|
"chooseExamples": "Beispiel auswählen"
|
||||||
|
},
|
||||||
|
"step1": {
|
||||||
|
"description": "Zustandsmodelle überwachen feste Kamerabereiche auf Veränderungen (z. B. Tür offen/geschlossen). Objektmodelle fügen den erkannten Objekten Klassifizierungen hinzu (z. B. bekannte Tiere, Lieferanten usw.).",
|
||||||
|
"name": "Name",
|
||||||
|
"namePlaceholder": "Eingeben Modell Name...",
|
||||||
|
"type": "Typ",
|
||||||
|
"typeState": "Zustand",
|
||||||
|
"typeObject": "Objekt",
|
||||||
|
"objectLabel": "Objekt Bezeichnung",
|
||||||
|
"objectLabelPlaceholder": "Auswahl Objekt Typ...",
|
||||||
|
"classificationType": "Klassifizierungstyp",
|
||||||
|
"classificationTypeTip": "Etwas über Klassifizierungstyp lernen",
|
||||||
|
"classificationTypeDesc": "Unterbezeichnungen fügen dem Objektnamen zusätzlichen Text hinzu (z. B. „Person: UPS“). Attribute sind durchsuchbare Metadaten, die separat in den Objektmetadaten gespeichert sind.",
|
||||||
|
"classificationSubLabel": "Unterlabel",
|
||||||
|
"classificationAttribute": "Merkmal",
|
||||||
|
"classes": "Klasse",
|
||||||
|
"states": "Gebiet",
|
||||||
|
"classesTip": "Über Klassen lernen",
|
||||||
|
"classesStateDesc": "Definieren Sie die verschiedenen Zustände, in denen sich Ihr Kamerabereich befinden kann. Beispiel: „offen” und „geschlossen” für ein Garagentor.",
|
||||||
|
"classesObjectDesc": "Definieren Sie die verschiedenen Kategorien, in die erkannte Objekte klassifiziert werden sollen. Beispiel: „Lieferant“, „Bewohner“, „Fremder“ für die Klassifizierung von Personen.",
|
||||||
|
"classPlaceholder": "Eingabe Klassenbezeichnung...",
|
||||||
|
"errors": {
|
||||||
|
"nameRequired": "Modellname ist erforderlich",
|
||||||
|
"nameLength": "Der Modellname darf maximal 64 Zeichen lang sein",
|
||||||
|
"nameOnlyNumbers": "Der Modellname darf nicht nur aus Zahlen bestehen",
|
||||||
|
"classRequired": "Mindestens eine Klasse ist erforderlich",
|
||||||
|
"classesUnique": "Klassenname muss eindeutig sein",
|
||||||
|
"stateRequiresTwoClasses": "Gebietsmodelle erfordern mindestens zwei Klassen",
|
||||||
|
"objectLabelRequired": "Bitte wähle eine Objektbeschriftung",
|
||||||
|
"objectTypeRequired": "Bitte wählen Sie einen Klassifizierungstyp aus"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"step2": {
|
||||||
|
"description": "Wählen Sie Kameras aus und legen Sie für jede Kamera den zu überwachenden Bereich fest. Das Modell klassifiziert den Zustand dieser Bereiche.",
|
||||||
|
"cameras": "Kameras",
|
||||||
|
"selectCamera": "Kamera auswählen",
|
||||||
|
"noCameras": "Klick + zum hinzufügen der Kameras",
|
||||||
|
"selectCameraPrompt": "Wählen Sie eine Kamera aus der Liste aus, um ihren Überwachungsbereich festzulegen"
|
||||||
|
},
|
||||||
|
"step3": {
|
||||||
|
"selectImagesPrompt": "Wählen sie alle Bilder mit: {{className}}",
|
||||||
|
"selectImagesDescription": "Klicken Sie auf die Bilder, um sie auszuwählen. Klicken Sie auf „Weiter“, wenn Sie mit diesem Kurs fertig sind.",
|
||||||
|
"allImagesRequired_one": "Bitte klassifizieren Sie alle Bilder. {{count}} Bild verbleibend.",
|
||||||
|
"allImagesRequired_other": "Bitte klassifizieren Sie alle Bilder. {{count}} Bilder verbleiben.",
|
||||||
|
"generating": {
|
||||||
|
"title": "Beispielbilder generieren",
|
||||||
|
"description": "Frigate extrahiert repräsentative Bilder aus Ihren Aufnahmen. Dies kann einen Moment dauern..."
|
||||||
|
},
|
||||||
|
"training": {
|
||||||
|
"title": "Trainingsmodell",
|
||||||
|
"description": "Ihr Modell wird im Hintergrund trainiert. Schließen Sie diesen Dialog, und Ihr Modell wird ausgeführt, sobald das Training abgeschlossen ist."
|
||||||
|
},
|
||||||
|
"retryGenerate": "Generierung wiederholen",
|
||||||
|
"noImages": "Keine Bilder generiert",
|
||||||
|
"classifying": "Klassifizieren und Trainieren...",
|
||||||
|
"trainingStarted": "Training wurde erfolgreich gestartet",
|
||||||
|
"errors": {
|
||||||
|
"noCameras": "Keine Kameras konfiguriert",
|
||||||
|
"noObjectLabel": "Kein Objektlabel ausgewählt",
|
||||||
|
"generateFailed": "Beispiele konnten nicht generiert werden: {{error}}",
|
||||||
|
"generationFailed": "Generierung fehlgeschlagen. Bitte versuchen Sie es erneut.",
|
||||||
|
"classifyFailed": "Bilder konnten nicht klassifiziert werden: {{error}}"
|
||||||
|
},
|
||||||
|
"generateSuccess": "Erfolgreich generierte Beispielbilder",
|
||||||
|
"modelCreated": "Modell erfolgreich erstellt. Verwenden Sie die Ansicht „Aktuelle Klassifizierungen“, um Bilder für fehlende Zustände hinzuzufügen, und trainieren Sie dann das Modell.",
|
||||||
|
"missingStatesWarning": {
|
||||||
|
"title": "Beispiele für fehlende Zustände",
|
||||||
|
"description": "Sie haben nicht für alle Zustände Beispiele ausgewählt. Das Modell wird erst trainiert, wenn für alle Zustände Bilder vorhanden sind. Fahren Sie fort und verwenden Sie die Ansicht „Aktuelle Klassifizierungen“, um Bilder für die fehlenden Zustände zu klassifizieren. Trainieren Sie anschließend das Modell."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -48,10 +48,15 @@
|
|||||||
"noDataFound": "Keine Detaildaten zur Überprüfung",
|
"noDataFound": "Keine Detaildaten zur Überprüfung",
|
||||||
"settings": "Detailansicht Einstellungen",
|
"settings": "Detailansicht Einstellungen",
|
||||||
"alwaysExpandActive": {
|
"alwaysExpandActive": {
|
||||||
"desc": "Immer die Objektdetails des aktiven Überprüfungselements erweitern, sofern verfügbar."
|
"desc": "Immer die Objektdetails vom aktivem Überprüfungselement erweitern, sofern verfügbar.",
|
||||||
|
"title": "Immer aktiv erweitern"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"objectTrack": {
|
"objectTrack": {
|
||||||
"trackedPoint": "Verfolgter Punkt"
|
"trackedPoint": "Verfolgter Punkt",
|
||||||
}
|
"clickToSeek": "Klicke, um zu dieser Zeit zu springen"
|
||||||
|
},
|
||||||
|
"normalActivity": "normal",
|
||||||
|
"needsReview": "benötigt Überprüfung",
|
||||||
|
"securityConcern": "Sicherheitsbedenken"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -18,7 +18,7 @@
|
|||||||
"updatedSublabel": "Unterkategorie erfolgreich aktualisiert.",
|
"updatedSublabel": "Unterkategorie erfolgreich aktualisiert.",
|
||||||
"updatedLPR": "Nummernschild erfolgreich aktualisiert.",
|
"updatedLPR": "Nummernschild erfolgreich aktualisiert.",
|
||||||
"regenerate": "Eine neue Beschreibung wurde von {{provider}} angefordert. Je nach Geschwindigkeit des Anbieters kann es einige Zeit dauern, bis die neue Beschreibung generiert ist.",
|
"regenerate": "Eine neue Beschreibung wurde von {{provider}} angefordert. Je nach Geschwindigkeit des Anbieters kann es einige Zeit dauern, bis die neue Beschreibung generiert ist.",
|
||||||
"audioTranscription": "Audio Transkription erfolgreich angefordert."
|
"audioTranscription": "Die Audio-Transkription wurde erfolgreich angefordert. Je nach Geschwindigkeit Ihres Frigate-Servers kann die Transkription einige Zeit in Anspruch nehmen."
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"regenerate": "Der Aufruf von {{provider}} für eine neue Beschreibung ist fehlgeschlagen: {{errorMessage}}",
|
"regenerate": "Der Aufruf von {{provider}} für eine neue Beschreibung ist fehlgeschlagen: {{errorMessage}}",
|
||||||
@ -159,7 +159,8 @@
|
|||||||
"video": "Video",
|
"video": "Video",
|
||||||
"object_lifecycle": "Objekt-Lebenszyklus",
|
"object_lifecycle": "Objekt-Lebenszyklus",
|
||||||
"snapshot": "Snapshot",
|
"snapshot": "Snapshot",
|
||||||
"thumbnail": "Vorschaubild"
|
"thumbnail": "Vorschaubild",
|
||||||
|
"tracking_details": "Nachverfolgungs-Details"
|
||||||
},
|
},
|
||||||
"itemMenu": {
|
"itemMenu": {
|
||||||
"downloadSnapshot": {
|
"downloadSnapshot": {
|
||||||
@ -249,13 +250,14 @@
|
|||||||
"faceOrLicense_plate": "{{attribute}} erkannt für {{label}}",
|
"faceOrLicense_plate": "{{attribute}} erkannt für {{label}}",
|
||||||
"other": "{{label}} erkannt als {{attribute}}"
|
"other": "{{label}} erkannt als {{attribute}}"
|
||||||
},
|
},
|
||||||
"gone": "{{label}} verließ",
|
"gone": "{{label}} hat verlassen",
|
||||||
"heard": "{{label}} wurde gehört",
|
"heard": "{{label}} wurde gehört",
|
||||||
"external": "{{label}} erkannt",
|
"external": "{{label}} erkannt",
|
||||||
"header": {
|
"header": {
|
||||||
"zones": "Zonen",
|
"zones": "Zonen",
|
||||||
"ratio": "Verhältnis",
|
"ratio": "Verhältnis",
|
||||||
"area": "Bereich"
|
"area": "Bereich",
|
||||||
|
"score": "Bewertung"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"annotationSettings": {
|
"annotationSettings": {
|
||||||
@ -278,6 +280,10 @@
|
|||||||
"previous": "Vorherige Anzeige",
|
"previous": "Vorherige Anzeige",
|
||||||
"next": "Nächste Anzeige"
|
"next": "Nächste Anzeige"
|
||||||
},
|
},
|
||||||
"title": "Verfolgungsdetails"
|
"title": "Verfolgungsdetails",
|
||||||
|
"adjustAnnotationSettings": "Anmerkungseinstellungen anpassen",
|
||||||
|
"autoTrackingTips": "Die Positionen der Begrenzungsrahmen sind bei Kameras mit automatischer Verfolgung ungenau.",
|
||||||
|
"count": "{{first}} von {{second}}",
|
||||||
|
"trackedPoint": "Verfolgter Punkt"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -44,7 +44,7 @@
|
|||||||
"deleteFace": "Lösche Gesicht"
|
"deleteFace": "Lösche Gesicht"
|
||||||
},
|
},
|
||||||
"train": {
|
"train": {
|
||||||
"title": "Aktuelle Erkennungen",
|
"title": "Kürzliche Erkennungen",
|
||||||
"aria": "Wähle aktuelle Erkennungen",
|
"aria": "Wähle aktuelle Erkennungen",
|
||||||
"empty": "Es gibt keine aktuellen Versuche zur Gesichtserkennung"
|
"empty": "Es gibt keine aktuellen Versuche zur Gesichtserkennung"
|
||||||
},
|
},
|
||||||
@ -64,7 +64,7 @@
|
|||||||
"deletedName_other": "{{count}} Gesichter wurden erfolgreich gelöscht.",
|
"deletedName_other": "{{count}} Gesichter wurden erfolgreich gelöscht.",
|
||||||
"addFaceLibrary": "{{name}} wurde erfolgreich in die Gesichtsbibliothek aufgenommen!",
|
"addFaceLibrary": "{{name}} wurde erfolgreich in die Gesichtsbibliothek aufgenommen!",
|
||||||
"trainedFace": "Gesicht erfolgreich trainiert.",
|
"trainedFace": "Gesicht erfolgreich trainiert.",
|
||||||
"updatedFaceScore": "Gesichtsbewertung erfolgreich aktualisiert.",
|
"updatedFaceScore": "Gesichtsbewertung erfolgreich auf {{name}} ({{score}}) aktualisiert.",
|
||||||
"renamedFace": "Gesicht erfolgreich in {{name}} umbenannt"
|
"renamedFace": "Gesicht erfolgreich in {{name}} umbenannt"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
|
|||||||
@ -172,9 +172,13 @@
|
|||||||
"disable": "Live Audio Transkription ausschalten"
|
"disable": "Live Audio Transkription ausschalten"
|
||||||
},
|
},
|
||||||
"noCameras": {
|
"noCameras": {
|
||||||
"title": "Keine Kameras eingerichtet",
|
"title": "Keine Kameras konfiguriert",
|
||||||
"description": "Beginne indem du eine Kamera anschließt.",
|
"description": "Beginne indem du eine Kamera anschließt.",
|
||||||
"buttonText": "Kamera hinzufügen"
|
"buttonText": "Kamera hinzufügen",
|
||||||
|
"restricted": {
|
||||||
|
"title": "Keine Kamera verfügbar",
|
||||||
|
"description": "Sie haben keine Berechtigung, Kameras in dieser Gruppe anzuzeigen."
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"snapshot": {
|
"snapshot": {
|
||||||
"takeSnapshot": "Sofort-Schnappschuss herunterladen",
|
"takeSnapshot": "Sofort-Schnappschuss herunterladen",
|
||||||
|
|||||||
@ -3,16 +3,16 @@
|
|||||||
"default": "Einstellungen - Frigate",
|
"default": "Einstellungen - Frigate",
|
||||||
"authentication": "Authentifizierungseinstellungen – Frigate",
|
"authentication": "Authentifizierungseinstellungen – Frigate",
|
||||||
"camera": "Kameraeinstellungen - Frigate",
|
"camera": "Kameraeinstellungen - Frigate",
|
||||||
"masksAndZones": "Masken- und Zonen-Editor – Frigate",
|
"masksAndZones": "Masken- und Zoneneditor – Frigate",
|
||||||
"object": "Debug - Frigate",
|
"object": "Debug - Frigate",
|
||||||
"general": "UI Einstellungen – Frigate",
|
"general": "UI Einstellungen – Frigate",
|
||||||
"frigatePlus": "Frigate+ Einstellungen – Frigate",
|
"frigatePlus": "Frigate+ Einstellungen – Frigate",
|
||||||
"classification": "Klassifizierungseinstellungen – Frigate",
|
"classification": "Klassifizierungseinstellungen – Frigate",
|
||||||
"motionTuner": "Bewegungserkennungs-Optimierer – Frigate",
|
"motionTuner": "Bewegungserkennungs-Optimierer – Frigate",
|
||||||
"notifications": "Benachrichtigungs-Einstellungen",
|
"notifications": "Benachrichtigungseinstellungen",
|
||||||
"enrichments": "Erweiterte Statistiken - Frigate",
|
"enrichments": "Erweiterte Statistiken - Frigate",
|
||||||
"cameraManagement": "Kameras verwalten - Frigate",
|
"cameraManagement": "Kameras verwalten - Frigate",
|
||||||
"cameraReview": "Kamera Einstellungen prüfen - Frigate"
|
"cameraReview": "Kameraeinstellungen prüfen - Frigate"
|
||||||
},
|
},
|
||||||
"menu": {
|
"menu": {
|
||||||
"ui": "Benutzeroberfläche",
|
"ui": "Benutzeroberfläche",
|
||||||
@ -41,7 +41,7 @@
|
|||||||
"noCamera": "Keine Kamera"
|
"noCamera": "Keine Kamera"
|
||||||
},
|
},
|
||||||
"general": {
|
"general": {
|
||||||
"title": "Allgemeine Einstellungen",
|
"title": "Einstellungen der Benutzeroberfläche",
|
||||||
"liveDashboard": {
|
"liveDashboard": {
|
||||||
"title": "Live Übersicht",
|
"title": "Live Übersicht",
|
||||||
"playAlertVideos": {
|
"playAlertVideos": {
|
||||||
@ -51,6 +51,14 @@
|
|||||||
"automaticLiveView": {
|
"automaticLiveView": {
|
||||||
"desc": "Wechsle automatisch zur Live Ansicht der Kamera, wenn einen Aktivität erkannt wurde. Wenn du diese Option deaktivierst, werden die statischen Kamerabilder auf der Liveübersicht nur einmal pro Minute aktualisiert.",
|
"desc": "Wechsle automatisch zur Live Ansicht der Kamera, wenn einen Aktivität erkannt wurde. Wenn du diese Option deaktivierst, werden die statischen Kamerabilder auf der Liveübersicht nur einmal pro Minute aktualisiert.",
|
||||||
"label": "Automatische Live Ansicht"
|
"label": "Automatische Live Ansicht"
|
||||||
|
},
|
||||||
|
"displayCameraNames": {
|
||||||
|
"label": "Immer Namen der Kamera anzeigen",
|
||||||
|
"desc": "Kamerabezeichnung immer im einem Chip im Live-View-Dashboard für mehrere Kameras anzeigen."
|
||||||
|
},
|
||||||
|
"liveFallbackTimeout": {
|
||||||
|
"label": "Live Player Ausfallzeitlimit",
|
||||||
|
"desc": "Wenn der hochwertige Live-Stream einer Kamera nicht verfügbar ist, wechsle nach dieser Anzahl von Sekunden in den Modus für geringe Bandbreite. Standard: 3."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"storedLayouts": {
|
"storedLayouts": {
|
||||||
@ -232,7 +240,8 @@
|
|||||||
"alreadyExists": "Für diese Kamera existiert bereits eine Zone mit diesem Namen.",
|
"alreadyExists": "Für diese Kamera existiert bereits eine Zone mit diesem Namen.",
|
||||||
"mustBeAtLeastTwoCharacters": "Der Zonenname muss aus mindestens 2 Zeichen bestehen.",
|
"mustBeAtLeastTwoCharacters": "Der Zonenname muss aus mindestens 2 Zeichen bestehen.",
|
||||||
"mustNotBeSameWithCamera": "Der Zonenname darf nicht mit dem Kameranamen identisch sein.",
|
"mustNotBeSameWithCamera": "Der Zonenname darf nicht mit dem Kameranamen identisch sein.",
|
||||||
"mustNotContainPeriod": "Der Zonenname darf keine Punkte enthalten."
|
"mustNotContainPeriod": "Der Zonenname darf keine Punkte enthalten.",
|
||||||
|
"mustHaveAtLeastOneLetter": "Der Name der Zone muss mindestens einen Buchstaben enthalten."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"loiteringTime": {
|
"loiteringTime": {
|
||||||
@ -311,7 +320,7 @@
|
|||||||
"name": {
|
"name": {
|
||||||
"title": "Name",
|
"title": "Name",
|
||||||
"inputPlaceHolder": "Geben Sie einen Namen ein…",
|
"inputPlaceHolder": "Geben Sie einen Namen ein…",
|
||||||
"tips": "Der Name muss aus mindestens 2 Zeichen bestehen und sollte nicht den Namen einer Kamera oder anderen Zone entsprechen."
|
"tips": "Der Name muss mindestens 2 Zeichen lang sein, mindestens einen Buchstaben enthalten und darf nicht der Name einer Kamera oder einer anderen Zone sein."
|
||||||
},
|
},
|
||||||
"objects": {
|
"objects": {
|
||||||
"title": "Objekte",
|
"title": "Objekte",
|
||||||
@ -686,13 +695,13 @@
|
|||||||
"semanticSearch": {
|
"semanticSearch": {
|
||||||
"reindexNow": {
|
"reindexNow": {
|
||||||
"confirmDesc": "Sind Sie sicher, dass Sie alle verfolgten Objekteinbettungen neu indizieren wollen? Dieser Prozess läuft im Hintergrund, kann aber Ihre CPU auslasten und eine gewisse Zeit in Anspruch nehmen. Sie können den Fortschritt auf der Seite Explore verfolgen.",
|
"confirmDesc": "Sind Sie sicher, dass Sie alle verfolgten Objekteinbettungen neu indizieren wollen? Dieser Prozess läuft im Hintergrund, kann aber Ihre CPU auslasten und eine gewisse Zeit in Anspruch nehmen. Sie können den Fortschritt auf der Seite Explore verfolgen.",
|
||||||
"label": "Jetzt neu indizien",
|
"label": "Jetzt neu indizieren",
|
||||||
"desc": "Bei der Neuindizierung werden die Einbettungen für alle verfolgten Objekte neu generiert. Dieser Prozess läuft im Hintergrund und kann je nach Anzahl der verfolgten Objekte Ihre CPU auslasten und eine gewisse Zeit in Anspruch nehmen.",
|
"desc": "Bei der Neuindizierung werden die Einbettungen für alle verfolgten Objekte neu generiert. Dieser Prozess läuft im Hintergrund und kann je nach Anzahl der verfolgten Objekte Ihre CPU auslasten und eine gewisse Zeit in Anspruch nehmen.",
|
||||||
"confirmTitle": "Neuinszenierung bestätigen",
|
"confirmTitle": "Neuindizierung bestätigen",
|
||||||
"confirmButton": "Neuindizierung",
|
"confirmButton": "Neuindizierung",
|
||||||
"success": "Die Neuindizierung wurde erfolgreich gestartet.",
|
"success": "Die Neuindizierung wurde erfolgreich gestartet.",
|
||||||
"alreadyInProgress": "Die Neuindizierung ist bereits im Gange.",
|
"alreadyInProgress": "Die Neuindizierung ist bereits im Gange.",
|
||||||
"error": "Neuindizierung konnte nicht gestartet werden: {{errorMessage}}"
|
"error": "Die Neuindizierung konnte nicht gestartet werden: {{errorMessage}}"
|
||||||
},
|
},
|
||||||
"modelSize": {
|
"modelSize": {
|
||||||
"small": {
|
"small": {
|
||||||
@ -715,7 +724,7 @@
|
|||||||
"desc": "Die Gesichtserkennung ermöglicht es, Personen Namen zuzuweisen, und wenn ihr Gesicht erkannt wird, ordnet Frigate den Namen der Person als Untertitel zu. Diese Informationen sind in der Benutzeroberfläche, den Filtern und in den Benachrichtigungen enthalten.",
|
"desc": "Die Gesichtserkennung ermöglicht es, Personen Namen zuzuweisen, und wenn ihr Gesicht erkannt wird, ordnet Frigate den Namen der Person als Untertitel zu. Diese Informationen sind in der Benutzeroberfläche, den Filtern und in den Benachrichtigungen enthalten.",
|
||||||
"readTheDocumentation": "Lies die Dokumentation",
|
"readTheDocumentation": "Lies die Dokumentation",
|
||||||
"modelSize": {
|
"modelSize": {
|
||||||
"label": "Modell Größe",
|
"label": "Modellgröße",
|
||||||
"desc": "Die Größe des für die Gesichtserkennung verwendeten Modells.",
|
"desc": "Die Größe des für die Gesichtserkennung verwendeten Modells.",
|
||||||
"small": {
|
"small": {
|
||||||
"title": "klein",
|
"title": "klein",
|
||||||
@ -741,7 +750,7 @@
|
|||||||
"triggers": {
|
"triggers": {
|
||||||
"documentTitle": "Auslöser",
|
"documentTitle": "Auslöser",
|
||||||
"management": {
|
"management": {
|
||||||
"title": "Auslöser Verwaltung",
|
"title": "Auslöser",
|
||||||
"desc": "Auslöser für {{camera}} verwalten. Verwenden Sie den Vorschaubild Typ, um ähnliche Vorschaubilder wie das ausgewählte verfolgte Objekt auszulösen, und den Beschreibungstyp, um ähnliche Beschreibungen wie den von Ihnen angegebenen Text auszulösen."
|
"desc": "Auslöser für {{camera}} verwalten. Verwenden Sie den Vorschaubild Typ, um ähnliche Vorschaubilder wie das ausgewählte verfolgte Objekt auszulösen, und den Beschreibungstyp, um ähnliche Beschreibungen wie den von Ihnen angegebenen Text auszulösen."
|
||||||
},
|
},
|
||||||
"addTrigger": "Auslöser hinzufügen",
|
"addTrigger": "Auslöser hinzufügen",
|
||||||
@ -762,7 +771,9 @@
|
|||||||
},
|
},
|
||||||
"actions": {
|
"actions": {
|
||||||
"alert": "Als Alarm markieren",
|
"alert": "Als Alarm markieren",
|
||||||
"notification": "Benachrichtigung senden"
|
"notification": "Benachrichtigung senden",
|
||||||
|
"sub_label": "Unterlabel hinzufügen",
|
||||||
|
"attribute": "Attribut hinzufügen"
|
||||||
},
|
},
|
||||||
"dialog": {
|
"dialog": {
|
||||||
"createTrigger": {
|
"createTrigger": {
|
||||||
@ -780,25 +791,28 @@
|
|||||||
"form": {
|
"form": {
|
||||||
"name": {
|
"name": {
|
||||||
"title": "Name",
|
"title": "Name",
|
||||||
"placeholder": "Auslöser Name eingeben",
|
"placeholder": "Benennen Sie diesen Auslöser",
|
||||||
"error": {
|
"error": {
|
||||||
"minLength": "Der Name muss mindestens 2 Zeichen lang sein.",
|
"minLength": "Der Name muss mindestens 2 Zeichen lang sein.",
|
||||||
"invalidCharacters": "Der Name darf nur Buchstaben, Zahlen, Unterstriche und Bindestriche enthalten.",
|
"invalidCharacters": "Der Name darf nur Buchstaben, Zahlen, Unterstriche und Bindestriche enthalten.",
|
||||||
"alreadyExists": "Ein Auslöser mit diesem Namen existiert bereits für diese Kamera."
|
"alreadyExists": "Ein Auslöser mit diesem Namen existiert bereits für diese Kamera."
|
||||||
}
|
},
|
||||||
|
"description": "Geben Sie einen eindeutigen Namen oder eine Beschreibung ein, um diesen Auslöser zu identifizieren"
|
||||||
},
|
},
|
||||||
"enabled": {
|
"enabled": {
|
||||||
"description": "Diesen Auslöser aktivieren oder deaktivieren"
|
"description": "Diesen Auslöser aktivieren oder deaktivieren"
|
||||||
},
|
},
|
||||||
"type": {
|
"type": {
|
||||||
"title": "Typ",
|
"title": "Typ",
|
||||||
"placeholder": "Auslöser Typ wählen"
|
"placeholder": "Auslöser Typ wählen",
|
||||||
|
"description": "Auslösen, wenn eine ähnliche Beschreibung eines verfolgten Objekts erkannt wird",
|
||||||
|
"thumbnail": "Auslösen, wenn eine ähnliche Miniaturansicht eines verfolgten Objekts erkannt wird"
|
||||||
},
|
},
|
||||||
"content": {
|
"content": {
|
||||||
"title": "Inhalt",
|
"title": "Inhalt",
|
||||||
"imagePlaceholder": "Ein Bild auswählen",
|
"imagePlaceholder": "Miniaturansicht auswählen",
|
||||||
"textPlaceholder": "Inhaltstext eingeben",
|
"textPlaceholder": "Inhaltstext eingeben",
|
||||||
"imageDesc": "Ein Bild auswählen, um diese Aktion auszulösen, wenn ein ähnliches Bild erkannt wird.",
|
"imageDesc": "Es werden nur die letzten 100 Miniaturansichten angezeigt. Wenn Sie die gewünschte Miniaturansicht nicht finden können, überprüfen Sie bitte frühere Objekte in „Explore“ und richten Sie dort über das Menü einen Trigger ein.",
|
||||||
"textDesc": "Einen Text eingeben, um diese Aktion auszulösen, wenn eine ähnliche Beschreibung eines verfolgten Objekts erkannt wird.",
|
"textDesc": "Einen Text eingeben, um diese Aktion auszulösen, wenn eine ähnliche Beschreibung eines verfolgten Objekts erkannt wird.",
|
||||||
"error": {
|
"error": {
|
||||||
"required": "Inhalt ist erforderlich."
|
"required": "Inhalt ist erforderlich."
|
||||||
@ -809,11 +823,12 @@
|
|||||||
"error": {
|
"error": {
|
||||||
"min": "Schwellenwert muss mindestens 0 sein",
|
"min": "Schwellenwert muss mindestens 0 sein",
|
||||||
"max": "Schwellenwert darf höchstens 1 sein"
|
"max": "Schwellenwert darf höchstens 1 sein"
|
||||||
}
|
},
|
||||||
|
"desc": "Legen Sie den Ähnlichkeitsschwellenwert für diesen Trigger fest. Ein höherer Schwellenwert bedeutet, dass eine größere Übereinstimmung erforderlich ist, um den Trigger auszulösen."
|
||||||
},
|
},
|
||||||
"actions": {
|
"actions": {
|
||||||
"title": "Aktionen",
|
"title": "Aktionen",
|
||||||
"desc": "Standardmäßig sendet Frigate eine MQTT-Nachricht für alle Trigger. Wähle eine zusätzliche Aktion aus, die ausgeführt werden soll, wenn dieser Trigger ausgelöst wird.",
|
"desc": "Standardmäßig sendet Frigate für alle Trigger eine MQTT-Nachricht. Unterbezeichnungen fügen den Triggernamen zur Objektbezeichnung hinzu. Attribute sind durchsuchbare Metadaten, die separat in den Metadaten des verfolgten Objekts gespeichert werden.",
|
||||||
"error": {
|
"error": {
|
||||||
"min": "Mindesten eine Aktion muss ausgewählt sein."
|
"min": "Mindesten eine Aktion muss ausgewählt sein."
|
||||||
}
|
}
|
||||||
@ -840,6 +855,23 @@
|
|||||||
"semanticSearch": {
|
"semanticSearch": {
|
||||||
"title": "Semantische Suche ist deaktiviert",
|
"title": "Semantische Suche ist deaktiviert",
|
||||||
"desc": "Semantische Suche muss aktiviert sein um Auslöser nutzen zu können."
|
"desc": "Semantische Suche muss aktiviert sein um Auslöser nutzen zu können."
|
||||||
|
},
|
||||||
|
"wizard": {
|
||||||
|
"title": "Auslöser erstellen",
|
||||||
|
"step1": {
|
||||||
|
"description": "Konfigurieren Sie die Grundeinstellungen für Ihren Auslöser."
|
||||||
|
},
|
||||||
|
"step2": {
|
||||||
|
"description": "Legen Sie den Inhalt fest, der diese Aktion auslöst."
|
||||||
|
},
|
||||||
|
"step3": {
|
||||||
|
"description": "Konfigurieren Sie den Schwellenwert und die Aktionen für diesen Trigger."
|
||||||
|
},
|
||||||
|
"steps": {
|
||||||
|
"nameAndType": "Name und Typ",
|
||||||
|
"configureData": "Daten konfigurieren",
|
||||||
|
"thresholdAndActions": "Schwellenwert und Maßnahmen"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"roles": {
|
"roles": {
|
||||||
@ -893,7 +925,7 @@
|
|||||||
"updateCameras": "Kameras für Rolle {{role}} aktualisiert",
|
"updateCameras": "Kameras für Rolle {{role}} aktualisiert",
|
||||||
"deleteRole": "Rolle {{role}} erfolgreich gelöscht",
|
"deleteRole": "Rolle {{role}} erfolgreich gelöscht",
|
||||||
"userRolesUpdated_one": "{{count}} Benutzer, denen diese Rolle zugewiesen wurde, wurden auf „Zuschauer“ aktualisiert, der Zugriff auf alle Kameras hat.",
|
"userRolesUpdated_one": "{{count}} Benutzer, denen diese Rolle zugewiesen wurde, wurden auf „Zuschauer“ aktualisiert, der Zugriff auf alle Kameras hat.",
|
||||||
"userRolesUpdated_other": ""
|
"userRolesUpdated_other": "{{count}} Benutzer, denen diese Rollen zugewiesen wurde, wurden auf „Zuschauer“ aktualisiert, der Zugriff auf alle Kameras habem."
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"createRoleFailed": "Fehler beim Erstellen der Rolle: {{errorMessage}}",
|
"createRoleFailed": "Fehler beim Erstellen der Rolle: {{errorMessage}}",
|
||||||
@ -909,7 +941,8 @@
|
|||||||
"steps": {
|
"steps": {
|
||||||
"nameAndConnection": "Name & Verbindung",
|
"nameAndConnection": "Name & Verbindung",
|
||||||
"streamConfiguration": "Stream Konfiguration",
|
"streamConfiguration": "Stream Konfiguration",
|
||||||
"validationAndTesting": "Überprüfung & Testen"
|
"validationAndTesting": "Überprüfung & Testen",
|
||||||
|
"probeOrSnapshot": "Sondierung oder Momentaufnahme"
|
||||||
},
|
},
|
||||||
"save": {
|
"save": {
|
||||||
"success": "Neue Kamera {{cameraName}} erfolgreich hinzugefügt.",
|
"success": "Neue Kamera {{cameraName}} erfolgreich hinzugefügt.",
|
||||||
@ -926,8 +959,8 @@
|
|||||||
"testFailed": "Stream Test fehlgeschlagen: {{error}}"
|
"testFailed": "Stream Test fehlgeschlagen: {{error}}"
|
||||||
},
|
},
|
||||||
"step1": {
|
"step1": {
|
||||||
"description": "Gib deine Kameradaten ein und teste die Verbindung.",
|
"description": "Geben Sie Ihre Kameradaten ein und wählen Sie, ob Sie die Kamera automatisch erkennen lassen oder die Marke manuell auswählen möchten.",
|
||||||
"cameraName": "Kamera-Name",
|
"cameraName": "Kameraname",
|
||||||
"cameraNamePlaceholder": "z.B. vordere_tür oder Hof Übersicht",
|
"cameraNamePlaceholder": "z.B. vordere_tür oder Hof Übersicht",
|
||||||
"host": "Host/IP Adresse",
|
"host": "Host/IP Adresse",
|
||||||
"port": "Port",
|
"port": "Port",
|
||||||
@ -936,8 +969,8 @@
|
|||||||
"password": "Passwort",
|
"password": "Passwort",
|
||||||
"passwordPlaceholder": "Optional",
|
"passwordPlaceholder": "Optional",
|
||||||
"selectTransport": "Transport-Protokoll auswählen",
|
"selectTransport": "Transport-Protokoll auswählen",
|
||||||
"cameraBrand": "Kamera-Hersteller",
|
"cameraBrand": "Kamerahersteller",
|
||||||
"selectBrand": "Wähle die Kamera-Hersteller für die URL-Vorlage aus",
|
"selectBrand": "Wähle die Kamerahersteller für die URL-Vorlage aus",
|
||||||
"customUrl": "Benutzerdefinierte Stream-URL",
|
"customUrl": "Benutzerdefinierte Stream-URL",
|
||||||
"brandInformation": "Hersteller Information",
|
"brandInformation": "Hersteller Information",
|
||||||
"brandUrlFormat": "Für Kameras mit RTSP URL nutze folgendes Format: {{exampleUrl}}",
|
"brandUrlFormat": "Für Kameras mit RTSP URL nutze folgendes Format: {{exampleUrl}}",
|
||||||
@ -950,21 +983,31 @@
|
|||||||
"noSnapshot": "Es kann kein Snapshot aus dem konfigurierten Stream abgerufen werden."
|
"noSnapshot": "Es kann kein Snapshot aus dem konfigurierten Stream abgerufen werden."
|
||||||
},
|
},
|
||||||
"errors": {
|
"errors": {
|
||||||
"brandOrCustomUrlRequired": "Wählen Sie entweder einen Kamera-Hersteller mit Host/IP aus oder wählen Sie „Andere“ mit einer benutzerdefinierten URL",
|
"brandOrCustomUrlRequired": "Wählen Sie entweder einen Kamerahersteller mit Host/IP aus oder wählen Sie „Andere“ mit einer benutzerdefinierten URL",
|
||||||
"nameRequired": "Kamera-Name benötigt",
|
"nameRequired": "Der Kameraname wird benötigt",
|
||||||
"nameLength": "Kamera-Name darf höchsten 64 Zeichen lang sein",
|
"nameLength": "Der Kameraname darf höchsten 64 Zeichen lang sein",
|
||||||
"invalidCharacters": "Kamera-Name enthält ungültige Zeichen",
|
"invalidCharacters": "Der Kameraname enthält ungültige Zeichen",
|
||||||
"nameExists": "Kamera-Name existiert bereits",
|
"nameExists": "Der Kameraname existiert bereits",
|
||||||
"brands": {
|
"brands": {
|
||||||
"reolink-rtsp": "Reolink RTSP wird nicht empfohlen. Es wird empfohlen, http in den Kameraeinstellungen zu aktivieren und den Kamera-Assistenten neu zu starten."
|
"reolink-rtsp": "Reolink RTSP wird nicht empfohlen. Es wird empfohlen, http in den Kameraeinstellungen zu aktivieren und den Kamera-Assistenten neu zu starten."
|
||||||
}
|
},
|
||||||
|
"customUrlRtspRequired": "Benutzerdefinierte URLs müssen mit „rtsp://“ beginnen. Für Nicht-RTSP-Kamerastreams ist eine manuelle Konfiguration erforderlich."
|
||||||
},
|
},
|
||||||
"docs": {
|
"docs": {
|
||||||
"reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras"
|
"reolink": "https://docs.frigate.video/configuration/camera_specific.html#reolink-cameras"
|
||||||
}
|
},
|
||||||
|
"connectionSettings": "Verbindungseinstellungen",
|
||||||
|
"detectionMethod": "Stream Erkennungsmethode",
|
||||||
|
"onvifPort": "ONVIF Port",
|
||||||
|
"probeMode": "Untersuche Kamera",
|
||||||
|
"detectionMethodDescription": "Suchen Sie die Kamera mit ONVIF (sofern unterstützt), um die URLs der Kamerastreams zu finden, oder wählen Sie manuell die Kameramarke aus, um vordefinierte URLs zu verwenden. Um eine benutzerdefinierte RTSP-URL einzugeben, wählen Sie die manuelle Methode und dann „Andere“.",
|
||||||
|
"onvifPortDescription": "Bei Kameras, die ONVIF unterstützen, ist dies in der Regel 80 oder 8080.",
|
||||||
|
"useDigestAuth": "Digest-Authentifizierung verwenden",
|
||||||
|
"useDigestAuthDescription": "Verwenden Sie die HTTP-Digest-Authentifizierung für ONVIF. Einige Kameras erfordern möglicherweise einen speziellen ONVIF-Benutzernamen/ein spezielles ONVIF-Passwort anstelle des Standard-Admin-Benutzers.",
|
||||||
|
"manualMode": "Manuelle Auswahl"
|
||||||
},
|
},
|
||||||
"step2": {
|
"step2": {
|
||||||
"description": "Konfigurieren Sie Stream-Rollen und fügen Sie zusätzliche Streams für Ihre Kamera hinzu.",
|
"description": "Suchen Sie in der Kamera nach verfügbaren Streams oder konfigurieren Sie manuelle Einstellungen basierend auf der von Ihnen ausgewählten Erkennungsmethode.",
|
||||||
"streamsTitle": "Kamera Streams",
|
"streamsTitle": "Kamera Streams",
|
||||||
"addStream": "Stream hinzufügen",
|
"addStream": "Stream hinzufügen",
|
||||||
"addAnotherStream": "Weiteren Stream hinzufügen",
|
"addAnotherStream": "Weiteren Stream hinzufügen",
|
||||||
@ -983,8 +1026,8 @@
|
|||||||
"audio": "Audio"
|
"audio": "Audio"
|
||||||
},
|
},
|
||||||
"testStream": "Verbindung testen",
|
"testStream": "Verbindung testen",
|
||||||
"testSuccess": "Stream erfolgreich getestet!",
|
"testSuccess": "Verbindung erfolgreich getestet!",
|
||||||
"testFailed": "Stream-Test fehlgeschlagen",
|
"testFailed": "Verbindungstest fehlgeschlagen. Bitte überprüfen Sie ihre Eingaben und versuchen Sie es erneut.",
|
||||||
"testFailedTitle": "Test fehlgeschlagen",
|
"testFailedTitle": "Test fehlgeschlagen",
|
||||||
"connected": "Verbunden",
|
"connected": "Verbunden",
|
||||||
"notConnected": "Nicht verbunden",
|
"notConnected": "Nicht verbunden",
|
||||||
@ -1000,10 +1043,42 @@
|
|||||||
"featuresPopover": {
|
"featuresPopover": {
|
||||||
"title": "Stream Funktionen",
|
"title": "Stream Funktionen",
|
||||||
"description": "Verwende go2rtc Restreaming, um die Verbindungen zu deiner Kamera zu reduzieren."
|
"description": "Verwende go2rtc Restreaming, um die Verbindungen zu deiner Kamera zu reduzieren."
|
||||||
|
},
|
||||||
|
"streamDetails": "Verbindungsdetails",
|
||||||
|
"probing": "Kamera wird geprüft...",
|
||||||
|
"retry": "Wiederholen",
|
||||||
|
"testing": {
|
||||||
|
"probingMetadata": "Metadaten der Kamera werden überprüft...",
|
||||||
|
"fetchingSnapshot": "Kamera-Schnappschuss wird abgerufen..."
|
||||||
|
},
|
||||||
|
"probeFailed": "Fehler beim Untersuchen der Kamera: {{error}}",
|
||||||
|
"probingDevice": "Untersuche Gerät...",
|
||||||
|
"probeSuccessful": "Erkennung erfolgreich",
|
||||||
|
"probeError": "Erkennungsfehler",
|
||||||
|
"probeNoSuccess": "Erkennung fehlgeschlagen",
|
||||||
|
"deviceInfo": "Geräteinformationen",
|
||||||
|
"manufacturer": "Hersteller",
|
||||||
|
"model": "Modell",
|
||||||
|
"firmware": "Firmware",
|
||||||
|
"profiles": "Profile",
|
||||||
|
"ptzSupport": "PTZ Unterstützung",
|
||||||
|
"autotrackingSupport": "Unterstützung für Autoverfolgung",
|
||||||
|
"presets": "Voreinstellung",
|
||||||
|
"rtspCandidates": "RTSP Kandidaten",
|
||||||
|
"rtspCandidatesDescription": "Die folgenden RTSP-URLs wurden bei der Kameraerkennung gefunden. Testen Sie die Verbindung, um die Stream-Metadaten anzuzeigen.",
|
||||||
|
"noRtspCandidates": "Es wurden keine RTSP-URLs von der Kamera gefunden. Möglicherweise sind Ihre Anmeldedaten falsch oder die Kamera unterstützt ONVIF oder die Methode zum Abrufen von RTSP-URLs nicht. Gehen Sie zurück und geben Sie die RTSP-URL manuell ein.",
|
||||||
|
"candidateStreamTitle": "Kandidate {{number}}",
|
||||||
|
"useCandidate": "Verwenden",
|
||||||
|
"uriCopy": "Kopieren",
|
||||||
|
"uriCopied": "URI in die Zwischenablage kopiert",
|
||||||
|
"testConnection": "Test Verbindung",
|
||||||
|
"toggleUriView": "Klicken Sie hier, um die vollständige URI zu sehen",
|
||||||
|
"errors": {
|
||||||
|
"hostRequired": "Host/IP adresse wird benötigt"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"step3": {
|
"step3": {
|
||||||
"description": "Endgültige Validierung und Analyse vor dem Speichern Ihrer neuen Kamera. Verbinde jeden Stream vor dem Speichern.",
|
"description": "Konfigurieren Sie Stream-Rollen und fügen Sie zusätzliche Streams für Ihre Kamera hinzu",
|
||||||
"validationTitle": "Stream Validierung",
|
"validationTitle": "Stream Validierung",
|
||||||
"connectAllStreams": "Verbinde alle Streams",
|
"connectAllStreams": "Verbinde alle Streams",
|
||||||
"reconnectionSuccess": "Wiederverbindung erfolgreich.",
|
"reconnectionSuccess": "Wiederverbindung erfolgreich.",
|
||||||
@ -1040,6 +1115,90 @@
|
|||||||
"hikvision": {
|
"hikvision": {
|
||||||
"substreamWarning": "Substream 1 ist auf eine niedrige Auflösung festgelegt. Viele Hikvision-Kameras unterstützen zusätzliche Substreams, die in den Kameraeinstellungen aktiviert werden müssen. Es wird empfohlen, diese Streams zu nutzen, sofern sie verfügbar sind."
|
"substreamWarning": "Substream 1 ist auf eine niedrige Auflösung festgelegt. Viele Hikvision-Kameras unterstützen zusätzliche Substreams, die in den Kameraeinstellungen aktiviert werden müssen. Es wird empfohlen, diese Streams zu nutzen, sofern sie verfügbar sind."
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"streamsTitle": "Kamera Stream",
|
||||||
|
"addStream": "Stream hinzufügen",
|
||||||
|
"addAnotherStream": "weiteren Stream hinzufügen",
|
||||||
|
"streamUrl": "Stream URL",
|
||||||
|
"streamUrlPlaceholder": "rtsp://benutzername:passwort@host:port/path",
|
||||||
|
"selectStream": "Auswahl Stream",
|
||||||
|
"searchCandidates": "Suche Kandidaten...",
|
||||||
|
"noStreamFound": "Kein Stream gefunden",
|
||||||
|
"url": "URL",
|
||||||
|
"resolution": "Auflösung",
|
||||||
|
"selectResolution": "Wähle Auflösung",
|
||||||
|
"quality": "Qualität",
|
||||||
|
"selectQuality": "Wähle Qualität",
|
||||||
|
"roleLabels": {
|
||||||
|
"detect": "Objekterkennung",
|
||||||
|
"record": "Aufnahme",
|
||||||
|
"audio": "Ton"
|
||||||
|
},
|
||||||
|
"testStream": "Verbindungstest",
|
||||||
|
"testSuccess": "Verbindungstest erfolgreich!",
|
||||||
|
"testFailed": "Verbindungstest fehlgeschlagen",
|
||||||
|
"testFailedTitle": "Test fehlgeschlagen",
|
||||||
|
"connected": "Verbunden",
|
||||||
|
"notConnected": "nicht verbunden",
|
||||||
|
"featuresTitle": "Funktionen",
|
||||||
|
"go2rtc": "Verbindungen zur Kamera reduzieren",
|
||||||
|
"detectRoleWarning": "Mindestens ein Stream muss die Rolle „detect“ haben, um fortfahren zu können.",
|
||||||
|
"rolesPopover": {
|
||||||
|
"title": "Stream Rollen",
|
||||||
|
"detect": "Hauptfeed für die Objekterkennung.",
|
||||||
|
"record": "Speichert Segmente des Video-Feeds basierend auf den Konfigurationseinstellungen.",
|
||||||
|
"audio": "Feed für audiobasierte Erkennung."
|
||||||
|
},
|
||||||
|
"featuresPopover": {
|
||||||
|
"title": "Stream Funktionen",
|
||||||
|
"description": "Verwenden Sie go2rtc-Restreaming, um die Verbindungen zu Ihrer Kamera zu reduzieren."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"step4": {
|
||||||
|
"description": "Endgültige Validierung und Analyse vor dem Speichern Ihrer neuen Kamera. Verbinden Sie jeden Stream vor dem Speichern.",
|
||||||
|
"validationTitle": "Stream-Validierung",
|
||||||
|
"connectAllStreams": "Alle Streams verbinden",
|
||||||
|
"reconnectionSuccess": "Wiederverbindung erfolgreich.",
|
||||||
|
"reconnectionPartial": "Einige Streams konnten nicht wieder verbunden werden.",
|
||||||
|
"streamUnavailable": "Stream Vorschau nicht verfügbar",
|
||||||
|
"reload": "neu Laden",
|
||||||
|
"connecting": "Verbinden...",
|
||||||
|
"streamTitle": "Stream {{number}}",
|
||||||
|
"valid": "gültig",
|
||||||
|
"failed": "fehlgeschlagen",
|
||||||
|
"notTested": "nicht getestet",
|
||||||
|
"connectStream": "Verbinden",
|
||||||
|
"connectingStream": "Verbinden",
|
||||||
|
"disconnectStream": "getrennt",
|
||||||
|
"estimatedBandwidth": "Voraussichtliche Bandbreite",
|
||||||
|
"roles": "Rollen",
|
||||||
|
"ffmpegModule": "Stream-Kompatibilitätsmodus verwenden",
|
||||||
|
"ffmpegModuleDescription": "Wenn der Stream nach mehreren Versuchen nicht geladen wird, versuchen Sie, diese Option zu aktivieren. Wenn diese Option aktiviert ist, verwendet Frigate das ffmpeg-Modul mit go2rtc. Dies kann zu einer besseren Kompatibilität mit einigen Kamerastreams führen.",
|
||||||
|
"none": "keiner",
|
||||||
|
"error": "Fehler",
|
||||||
|
"streamValidated": "Steam {{number}} erfolgreich validiert",
|
||||||
|
"streamValidationFailed": "Stream {{number}} Validierung fehlgeschlagen",
|
||||||
|
"saveAndApply": "Neue Kamera speichern",
|
||||||
|
"saveError": "Ungültige Konfiguration. Bitte überprüfen Sie Ihre Einstellungen.",
|
||||||
|
"issues": {
|
||||||
|
"title": "Stream-Validierung",
|
||||||
|
"videoCodecGood": "Video codec ist {{codec}}.",
|
||||||
|
"audioCodecGood": "Audio codec ist {{codec}}.",
|
||||||
|
"resolutionHigh": "Eine Auflösung von {{resolution}} kann zu einem erhöhten Ressourcenverbrauch führen.",
|
||||||
|
"resolutionLow": "Eine Auflösung von {{resolution}} ist möglicherweise zu gering, um kleine Objekte zuverlässig zu erkennen.",
|
||||||
|
"noAudioWarning": "Für diesen Stream wurde kein Ton erkannt, die Aufzeichnungen enthalten keinen Ton.",
|
||||||
|
"audioCodecRecordError": "Der AAC-Audio-Codec ist erforderlich, um Audio in Aufnahmen zu unterstützen.",
|
||||||
|
"audioCodecRequired": "Ein Audiostream ist erforderlich, um die Audioerkennung zu unterstützen.",
|
||||||
|
"restreamingWarning": "Die Reduzierung der Verbindungen zur Kamera für den Aufzeichnungsstream kann zu einer geringfügigen Erhöhung der CPU-Auslastung führen.",
|
||||||
|
"brands": {
|
||||||
|
"reolink-rtsp": "Reolink RTSP wird nicht empfohlen. Aktivieren Sie HTTP in den Firmware-Einstellungen der Kamera und starten Sie den Assistenten neu."
|
||||||
|
},
|
||||||
|
"dahua": {
|
||||||
|
"substreamWarning": "Substream 1 ist auf eine niedrige Auflösung festgelegt. Viele Kameras von Dahua / Amcrest / EmpireTech unterstützen zusätzliche Substreams, die in den Kameraeinstellungen aktiviert werden müssen. Es wird empfohlen, diese Streams zu überprüfen und zu nutzen, sofern sie verfügbar sind."
|
||||||
|
},
|
||||||
|
"hikvision": {
|
||||||
|
"substreamWarning": "Substream 1 ist auf eine niedrige Auflösung festgelegt. Viele Hikvision-Kameras unterstützen zusätzliche Substreams, die in den Kameraeinstellungen aktiviert werden müssen. Es wird empfohlen, diese Streams zu überprüfen und zu nutzen, sofern sie verfügbar sind."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -1057,9 +1216,9 @@
|
|||||||
"add": "Kamera hinzufügen",
|
"add": "Kamera hinzufügen",
|
||||||
"edit": "Kamera bearbeiten",
|
"edit": "Kamera bearbeiten",
|
||||||
"description": "Konfiguriere die Kameraeinstellungen, einschließlich Streams und Rollen.",
|
"description": "Konfiguriere die Kameraeinstellungen, einschließlich Streams und Rollen.",
|
||||||
"name": "Kamera-Name",
|
"name": "Kameraname",
|
||||||
"nameRequired": "Kamera-Name benötigt",
|
"nameRequired": "Kameraname benötigt",
|
||||||
"nameLength": "Kamera-Name darf maximal 64 Zeichen lang sein.",
|
"nameLength": "Kameraname darf maximal 64 Zeichen lang sein.",
|
||||||
"namePlaceholder": "z.B. vordere_tür oder Hof Übersicht",
|
"namePlaceholder": "z.B. vordere_tür oder Hof Übersicht",
|
||||||
"enabled": "Aktiviert",
|
"enabled": "Aktiviert",
|
||||||
"ffmpeg": {
|
"ffmpeg": {
|
||||||
@ -1094,14 +1253,14 @@
|
|||||||
"desc": "Generative KI Review Beschreibungen für diese Kamera vorübergehend aktivieren/deaktivieren. Wenn diese Option deaktiviert ist, werden für die Review Elemente dieser Kamera keine KI-generierten Beschreibungen angefordert."
|
"desc": "Generative KI Review Beschreibungen für diese Kamera vorübergehend aktivieren/deaktivieren. Wenn diese Option deaktiviert ist, werden für die Review Elemente dieser Kamera keine KI-generierten Beschreibungen angefordert."
|
||||||
},
|
},
|
||||||
"review": {
|
"review": {
|
||||||
"title": "Review",
|
"title": "Überprüfung",
|
||||||
"desc": "Aktivieren/deaktivieren Sie vorübergehend Warnmeldungen und Erkennungen für diese Kamera, bis Frigate neu gestartet wird. Wenn diese Funktion deaktiviert ist, werden keine neuen Überprüfungselemente generiert. ",
|
"desc": "Aktivieren/deaktivieren Sie vorübergehend Warnmeldungen und Erkennungen für diese Kamera, bis Frigate neu gestartet wird. Wenn diese Funktion deaktiviert ist, werden keine neuen Überprüfungselemente generiert. ",
|
||||||
"alerts": "Warnungen ",
|
"alerts": "Warnungen ",
|
||||||
"detections": "Erkennungen "
|
"detections": "Erkennungen "
|
||||||
},
|
},
|
||||||
"reviewClassification": {
|
"reviewClassification": {
|
||||||
"title": "Bewertungsklassifizierung",
|
"title": "Bewertungsklassifizierung",
|
||||||
"desc": "Frigate kategorisiert zu überprüfende Elemente als Warnmeldungen und Erkennungen. Standardmäßig werden alle Objekte vom Typ <em>person</em> und <em>car</em> als Warnmeldungen betrachtet. Sie können die Kategorisierung der zu überprüfenden Elemente verfeinern, indem Sie die erforderlichen Zonen für sie konfigurieren.",
|
"desc": "Frigate kategorisiert zu überprüfende Elemente als Warnmeldungen und Erkennungen. Standardmäßig werden alle Objekte vom Typ <em>Person</em> und <em>Auto</em> als Warnmeldungen betrachtet. Sie können die Kategorisierung der zu überprüfenden Elemente verfeinern, indem Sie die erforderlichen Zonen für sie konfigurieren.",
|
||||||
"noDefinedZones": "Für diese Kamera sind keine Zonen definiert.",
|
"noDefinedZones": "Für diese Kamera sind keine Zonen definiert.",
|
||||||
"objectAlertsTips": "Alle {{alertsLabels}}-Objekte auf {{cameraName}} werden als Warnmeldungen angezeigt.",
|
"objectAlertsTips": "Alle {{alertsLabels}}-Objekte auf {{cameraName}} werden als Warnmeldungen angezeigt.",
|
||||||
"zoneObjectAlertsTips": "Alle {{alertsLabels}}-Objekte, die in {{zone}} auf {{cameraName}} erkannt wurden, werden als Warnmeldungen angezeigt.",
|
"zoneObjectAlertsTips": "Alle {{alertsLabels}}-Objekte, die in {{zone}} auf {{cameraName}} erkannt wurden, werden als Warnmeldungen angezeigt.",
|
||||||
|
|||||||
@ -31,7 +31,12 @@
|
|||||||
"gpuDecoder": "GPU Decoder",
|
"gpuDecoder": "GPU Decoder",
|
||||||
"gpuEncoder": "GPU Encoder",
|
"gpuEncoder": "GPU Encoder",
|
||||||
"npuUsage": "NPU Verwendung",
|
"npuUsage": "NPU Verwendung",
|
||||||
"npuMemory": "NPU Speicher"
|
"npuMemory": "NPU Speicher",
|
||||||
|
"intelGpuWarning": {
|
||||||
|
"title": "Intel GPU Statistik Warnung",
|
||||||
|
"message": "GPU stats nicht verfügbar",
|
||||||
|
"description": "Dies ist ein bekannter Fehler in den GPU-Statistik-Tools von Intel (intel_gpu_top), bei dem das Tool ausfällt und wiederholt eine GPU-Auslastung von 0 % anzeigt, selbst wenn die Hardwarebeschleunigung und die Objekterkennung auf der (i)GPU korrekt funktionieren. Dies ist kein Fehler von Frigate. Du kannst den Host neu starten, um das Problem vorübergehend zu beheben und zu prüfen, ob die GPU korrekt funktioniert. Dies hat keine Auswirkungen auf die Leistung."
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"title": "Allgemein",
|
"title": "Allgemein",
|
||||||
"detector": {
|
"detector": {
|
||||||
@ -167,10 +172,17 @@
|
|||||||
"face_recognition": "Gesichts Erkennung",
|
"face_recognition": "Gesichts Erkennung",
|
||||||
"image_embedding": "Bild Embedding",
|
"image_embedding": "Bild Embedding",
|
||||||
"yolov9_plate_detection_speed": "YOLOv9 Kennzeichenerkennungsgeschwindigkeit",
|
"yolov9_plate_detection_speed": "YOLOv9 Kennzeichenerkennungsgeschwindigkeit",
|
||||||
"yolov9_plate_detection": "YOLOv9 Kennzeichenerkennung"
|
"yolov9_plate_detection": "YOLOv9 Kennzeichenerkennung",
|
||||||
|
"review_description": "Bewertung Beschreibung",
|
||||||
|
"review_description_speed": "Bewertungsbeschreibung Geschwindigkeit",
|
||||||
|
"review_description_events_per_second": "Bewertungsbeschreibung",
|
||||||
|
"object_description": "Objekt Beschreibung",
|
||||||
|
"object_description_speed": "Objektbeschreibung Geschwindigkeit",
|
||||||
|
"object_description_events_per_second": "Objektbeschreibung"
|
||||||
},
|
},
|
||||||
"title": "Optimierungen",
|
"title": "Optimierungen",
|
||||||
"infPerSecond": "Rückschlüsse pro Sekunde"
|
"infPerSecond": "Rückschlüsse pro Sekunde",
|
||||||
|
"averageInf": "Durchschnittliche Inferenzzeit"
|
||||||
},
|
},
|
||||||
"stats": {
|
"stats": {
|
||||||
"healthy": "Das System läuft problemlos",
|
"healthy": "Das System läuft problemlos",
|
||||||
|
|||||||
@ -177,7 +177,7 @@
|
|||||||
"generateSuccess": "Successfully generated sample images",
|
"generateSuccess": "Successfully generated sample images",
|
||||||
"missingStatesWarning": {
|
"missingStatesWarning": {
|
||||||
"title": "Missing State Examples",
|
"title": "Missing State Examples",
|
||||||
"description": "You haven't selected examples for all states. The model will not be trained until all states have images. After continuing, use the Recent Classifications view to classify images for the missing states, then train the model."
|
"description": "It's recommended to select examples for all states for best results. You can continue without selecting all states, but the model will not be trained until all states have images. After continuing, use the Recent Classifications view to classify images for the missing states, then train the model."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -500,7 +500,7 @@
|
|||||||
"name": {
|
"name": {
|
||||||
"title": "Name",
|
"title": "Name",
|
||||||
"inputPlaceHolder": "Enter a name…",
|
"inputPlaceHolder": "Enter a name…",
|
||||||
"tips": "Name must be at least 2 characters, must have at least one letter, and must not be the name of a camera or another zone."
|
"tips": "Name must be at least 2 characters, must have at least one letter, and must not be the name of a camera or another zone on this camera."
|
||||||
},
|
},
|
||||||
"inertia": {
|
"inertia": {
|
||||||
"title": "Inertia",
|
"title": "Inertia",
|
||||||
|
|||||||
@ -124,7 +124,7 @@
|
|||||||
"twoWayTalk": {
|
"twoWayTalk": {
|
||||||
"tips.documentation": "Leer la documentación ",
|
"tips.documentation": "Leer la documentación ",
|
||||||
"available": "La conversación bidireccional está disponible para esta transmisión",
|
"available": "La conversación bidireccional está disponible para esta transmisión",
|
||||||
"unavailable": "La conversación bidireccional está disponible para esta transmisión",
|
"unavailable": "La conversación bidireccional no está disponible para esta transmisión",
|
||||||
"tips": "Tu dispositivo debe soportar la función y WebRTC debe estar configurado para la conversación bidireccional."
|
"tips": "Tu dispositivo debe soportar la función y WebRTC debe estar configurado para la conversación bidireccional."
|
||||||
},
|
},
|
||||||
"lowBandwidth": {
|
"lowBandwidth": {
|
||||||
|
|||||||
1
web/public/locales/et/audio.json
Normal file
1
web/public/locales/et/audio.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/common.json
Normal file
1
web/public/locales/et/common.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/components/auth.json
Normal file
1
web/public/locales/et/components/auth.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/components/camera.json
Normal file
1
web/public/locales/et/components/camera.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/components/dialog.json
Normal file
1
web/public/locales/et/components/dialog.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/components/filter.json
Normal file
1
web/public/locales/et/components/filter.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/components/icons.json
Normal file
1
web/public/locales/et/components/icons.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/components/input.json
Normal file
1
web/public/locales/et/components/input.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/components/player.json
Normal file
1
web/public/locales/et/components/player.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/objects.json
Normal file
1
web/public/locales/et/objects.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/classificationModel.json
Normal file
1
web/public/locales/et/views/classificationModel.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/configEditor.json
Normal file
1
web/public/locales/et/views/configEditor.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/events.json
Normal file
1
web/public/locales/et/views/events.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/explore.json
Normal file
1
web/public/locales/et/views/explore.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/exports.json
Normal file
1
web/public/locales/et/views/exports.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/faceLibrary.json
Normal file
1
web/public/locales/et/views/faceLibrary.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/live.json
Normal file
1
web/public/locales/et/views/live.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/recording.json
Normal file
1
web/public/locales/et/views/recording.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/search.json
Normal file
1
web/public/locales/et/views/search.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/settings.json
Normal file
1
web/public/locales/et/views/settings.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
1
web/public/locales/et/views/system.json
Normal file
1
web/public/locales/et/views/system.json
Normal file
@ -0,0 +1 @@
|
|||||||
|
{}
|
||||||
@ -65,7 +65,8 @@
|
|||||||
"endTimeMustAfterStartTime": "L'heure de fin doit être postérieure à l'heure de début.",
|
"endTimeMustAfterStartTime": "L'heure de fin doit être postérieure à l'heure de début.",
|
||||||
"noVaildTimeSelected": "La plage horaire sélectionnée n'est pas valide."
|
"noVaildTimeSelected": "La plage horaire sélectionnée n'est pas valide."
|
||||||
},
|
},
|
||||||
"success": "Exportation démarrée avec succès. Consultez le fichier sur la page des exportations."
|
"success": "Exportation démarrée avec succès. Consultez le fichier sur la page des exportations.",
|
||||||
|
"view": "Vue"
|
||||||
},
|
},
|
||||||
"select": "Sélectionner",
|
"select": "Sélectionner",
|
||||||
"name": {
|
"name": {
|
||||||
|
|||||||
@ -152,7 +152,12 @@
|
|||||||
"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_one": "Veuillez classifier toutes les images. {{count}} image restante.",
|
||||||
"allImagesRequired_many": "Veuillez classifier toutes les images. {{count}} images restantes.",
|
"allImagesRequired_many": "Veuillez classifier toutes les images. {{count}} images restantes.",
|
||||||
"allImagesRequired_other": "Veuillez classifier toutes les images. {{count}} images restantes."
|
"allImagesRequired_other": "Veuillez classifier toutes les images. {{count}} images restantes.",
|
||||||
|
"modelCreated": "Modèle créé avec succès. Utilisez la vue Classifications récentes pour ajouter des images pour les états manquants, puis entraînez le modèle.",
|
||||||
|
"missingStatesWarning": {
|
||||||
|
"title": "Exemples d'états manquants",
|
||||||
|
"description": "Vous n'avez pas sélectionné d'exemples pour tous les états. L'entraînement ne pourra débuter que lorsque chaque état disposera d'images. Continuez, puis utilisez la vue Classifications récentes pour classer les images manquantes et lancer l'entraînement."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deleteModel": {
|
"deleteModel": {
|
||||||
|
|||||||
@ -56,5 +56,8 @@
|
|||||||
"clickToSeek": "Cliquez pour atteindre ce moment."
|
"clickToSeek": "Cliquez pour atteindre ce moment."
|
||||||
},
|
},
|
||||||
"zoomIn": "Zoom avant",
|
"zoomIn": "Zoom avant",
|
||||||
"zoomOut": "Zoom arrière"
|
"zoomOut": "Zoom arrière",
|
||||||
|
"normalActivity": "Normal",
|
||||||
|
"needsReview": "Nécessite une revue",
|
||||||
|
"securityConcern": "Problème de sécurité"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -208,6 +208,10 @@
|
|||||||
"viewTrackingDetails": {
|
"viewTrackingDetails": {
|
||||||
"label": "Voir les détails du suivi",
|
"label": "Voir les détails du suivi",
|
||||||
"aria": "Afficher les détails du suivi"
|
"aria": "Afficher les détails du suivi"
|
||||||
|
},
|
||||||
|
"downloadCleanSnapshot": {
|
||||||
|
"label": "Télécharger l'instantané vierge",
|
||||||
|
"aria": "Télécharger l'instantané vierge"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"dialog": {
|
"dialog": {
|
||||||
@ -263,7 +267,8 @@
|
|||||||
"header": {
|
"header": {
|
||||||
"zones": "Zones",
|
"zones": "Zones",
|
||||||
"ratio": "Ratio",
|
"ratio": "Ratio",
|
||||||
"area": "Surface"
|
"area": "Surface",
|
||||||
|
"score": "Score"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"annotationSettings": {
|
"annotationSettings": {
|
||||||
|
|||||||
@ -66,7 +66,8 @@
|
|||||||
"failed": "Impossibile avviare l'esportazione: {{error}}",
|
"failed": "Impossibile avviare l'esportazione: {{error}}",
|
||||||
"endTimeMustAfterStartTime": "L'ora di fine deve essere successiva all'ora di inizio",
|
"endTimeMustAfterStartTime": "L'ora di fine deve essere successiva all'ora di inizio",
|
||||||
"noVaildTimeSelected": "Nessun intervallo di tempo valido selezionato"
|
"noVaildTimeSelected": "Nessun intervallo di tempo valido selezionato"
|
||||||
}
|
},
|
||||||
|
"view": "Visualizzazione"
|
||||||
},
|
},
|
||||||
"fromTimeline": {
|
"fromTimeline": {
|
||||||
"saveExport": "Salva esportazione",
|
"saveExport": "Salva esportazione",
|
||||||
|
|||||||
@ -152,7 +152,12 @@
|
|||||||
"generateSuccess": "Immagini campione generate correttamente",
|
"generateSuccess": "Immagini campione generate correttamente",
|
||||||
"allImagesRequired_one": "Classifica tutte le immagini. Rimane {{count}} immagine.",
|
"allImagesRequired_one": "Classifica tutte le immagini. Rimane {{count}} immagine.",
|
||||||
"allImagesRequired_many": "Classifica tutte le immagini. Rimangono {{count}} immagini.",
|
"allImagesRequired_many": "Classifica tutte le immagini. Rimangono {{count}} immagini.",
|
||||||
"allImagesRequired_other": "Classifica tutte le immagini. Rimangono {{count}} immagini."
|
"allImagesRequired_other": "Classifica tutte le immagini. Rimangono {{count}} immagini.",
|
||||||
|
"modelCreated": "Modello creato correttamente. Utilizza la vista Classificazioni recenti per aggiungere immagini per gli stati mancanti, quindi addestrare il modello.",
|
||||||
|
"missingStatesWarning": {
|
||||||
|
"title": "Esempi di stati mancanti",
|
||||||
|
"description": "Non hai selezionato esempi per tutti gli stati. Il modello non verrà addestrato finché tutti gli stati non avranno immagini. Dopo aver continuato, utilizza la vista Classificazioni recenti per classificare le immagini per gli stati mancanti, quindi addestra il modello."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deleteModel": {
|
"deleteModel": {
|
||||||
|
|||||||
@ -56,5 +56,8 @@
|
|||||||
"clickToSeek": "Premi per cercare in questo momento"
|
"clickToSeek": "Premi per cercare in questo momento"
|
||||||
},
|
},
|
||||||
"zoomIn": "Ingrandisci",
|
"zoomIn": "Ingrandisci",
|
||||||
"zoomOut": "Rimpicciolisci"
|
"zoomOut": "Rimpicciolisci",
|
||||||
|
"normalActivity": "Normale",
|
||||||
|
"needsReview": "Necessita revisione",
|
||||||
|
"securityConcern": "Rischio per la sicurezza"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -263,7 +263,8 @@
|
|||||||
"header": {
|
"header": {
|
||||||
"zones": "Zone",
|
"zones": "Zone",
|
||||||
"ratio": "Rapporto",
|
"ratio": "Rapporto",
|
||||||
"area": "Area"
|
"area": "Area",
|
||||||
|
"score": "Punteggio"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"annotationSettings": {
|
"annotationSettings": {
|
||||||
|
|||||||
@ -61,7 +61,8 @@
|
|||||||
"failed": "Klarte ikke å starte eksport: {{error}}",
|
"failed": "Klarte ikke å starte eksport: {{error}}",
|
||||||
"noVaildTimeSelected": "Ingen gyldig tidsperiode valgt",
|
"noVaildTimeSelected": "Ingen gyldig tidsperiode valgt",
|
||||||
"endTimeMustAfterStartTime": "Sluttid må være etter starttid"
|
"endTimeMustAfterStartTime": "Sluttid må være etter starttid"
|
||||||
}
|
},
|
||||||
|
"view": "Vis"
|
||||||
},
|
},
|
||||||
"fromTimeline": {
|
"fromTimeline": {
|
||||||
"previewExport": "Forhåndsvis eksport",
|
"previewExport": "Forhåndsvis eksport",
|
||||||
|
|||||||
@ -23,8 +23,8 @@
|
|||||||
"label": "Sorter",
|
"label": "Sorter",
|
||||||
"dateAsc": "Dato (Stigende)",
|
"dateAsc": "Dato (Stigende)",
|
||||||
"dateDesc": "Dato (Synkende)",
|
"dateDesc": "Dato (Synkende)",
|
||||||
"scoreAsc": "Objektpoengsum (Stigende)",
|
"scoreAsc": "Objektscore (Stigende)",
|
||||||
"scoreDesc": "Objektpoengsum (Synkende)",
|
"scoreDesc": "Objektscore (Synkende)",
|
||||||
"speedAsc": "Estimert hastighet (Stigende)",
|
"speedAsc": "Estimert hastighet (Stigende)",
|
||||||
"speedDesc": "Estimert hastighet (Synkende)",
|
"speedDesc": "Estimert hastighet (Synkende)",
|
||||||
"relevance": "Relevans"
|
"relevance": "Relevans"
|
||||||
@ -104,7 +104,7 @@
|
|||||||
"label": "Underetiketter",
|
"label": "Underetiketter",
|
||||||
"all": "Alle underetiketter"
|
"all": "Alle underetiketter"
|
||||||
},
|
},
|
||||||
"score": "Poengsum",
|
"score": "Score",
|
||||||
"estimatedSpeed": "Estimert hastighet ({{unit}})",
|
"estimatedSpeed": "Estimert hastighet ({{unit}})",
|
||||||
"cameras": {
|
"cameras": {
|
||||||
"all": {
|
"all": {
|
||||||
|
|||||||
@ -12,19 +12,19 @@
|
|||||||
},
|
},
|
||||||
"toast": {
|
"toast": {
|
||||||
"success": {
|
"success": {
|
||||||
"deletedCategory": "Kategori slettet",
|
"deletedCategory": "Klasse slettet",
|
||||||
"deletedImage": "Bilder slettet",
|
"deletedImage": "Bilder slettet",
|
||||||
"categorizedImage": "Bildet ble klassifisert",
|
"categorizedImage": "Klassifiserte bildet",
|
||||||
"trainedModel": "Modellen ble trent.",
|
"trainedModel": "Modellen ble trent.",
|
||||||
"trainingModel": "Modelltrening startet.",
|
"trainingModel": "Modelltrening startet.",
|
||||||
"deletedModel_one": "{{count}} modell ble slettet",
|
"deletedModel_one": "{{count}} modell ble slettet",
|
||||||
"deletedModel_other": "{{count}} modeller ble slettet",
|
"deletedModel_other": "{{count}} modeller ble slettet",
|
||||||
"updatedModel": "Modellkonfigurasjonen ble oppdatert",
|
"updatedModel": "Modellkonfigurasjonen ble oppdatert",
|
||||||
"renamedCategory": "Kategorien ble omdøpt til {{name}}"
|
"renamedCategory": "Klassen ble omdøpt til {{name}}"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"deleteImageFailed": "Kunne ikke slette: {{errorMessage}}",
|
"deleteImageFailed": "Kunne ikke slette: {{errorMessage}}",
|
||||||
"deleteCategoryFailed": "Kunne ikke slette kategori: {{errorMessage}}",
|
"deleteCategoryFailed": "Kunne ikke slette klasse: {{errorMessage}}",
|
||||||
"categorizeFailed": "Kunne ikke klassifisere bilde: {{errorMessage}}",
|
"categorizeFailed": "Kunne ikke klassifisere bilde: {{errorMessage}}",
|
||||||
"trainingFailed": "Modelltrening mislyktes. Sjekk Frigate-loggene for detaljer.",
|
"trainingFailed": "Modelltrening mislyktes. Sjekk Frigate-loggene for detaljer.",
|
||||||
"deleteModelFailed": "Kunne ikke slette modell: {{errorMessage}}",
|
"deleteModelFailed": "Kunne ikke slette modell: {{errorMessage}}",
|
||||||
@ -34,10 +34,10 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deleteCategory": {
|
"deleteCategory": {
|
||||||
"title": "Slett kategori",
|
"title": "Slett klasse",
|
||||||
"desc": "Er du sikker på at du vil slette kategorien {{name}}? Dette vil permanent slette alle tilknyttede bilder og kreve at modellen trenes på nytt.",
|
"desc": "Er du sikker på at du vil slette klassen {{name}}? Dette vil permanent slette alle tilknyttede bilder og kreve at modellen trenes på nytt.",
|
||||||
"minClassesTitle": "Kan ikke slette klasse",
|
"minClassesTitle": "Kan ikke slette klasse",
|
||||||
"minClassesDesc": "En klassifiseringsmodell må ha minst 2 kategorier. Legg til en ny kategori før du sletter denne."
|
"minClassesDesc": "En klassifiseringsmodell må ha minst 2 klasser. Legg til en ny klasse før du sletter denne."
|
||||||
},
|
},
|
||||||
"deleteDatasetImages": {
|
"deleteDatasetImages": {
|
||||||
"title": "Slett datasettbilder",
|
"title": "Slett datasettbilder",
|
||||||
@ -48,7 +48,7 @@
|
|||||||
"desc": "Er du sikker på at du vil slette {{count}} bilder? Denne handlingen kan ikke angres."
|
"desc": "Er du sikker på at du vil slette {{count}} bilder? Denne handlingen kan ikke angres."
|
||||||
},
|
},
|
||||||
"renameCategory": {
|
"renameCategory": {
|
||||||
"title": "Gi nytt navn til kategori",
|
"title": "Omdøp klasse",
|
||||||
"desc": "Skriv inn et nytt navn for {{name}}. Du må trene modellen på nytt for at navneendringen skal tre i kraft."
|
"desc": "Skriv inn et nytt navn for {{name}}. Du må trene modellen på nytt for at navneendringen skal tre i kraft."
|
||||||
},
|
},
|
||||||
"description": {
|
"description": {
|
||||||
@ -59,9 +59,9 @@
|
|||||||
"aria": "Velg nylige klassifiseringer",
|
"aria": "Velg nylige klassifiseringer",
|
||||||
"titleShort": "Nylig"
|
"titleShort": "Nylig"
|
||||||
},
|
},
|
||||||
"categories": "Kategorier",
|
"categories": "Klasser",
|
||||||
"createCategory": {
|
"createCategory": {
|
||||||
"new": "Opprett ny kategori"
|
"new": "Opprett ny klasse"
|
||||||
},
|
},
|
||||||
"categorizeImageAs": "Klassifiser bilde som:",
|
"categorizeImageAs": "Klassifiser bilde som:",
|
||||||
"categorizeImage": "Klassifiser bilde",
|
"categorizeImage": "Klassifiser bilde",
|
||||||
@ -98,18 +98,18 @@
|
|||||||
"classificationTypeDesc": "Underetiketter legger til ekstra tekst på objektetiketten (f.eks. 'Person: Posten'). Attributter er søkbare metadata som lagres separat i objektets metadata.",
|
"classificationTypeDesc": "Underetiketter legger til ekstra tekst på objektetiketten (f.eks. 'Person: Posten'). Attributter er søkbare metadata som lagres separat i objektets metadata.",
|
||||||
"classificationSubLabel": "Underetikett",
|
"classificationSubLabel": "Underetikett",
|
||||||
"classificationAttribute": "Attributt",
|
"classificationAttribute": "Attributt",
|
||||||
"classes": "Kategorier",
|
"classes": "Klasser",
|
||||||
"classesTip": "Lær om kategorier",
|
"classesTip": "Lær om klasser",
|
||||||
"classesStateDesc": "Definer de ulike tilstandene kamerasonen kan være i. For eksempel: 'åpen' og 'lukket' for en garasjeport.",
|
"classesStateDesc": "Definer de ulike tilstandene kamerasonen kan være i. For eksempel: 'åpen' og 'lukket' for en garasjeport.",
|
||||||
"classesObjectDesc": "Definer kategoriene du vil klassifisere oppdagede objekter i. For eksempel: 'bud', 'beboer', 'fremmed' for personklassifisering.",
|
"classesObjectDesc": "Definer klassene du vil klassifisere oppdagede objekter i. For eksempel: 'bud', 'beboer', 'fremmed' for personklassifisering.",
|
||||||
"classPlaceholder": "Skriv inn tilstandsnavn...",
|
"classPlaceholder": "Skriv inn klassenavn...",
|
||||||
"errors": {
|
"errors": {
|
||||||
"nameRequired": "Modellnavn er påkrevd",
|
"nameRequired": "Modellnavn er påkrevd",
|
||||||
"nameLength": "Modellnavn må være på 64 tegn eller mindre",
|
"nameLength": "Modellnavn må være på 64 tegn eller mindre",
|
||||||
"nameOnlyNumbers": "Modellnavn kan ikke bare inneholde tall",
|
"nameOnlyNumbers": "Modellnavn kan ikke bare inneholde tall",
|
||||||
"classRequired": "Minst én kategori er påkrevd",
|
"classRequired": "Minst én klasse er påkrevd",
|
||||||
"classesUnique": "Kategorinavn må være unike",
|
"classesUnique": "Klassenavn må være unike",
|
||||||
"stateRequiresTwoClasses": "Tilstandsmodeller krever minst to kategorier",
|
"stateRequiresTwoClasses": "Tilstandsmodeller krever minst to klasser",
|
||||||
"objectLabelRequired": "Velg en objektetikett",
|
"objectLabelRequired": "Velg en objektetikett",
|
||||||
"objectTypeRequired": "Velg en klassifiseringstype"
|
"objectTypeRequired": "Velg en klassifiseringstype"
|
||||||
},
|
},
|
||||||
@ -124,7 +124,7 @@
|
|||||||
},
|
},
|
||||||
"step3": {
|
"step3": {
|
||||||
"selectImagesPrompt": "Velg alle bilder med: {{className}}",
|
"selectImagesPrompt": "Velg alle bilder med: {{className}}",
|
||||||
"selectImagesDescription": "Klikk på bilder for å velge dem. Klikk Fortsett når du er ferdig med denne kategorien.",
|
"selectImagesDescription": "Klikk på bilder for å velge dem. Klikk Fortsett når du er ferdig med denne klassen.",
|
||||||
"generating": {
|
"generating": {
|
||||||
"title": "Genererer eksempelbilder",
|
"title": "Genererer eksempelbilder",
|
||||||
"description": "Frigate henter representative bilder fra opptakene dine. Dette kan ta litt tid..."
|
"description": "Frigate henter representative bilder fra opptakene dine. Dette kan ta litt tid..."
|
||||||
@ -146,7 +146,12 @@
|
|||||||
},
|
},
|
||||||
"generateSuccess": "Eksempelbilder ble generert",
|
"generateSuccess": "Eksempelbilder ble generert",
|
||||||
"allImagesRequired_one": "Vennligst klassifiser alle bildene. {{count}} bilde gjenstår.",
|
"allImagesRequired_one": "Vennligst klassifiser alle bildene. {{count}} bilde gjenstår.",
|
||||||
"allImagesRequired_other": "Vennligst klassifiser alle bildene. {{count}} bilder gjenstår."
|
"allImagesRequired_other": "Vennligst klassifiser alle bildene. {{count}} bilder gjenstår.",
|
||||||
|
"modelCreated": "Modellen ble opprettet. Bruk visningen Nylige klassifiseringer for å legge til bilder for manglende tilstander, og tren deretter modellen.",
|
||||||
|
"missingStatesWarning": {
|
||||||
|
"title": "Manglende tilstandseksempler",
|
||||||
|
"description": "Du har ikke valgt eksempler for alle tilstander. Modellen vil ikke trenes før alle tilstander har bilder. Når du har gått videre, bruk visningen Nylige klassifiseringer til å klassifisere bilder for de manglende tilstandene, og tren deretter modellen."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deleteModel": {
|
"deleteModel": {
|
||||||
@ -159,7 +164,7 @@
|
|||||||
"states": "Tilstander"
|
"states": "Tilstander"
|
||||||
},
|
},
|
||||||
"details": {
|
"details": {
|
||||||
"scoreInfo": "Poengsummen representerer gjennomsnittlig klassifiseringskonfidens på tvers av alle deteksjoner av dette objektet."
|
"scoreInfo": "Score representerer gjennomsnittlig klassifiseringskonfidens på tvers av alle deteksjoner av dette objektet."
|
||||||
},
|
},
|
||||||
"tooltip": {
|
"tooltip": {
|
||||||
"trainingInProgress": "Modellen trenes for øyeblikket",
|
"trainingInProgress": "Modellen trenes for øyeblikket",
|
||||||
|
|||||||
@ -55,5 +55,8 @@
|
|||||||
"clickToSeek": "Klikk for å gå til dette tidspunktet"
|
"clickToSeek": "Klikk for å gå til dette tidspunktet"
|
||||||
},
|
},
|
||||||
"zoomIn": "Zoom inn",
|
"zoomIn": "Zoom inn",
|
||||||
"zoomOut": "Zoom ut"
|
"zoomOut": "Zoom ut",
|
||||||
|
"normalActivity": "Normal",
|
||||||
|
"needsReview": "Trenger inspeksjon",
|
||||||
|
"securityConcern": "Sikkerhetsrisiko"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -90,7 +90,7 @@
|
|||||||
"updatedSublabel": "Underetikett ble oppdatert.",
|
"updatedSublabel": "Underetikett ble oppdatert.",
|
||||||
"updatedLPR": "Vellykket oppdatering av kjennemerke.",
|
"updatedLPR": "Vellykket oppdatering av kjennemerke.",
|
||||||
"regenerate": "En ny beskrivelse har blitt anmodet fra {{provider}}. Avhengig av hastigheten til leverandøren din, kan den nye beskrivelsen ta litt tid å regenerere.",
|
"regenerate": "En ny beskrivelse har blitt anmodet fra {{provider}}. Avhengig av hastigheten til leverandøren din, kan den nye beskrivelsen ta litt tid å regenerere.",
|
||||||
"audioTranscription": "Lydtranskripsjon ble forespurt."
|
"audioTranscription": "Lydtranskripsjon ble forespurt. Avhengig av ytelsen på din Frigate server kan transkripsjonen ta noe tid å fullføre."
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"regenerate": "Feil ved anrop til {{provider}} for en ny beskrivelse: {{errorMessage}}",
|
"regenerate": "Feil ved anrop til {{provider}} for en ny beskrivelse: {{errorMessage}}",
|
||||||
@ -107,8 +107,8 @@
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
"topScore": {
|
"topScore": {
|
||||||
"info": "Den høyeste poengsummen er den høyeste medianverdi for det sporede objektet, så denne kan avvike fra poengsummen som vises på miniatyrbildet for søkeresultatet.",
|
"info": "Toppscoren er den høyeste medianverdien for det sporede objektet, så denne kan avvike fra scoren som vises på miniatyrbildet i søkeresultatet.",
|
||||||
"label": "Høyeste poengsum"
|
"label": "Toppscore"
|
||||||
},
|
},
|
||||||
"estimatedSpeed": "Estimert hastighet",
|
"estimatedSpeed": "Estimert hastighet",
|
||||||
"objects": "Objekter",
|
"objects": "Objekter",
|
||||||
@ -147,10 +147,10 @@
|
|||||||
"descNoLabel": "Angi en ny underetikett for dette sporede objektet"
|
"descNoLabel": "Angi en ny underetikett for dette sporede objektet"
|
||||||
},
|
},
|
||||||
"snapshotScore": {
|
"snapshotScore": {
|
||||||
"label": "Øyeblikksbilde poengsum"
|
"label": "Øyeblikksbilde score"
|
||||||
},
|
},
|
||||||
"score": {
|
"score": {
|
||||||
"label": "Poengsum"
|
"label": "Score"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"itemMenu": {
|
"itemMenu": {
|
||||||
@ -261,7 +261,8 @@
|
|||||||
"header": {
|
"header": {
|
||||||
"zones": "Soner",
|
"zones": "Soner",
|
||||||
"ratio": "Forhold",
|
"ratio": "Forhold",
|
||||||
"area": "Område"
|
"area": "Område",
|
||||||
|
"score": "Score"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"annotationSettings": {
|
"annotationSettings": {
|
||||||
|
|||||||
@ -11,7 +11,7 @@
|
|||||||
"face": "Ansiktsdetaljer",
|
"face": "Ansiktsdetaljer",
|
||||||
"faceDesc": "Detaljer for sporet objekt som genererte dette ansiktet",
|
"faceDesc": "Detaljer for sporet objekt som genererte dette ansiktet",
|
||||||
"timestamp": "Tidsstempel",
|
"timestamp": "Tidsstempel",
|
||||||
"scoreInfo": "Under-merkelappens poengsum er basert på en vektet sum ut ifra hvor sikre gjenkjenningene av ansiktene er, så den kan avvike fra poengsummen som vises på øyeblikksbildet.",
|
"scoreInfo": "Score er et vektet gjennomsnitt av alle ansiktsscorer, vektet etter størrelsen på ansiktet i hvert bilde.",
|
||||||
"subLabelScore": "Poengsum for under-merkelapp",
|
"subLabelScore": "Poengsum for under-merkelapp",
|
||||||
"unknown": "Ukjent"
|
"unknown": "Ukjent"
|
||||||
},
|
},
|
||||||
@ -38,7 +38,7 @@
|
|||||||
"deleteFaceFailed": "Kunne ikke slette: {{errorMessage}}",
|
"deleteFaceFailed": "Kunne ikke slette: {{errorMessage}}",
|
||||||
"uploadingImageFailed": "Kunne ikke laste opp bilde: {{errorMessage}}",
|
"uploadingImageFailed": "Kunne ikke laste opp bilde: {{errorMessage}}",
|
||||||
"trainFailed": "Kunne ikke trene: {{errorMessage}}",
|
"trainFailed": "Kunne ikke trene: {{errorMessage}}",
|
||||||
"updateFaceScoreFailed": "Kunne ikke oppdatere ansiktsskåring: {{errorMessage}}",
|
"updateFaceScoreFailed": "Kunne ikke oppdatere ansiktsscore: {{errorMessage}}",
|
||||||
"addFaceLibraryFailed": "Kunne ikke angi ansiktsnavn: {{errorMessage}}",
|
"addFaceLibraryFailed": "Kunne ikke angi ansiktsnavn: {{errorMessage}}",
|
||||||
"deleteNameFailed": "Kunne ikke slette navn: {{errorMessage}}",
|
"deleteNameFailed": "Kunne ikke slette navn: {{errorMessage}}",
|
||||||
"renameFaceFailed": "Kunne ikke gi nytt navn til ansikt: {{errorMessage}}"
|
"renameFaceFailed": "Kunne ikke gi nytt navn til ansikt: {{errorMessage}}"
|
||||||
@ -49,7 +49,7 @@
|
|||||||
"deletedName_one": "{{count}} ansikt ble slettet.",
|
"deletedName_one": "{{count}} ansikt ble slettet.",
|
||||||
"deletedName_other": "{{count}} ansikter ble slettet.",
|
"deletedName_other": "{{count}} ansikter ble slettet.",
|
||||||
"trainedFace": "Ansiktet ble trent.",
|
"trainedFace": "Ansiktet ble trent.",
|
||||||
"updatedFaceScore": "Ansiktsskåring ble oppdatert til {{name}} ({{score}}).",
|
"updatedFaceScore": "Oppdaterte ansiktsscore for {{name}} ({{score}}).",
|
||||||
"uploadedImage": "Bildet ble lastet opp.",
|
"uploadedImage": "Bildet ble lastet opp.",
|
||||||
"addFaceLibrary": "{{name}} ble lagt til i ansiktsbiblioteket!",
|
"addFaceLibrary": "{{name}} ble lagt til i ansiktsbiblioteket!",
|
||||||
"renamedFace": "Nytt navn ble gitt til ansikt {{name}}"
|
"renamedFace": "Nytt navn ble gitt til ansikt {{name}}"
|
||||||
|
|||||||
@ -15,8 +15,8 @@
|
|||||||
"labels": "Etiketter",
|
"labels": "Etiketter",
|
||||||
"search_type": "Søketype",
|
"search_type": "Søketype",
|
||||||
"after": "Etter",
|
"after": "Etter",
|
||||||
"min_score": "Min. poengsum",
|
"min_score": "Min. score",
|
||||||
"max_score": "Maks. poengsum",
|
"max_score": "Maks. score",
|
||||||
"min_speed": "Min. hastighet",
|
"min_speed": "Min. hastighet",
|
||||||
"zones": "Soner",
|
"zones": "Soner",
|
||||||
"sub_labels": "Underetiketter",
|
"sub_labels": "Underetiketter",
|
||||||
@ -36,8 +36,8 @@
|
|||||||
"minSpeedMustBeLessOrEqualMaxSpeed": "Minimum hastighet 'min_speed' må være mindre enn eller lik maksimum hastighet 'max_speed'.",
|
"minSpeedMustBeLessOrEqualMaxSpeed": "Minimum hastighet 'min_speed' må være mindre enn eller lik maksimum hastighet 'max_speed'.",
|
||||||
"beforeDateBeLaterAfter": "Før-datoen 'before' må være senere enn etter-datoen 'after'.",
|
"beforeDateBeLaterAfter": "Før-datoen 'before' må være senere enn etter-datoen 'after'.",
|
||||||
"afterDatebeEarlierBefore": "Etter-datoen 'after' må være tidligere enn før-datoen 'before'.",
|
"afterDatebeEarlierBefore": "Etter-datoen 'after' må være tidligere enn før-datoen 'before'.",
|
||||||
"minScoreMustBeLessOrEqualMaxScore": "Minimum poengsum 'min_score' må være mindre enn eller lik maksimum poengsum 'max_score'.",
|
"minScoreMustBeLessOrEqualMaxScore": "Minimum score 'min_score' må være mindre enn eller lik maksimum score 'max_score'.",
|
||||||
"maxScoreMustBeGreaterOrEqualMinScore": "Maksimum poengsum 'max_score' må være større enn eller lik minimum poengsum 'min_score'.",
|
"maxScoreMustBeGreaterOrEqualMinScore": "Maksimum score 'max_score' må være større enn eller lik minimum score 'min_score'.",
|
||||||
"maxSpeedMustBeGreaterOrEqualMinSpeed": "Maksimum hastighet 'max_speed' må være større enn eller lik minimum hastighet 'min_speed'."
|
"maxSpeedMustBeGreaterOrEqualMinSpeed": "Maksimum hastighet 'max_speed' må være større enn eller lik minimum hastighet 'min_speed'."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
@ -460,7 +460,7 @@
|
|||||||
},
|
},
|
||||||
"objectShapeFilterDrawing": {
|
"objectShapeFilterDrawing": {
|
||||||
"document": "Se dokumentasjonen ",
|
"document": "Se dokumentasjonen ",
|
||||||
"score": "Poengsum",
|
"score": "Score",
|
||||||
"ratio": "Forhold",
|
"ratio": "Forhold",
|
||||||
"area": "Areal",
|
"area": "Areal",
|
||||||
"title": "Tegning av objektformfilter",
|
"title": "Tegning av objektformfilter",
|
||||||
@ -478,7 +478,7 @@
|
|||||||
"audio": {
|
"audio": {
|
||||||
"title": "Lyd",
|
"title": "Lyd",
|
||||||
"noAudioDetections": "Ingen lyddeteksjoner",
|
"noAudioDetections": "Ingen lyddeteksjoner",
|
||||||
"score": "poengsum",
|
"score": "score",
|
||||||
"currentRMS": "Nåværende RMS",
|
"currentRMS": "Nåværende RMS",
|
||||||
"currentdbFS": "Nåværende dbFS"
|
"currentdbFS": "Nåværende dbFS"
|
||||||
},
|
},
|
||||||
|
|||||||
@ -76,7 +76,7 @@
|
|||||||
"npuMemory": "NPU minne",
|
"npuMemory": "NPU minne",
|
||||||
"npuUsage": "NPU belastning",
|
"npuUsage": "NPU belastning",
|
||||||
"intelGpuWarning": {
|
"intelGpuWarning": {
|
||||||
"title": "Advarsel om Intel GPU-statistikk",
|
"title": "Til info om Intel GPU-statistikk",
|
||||||
"message": "GPU statistikk ikke tilgjengelig",
|
"message": "GPU statistikk ikke tilgjengelig",
|
||||||
"description": "Dette er en kjent feil i Intels verktøy for rapportering av GPU-statistikk (intel_gpu_top), der verktøyet slutter å fungere og gjentatte ganger viser 0 % GPU-bruk, selv om maskinvareakselerasjon og objektdeteksjon kjører korrekt på (i)GPU-en. Dette er ikke en feil i Frigate. Du kan starte verten på nytt for å løse problemet midlertidig, og for å bekrefte at GPU-en fungerer som den skal. Dette påvirker ikke ytelsen."
|
"description": "Dette er en kjent feil i Intels verktøy for rapportering av GPU-statistikk (intel_gpu_top), der verktøyet slutter å fungere og gjentatte ganger viser 0 % GPU-bruk, selv om maskinvareakselerasjon og objektdeteksjon kjører korrekt på (i)GPU-en. Dette er ikke en feil i Frigate. Du kan starte verten på nytt for å løse problemet midlertidig, og for å bekrefte at GPU-en fungerer som den skal. Dette påvirker ikke ytelsen."
|
||||||
}
|
}
|
||||||
|
|||||||
@ -65,7 +65,8 @@
|
|||||||
"noVaildTimeSelected": "Geen geldig tijdsbereik geselecteerd",
|
"noVaildTimeSelected": "Geen geldig tijdsbereik geselecteerd",
|
||||||
"endTimeMustAfterStartTime": "Eindtijd moet na starttijd zijn"
|
"endTimeMustAfterStartTime": "Eindtijd moet na starttijd zijn"
|
||||||
},
|
},
|
||||||
"success": "Export is succesvol gestart. Bekijk het bestand op de exportpagina."
|
"success": "Export is succesvol gestart. Bekijk het bestand op de exportpagina.",
|
||||||
|
"view": "Weergeven"
|
||||||
},
|
},
|
||||||
"fromTimeline": {
|
"fromTimeline": {
|
||||||
"saveExport": "Export opslaan",
|
"saveExport": "Export opslaan",
|
||||||
|
|||||||
@ -148,7 +148,12 @@
|
|||||||
},
|
},
|
||||||
"generateSuccess": "Met succes gegenereerde voorbeeldafbeeldingen",
|
"generateSuccess": "Met succes gegenereerde voorbeeldafbeeldingen",
|
||||||
"allImagesRequired_one": "Classificeer alle afbeeldingen. {{count}} afbeelding resterend.",
|
"allImagesRequired_one": "Classificeer alle afbeeldingen. {{count}} afbeelding resterend.",
|
||||||
"allImagesRequired_other": "Classificeer alle afbeeldingen. {{count}} afbeeldingen resterend."
|
"allImagesRequired_other": "Classificeer alle afbeeldingen. {{count}} afbeeldingen resterend.",
|
||||||
|
"modelCreated": "Model succesvol aangemaakt. Gebruik de weergave Recente classificaties om afbeeldingen voor ontbrekende statussen toe te voegen en train vervolgens het model.",
|
||||||
|
"missingStatesWarning": {
|
||||||
|
"title": "Voorbeelden van ontbrekende staten",
|
||||||
|
"description": "Je hebt geen voorbeelden geselecteerd voor alle staten. Het model wordt pas getraind wanneer alle staten afbeeldingen hebben. Ga je verder, gebruik dan de weergave Recente Classificaties om afbeeldingen voor de ontbrekende staten te classificeren en train daarna het model."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deleteModel": {
|
"deleteModel": {
|
||||||
|
|||||||
@ -55,5 +55,8 @@
|
|||||||
"clickToSeek": "Klik om naar deze tijd te zoeken"
|
"clickToSeek": "Klik om naar deze tijd te zoeken"
|
||||||
},
|
},
|
||||||
"zoomIn": "Zoom in",
|
"zoomIn": "Zoom in",
|
||||||
"zoomOut": "Zoom uit"
|
"zoomOut": "Zoom uit",
|
||||||
|
"normalActivity": "Normaal",
|
||||||
|
"needsReview": "Heeft een beoordeling nodig",
|
||||||
|
"securityConcern": "Beveiligingsprobleem"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -207,6 +207,10 @@
|
|||||||
"viewTrackingDetails": {
|
"viewTrackingDetails": {
|
||||||
"label": "Bekijk trackinggegevens",
|
"label": "Bekijk trackinggegevens",
|
||||||
"aria": "Toon de trackinggegevens"
|
"aria": "Toon de trackinggegevens"
|
||||||
|
},
|
||||||
|
"downloadCleanSnapshot": {
|
||||||
|
"label": "Download schone snapshot",
|
||||||
|
"aria": "Download schone snapshot"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"noTrackedObjects": "Geen gevolgde objecten gevonden",
|
"noTrackedObjects": "Geen gevolgde objecten gevonden",
|
||||||
@ -261,7 +265,8 @@
|
|||||||
"header": {
|
"header": {
|
||||||
"zones": "Zones",
|
"zones": "Zones",
|
||||||
"ratio": "Verhouding",
|
"ratio": "Verhouding",
|
||||||
"area": "Gebied"
|
"area": "Gebied",
|
||||||
|
"score": "Score"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"annotationSettings": {
|
"annotationSettings": {
|
||||||
|
|||||||
@ -87,7 +87,10 @@
|
|||||||
"formattedTimestampMonthDayYear": {
|
"formattedTimestampMonthDayYear": {
|
||||||
"12hour": "d MMMM yyyy",
|
"12hour": "d MMMM yyyy",
|
||||||
"24hour": "d MMMM yyyy"
|
"24hour": "d MMMM yyyy"
|
||||||
}
|
},
|
||||||
|
"inProgress": "W trakcie",
|
||||||
|
"invalidStartTime": "Nieprawidłowy czas rozpoczęcia",
|
||||||
|
"invalidEndTime": "Nieprawidłowy czas zakończenia"
|
||||||
},
|
},
|
||||||
"unit": {
|
"unit": {
|
||||||
"speed": {
|
"speed": {
|
||||||
@ -97,10 +100,23 @@
|
|||||||
"length": {
|
"length": {
|
||||||
"feet": "stopy",
|
"feet": "stopy",
|
||||||
"meters": "metry"
|
"meters": "metry"
|
||||||
|
},
|
||||||
|
"data": {
|
||||||
|
"kbps": "kB/s",
|
||||||
|
"mbps": "MB/s",
|
||||||
|
"gbps": "GB/s",
|
||||||
|
"kbph": "kB/godz.",
|
||||||
|
"mbph": "MB/godz.",
|
||||||
|
"gbph": "GB/godz."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"label": {
|
"label": {
|
||||||
"back": "Wróć"
|
"back": "Wróć",
|
||||||
|
"hide": "Ukryj {{item}}",
|
||||||
|
"show": "Pokaż {{item}}",
|
||||||
|
"ID": "ID",
|
||||||
|
"none": "Brak",
|
||||||
|
"all": "Wszystko"
|
||||||
},
|
},
|
||||||
"button": {
|
"button": {
|
||||||
"apply": "Zastosuj",
|
"apply": "Zastosuj",
|
||||||
@ -137,7 +153,8 @@
|
|||||||
"cameraAudio": "Dźwięk kamery",
|
"cameraAudio": "Dźwięk kamery",
|
||||||
"off": "WYŁĄCZ",
|
"off": "WYŁĄCZ",
|
||||||
"edit": "Edytuj",
|
"edit": "Edytuj",
|
||||||
"copyCoordinates": "Kopiuj współrzędne"
|
"copyCoordinates": "Kopiuj współrzędne",
|
||||||
|
"continue": "Kontynuuj"
|
||||||
},
|
},
|
||||||
"menu": {
|
"menu": {
|
||||||
"system": "System",
|
"system": "System",
|
||||||
@ -239,7 +256,8 @@
|
|||||||
"configurationEditor": "Edytor konfiguracji",
|
"configurationEditor": "Edytor konfiguracji",
|
||||||
"help": "Pomoc",
|
"help": "Pomoc",
|
||||||
"settings": "Ustawienia",
|
"settings": "Ustawienia",
|
||||||
"export": "Eksportuj"
|
"export": "Eksportuj",
|
||||||
|
"classification": "Klasyfikacja"
|
||||||
},
|
},
|
||||||
"role": {
|
"role": {
|
||||||
"viewer": "Przeglądający",
|
"viewer": "Przeglądający",
|
||||||
@ -283,5 +301,9 @@
|
|||||||
"readTheDocumentation": "Przeczytaj dokumentację",
|
"readTheDocumentation": "Przeczytaj dokumentację",
|
||||||
"information": {
|
"information": {
|
||||||
"pixels": "{{area}}px"
|
"pixels": "{{area}}px"
|
||||||
|
},
|
||||||
|
"list": {
|
||||||
|
"two": "{{0}} i {{1}}",
|
||||||
|
"many": "{{items}}, oraz {{last}}"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -3,7 +3,7 @@
|
|||||||
"button": {
|
"button": {
|
||||||
"deleteClassificationAttempts": "Usuń obrazy klasyfikacyjne",
|
"deleteClassificationAttempts": "Usuń obrazy klasyfikacyjne",
|
||||||
"renameCategory": "Zmień nazwę klasy",
|
"renameCategory": "Zmień nazwę klasy",
|
||||||
"deleteCategory": "Usuń klasę",
|
"deleteCategory": "Usuń klasyfikację",
|
||||||
"deleteImages": "Usuń obrazy",
|
"deleteImages": "Usuń obrazy",
|
||||||
"trainModel": "Przeszkol model",
|
"trainModel": "Przeszkol model",
|
||||||
"addClassification": "Dodaj klasyfikację",
|
"addClassification": "Dodaj klasyfikację",
|
||||||
@ -39,7 +39,9 @@
|
|||||||
},
|
},
|
||||||
"deleteCategory": {
|
"deleteCategory": {
|
||||||
"title": "Usuń klasę",
|
"title": "Usuń klasę",
|
||||||
"desc": "Czy na pewno chcesz usunąć klasę {{name}}? Spowoduje to trawałe usunięcie wszystkich powiązanych obrazków i konieczność ponownego trenowania modelu."
|
"desc": "Czy na pewno chcesz usunąć klasę {{name}}? Spowoduje to trawałe usunięcie wszystkich powiązanych obrazków i konieczność ponownego trenowania modelu.",
|
||||||
|
"minClassesTitle": "Nie można usunąć kategorii",
|
||||||
|
"minClassesDesc": "Model klasyfikacyjny musi posiadać co najmniej dwie kategorie. Dodaj inną kategorię aby możliwe było usunięcie tej kategorii."
|
||||||
},
|
},
|
||||||
"deleteModel": {
|
"deleteModel": {
|
||||||
"title": "Usuń model klasyfikacji",
|
"title": "Usuń model klasyfikacji",
|
||||||
@ -49,10 +51,29 @@
|
|||||||
"desc_many": "Czy na pewno chcesz usunąć {{count}} modeli? Spowoduje to trwałe usunięcie wszystkich powiązanych danych, włącznie z obrazami i danymi treningowymi. Nie można cofnąć tej operacji."
|
"desc_many": "Czy na pewno chcesz usunąć {{count}} modeli? Spowoduje to trwałe usunięcie wszystkich powiązanych danych, włącznie z obrazami i danymi treningowymi. Nie można cofnąć tej operacji."
|
||||||
},
|
},
|
||||||
"edit": {
|
"edit": {
|
||||||
"title": "Edytuj model klasyfikacji"
|
"title": "Edytuj model klasyfikacji",
|
||||||
|
"descriptionObject": "Zmień typ obiektu i kryteria dla tego modelu klasyfikacji.",
|
||||||
|
"stateClassesInfo": "Uwaga: Zmiana typu klasyfikacji wymaga treningu nowego modelu."
|
||||||
},
|
},
|
||||||
"tooltip": {
|
"tooltip": {
|
||||||
"trainingInProgress": "Trwa trenowanie modelu",
|
"trainingInProgress": "Trwa trenowanie modelu",
|
||||||
"modelNotReady": "Mode nie jest gotowy do trenowania"
|
"modelNotReady": "Mode nie jest gotowy do trenowania",
|
||||||
|
"noChanges": "Brak zmian w zbiorze danych od czasu ostatniego treningu."
|
||||||
|
},
|
||||||
|
"deleteDatasetImages": {
|
||||||
|
"title": "Usuń obrazy z puli danych"
|
||||||
|
},
|
||||||
|
"renameCategory": {
|
||||||
|
"title": "Zmień nazwę klasy",
|
||||||
|
"desc": "Wprowadź nową nazwę dla {{name}}. Zastosowanie tej zmiany wymagać będzie treningu nowego modelu."
|
||||||
|
},
|
||||||
|
"description": {
|
||||||
|
"invalidName": "Niepoprawna nazwa. Nazwy mogą zawierać tylko: litery, cyfry, spacje, cudzysłowy, podkreślniniki i myślniki."
|
||||||
|
},
|
||||||
|
"train": {
|
||||||
|
"title": "Ostatnie Klasyfikacje"
|
||||||
|
},
|
||||||
|
"createCategory": {
|
||||||
|
"new": "Stwórz nową klasyfikację"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -43,8 +43,8 @@
|
|||||||
"label": "Szczegóły",
|
"label": "Szczegóły",
|
||||||
"noDataFound": "Brak szczegółów do przejrzenia",
|
"noDataFound": "Brak szczegółów do przejrzenia",
|
||||||
"aria": "Przełącz widok szczegółów",
|
"aria": "Przełącz widok szczegółów",
|
||||||
"trackedObject_one": "obiekt",
|
"trackedObject_one": "{{count}} obiekt",
|
||||||
"trackedObject_other": "obiekty",
|
"trackedObject_other": "{{count}} obiekty",
|
||||||
"noObjectDetailData": "Brak danych szczegółowych dla obiektu.",
|
"noObjectDetailData": "Brak danych szczegółowych dla obiektu.",
|
||||||
"settings": "Ustawienia widoku szczegółów",
|
"settings": "Ustawienia widoku szczegółów",
|
||||||
"alwaysExpandActive": {
|
"alwaysExpandActive": {
|
||||||
@ -55,5 +55,6 @@
|
|||||||
"objectTrack": {
|
"objectTrack": {
|
||||||
"trackedPoint": "Śledzony punkt",
|
"trackedPoint": "Śledzony punkt",
|
||||||
"clickToSeek": "Kliknij aby przewinąć do tego miejsca"
|
"clickToSeek": "Kliknij aby przewinąć do tego miejsca"
|
||||||
}
|
},
|
||||||
|
"needsReview": "Wymaga manualnego sprawdzenia"
|
||||||
}
|
}
|
||||||
|
|||||||
@ -160,7 +160,8 @@
|
|||||||
"snapshot": "zrzut ekranu",
|
"snapshot": "zrzut ekranu",
|
||||||
"video": "wideo",
|
"video": "wideo",
|
||||||
"object_lifecycle": "cykl życia obiektu",
|
"object_lifecycle": "cykl życia obiektu",
|
||||||
"thumbnail": "miniaturka"
|
"thumbnail": "miniaturka",
|
||||||
|
"tracking_details": "szczegóły śledzenia"
|
||||||
},
|
},
|
||||||
"itemMenu": {
|
"itemMenu": {
|
||||||
"downloadSnapshot": {
|
"downloadSnapshot": {
|
||||||
@ -232,6 +233,29 @@
|
|||||||
"createObjectMask": "Utwórz maskę obiektu",
|
"createObjectMask": "Utwórz maskę obiektu",
|
||||||
"adjustAnnotationSettings": "Dostosuj ustawienia adnotacji",
|
"adjustAnnotationSettings": "Dostosuj ustawienia adnotacji",
|
||||||
"scrollViewTips": "Kliknij, aby zobaczyć najważniejsze momenty cyklu życia tego obiektu.",
|
"scrollViewTips": "Kliknij, aby zobaczyć najważniejsze momenty cyklu życia tego obiektu.",
|
||||||
"count": "{{first}} z {{second}}"
|
"count": "{{first}} z {{second}}",
|
||||||
|
"autoTrackingTips": "Pozycja znacznika obiektu jest niedokładna dla kamer z automatycznym śledzeniem.",
|
||||||
|
"lifecycleItemDesc": {
|
||||||
|
"visible": "Wykryto {{label}}",
|
||||||
|
"entered_zone": "{{label}} pojawił się w {{zones}}",
|
||||||
|
"active": "{{label}} poruszył się",
|
||||||
|
"stationary": "{{label}} zatrzymał się",
|
||||||
|
"attribute": {
|
||||||
|
"faceOrLicense_plate": "Wykryto {{attribute}} dla obiektu {{label}}",
|
||||||
|
"other": "{{label}} został rozpoznany jako {{attribute}}"
|
||||||
|
},
|
||||||
|
"gone": "Utracono śledzenie dla {{label}}",
|
||||||
|
"external": "Wykryto {{label}}",
|
||||||
|
"header": {
|
||||||
|
"zones": "Strefy"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"annotationSettings": {
|
||||||
|
"title": "Ustawienia adnotacji",
|
||||||
|
"showAllZones": {
|
||||||
|
"title": "Pokaż wszystkie strefy",
|
||||||
|
"desc": "Pokazuj linie stref w momencie wejścia obiektu w strefę."
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -3,7 +3,7 @@
|
|||||||
"description": {
|
"description": {
|
||||||
"addFace": "Dodaj nową kolekcję do biblioteki twarzy, przesyłając swoje pierwsze zdjęcie.",
|
"addFace": "Dodaj nową kolekcję do biblioteki twarzy, przesyłając swoje pierwsze zdjęcie.",
|
||||||
"placeholder": "Wprowadź nazwę tej kolekcji",
|
"placeholder": "Wprowadź nazwę tej kolekcji",
|
||||||
"invalidName": "Nieprawidłowa nazwa. Nazwy mogą zawierać tylko litery, cyfry, spacje, apostrofy, podkreślenia oraz myślniki."
|
"invalidName": "Niepoprawna nazwa. Nazwy mogą zawierać tylko: litery, cyfry, spacje, cudzysłowy, podkreślniniki i myślniki."
|
||||||
},
|
},
|
||||||
"details": {
|
"details": {
|
||||||
"person": "Osoba",
|
"person": "Osoba",
|
||||||
|
|||||||
@ -67,7 +67,7 @@
|
|||||||
},
|
},
|
||||||
"manualRecording": {
|
"manualRecording": {
|
||||||
"title": "Nagrywanie na żądanie",
|
"title": "Nagrywanie na żądanie",
|
||||||
"tips": "Rozpocznij ręczne zdarzenie w oparciu o ustawienia przechowywania nagrań tej kamery.",
|
"tips": "Ręcznie rozpocznij zdarzenie w oparciu o ustawienia przechowywania nagrań tej kamery.",
|
||||||
"playInBackground": {
|
"playInBackground": {
|
||||||
"label": "Odtwarzaj w tle",
|
"label": "Odtwarzaj w tle",
|
||||||
"desc": "Włącz tę opcję, aby kontynuować transmisję, gdy odtwarzacz jest ukryty."
|
"desc": "Włącz tę opcję, aby kontynuować transmisję, gdy odtwarzacz jest ukryty."
|
||||||
@ -173,7 +173,17 @@
|
|||||||
},
|
},
|
||||||
"noCameras": {
|
"noCameras": {
|
||||||
"buttonText": "Dodaj kamerę",
|
"buttonText": "Dodaj kamerę",
|
||||||
"description": "Zacznij od podłączenia kamery.",
|
"description": "Zacznij od podłączenia kamery do Frigate.",
|
||||||
"title": "Nie ustawiono żadnej kamery"
|
"title": "Nie skonfigurowano żadnej kamery",
|
||||||
|
"restricted": {
|
||||||
|
"title": "Brak dostępnych kamer",
|
||||||
|
"description": "Nie masz uprawnień aby przeglądać kamery w tej grupie."
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"snapshot": {
|
||||||
|
"takeSnapshot": "Pobierz miniaturę",
|
||||||
|
"captureFailed": "Nie udało się wykonać migawki.",
|
||||||
|
"downloadStarted": "Pobieranie migawki rozpoczęte.",
|
||||||
|
"noVideoSource": "Brak źródeł video dostępnych do wykonania migawki."
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -13,7 +13,7 @@
|
|||||||
"triggers": "Wyzwalacze",
|
"triggers": "Wyzwalacze",
|
||||||
"roles": "Role",
|
"roles": "Role",
|
||||||
"cameraManagement": "Zarządzanie",
|
"cameraManagement": "Zarządzanie",
|
||||||
"cameraReview": "Przejrzyj"
|
"cameraReview": "Przegląd"
|
||||||
},
|
},
|
||||||
"dialog": {
|
"dialog": {
|
||||||
"unsavedChanges": {
|
"unsavedChanges": {
|
||||||
@ -26,7 +26,7 @@
|
|||||||
"noCamera": "Brak Kamery"
|
"noCamera": "Brak Kamery"
|
||||||
},
|
},
|
||||||
"general": {
|
"general": {
|
||||||
"title": "Ustawienia Ogólne",
|
"title": "Ustawienia interfejsu użytkownika",
|
||||||
"storedLayouts": {
|
"storedLayouts": {
|
||||||
"title": "Zapisane Układy",
|
"title": "Zapisane Układy",
|
||||||
"clearAll": "Wyczyść Wszystkie Układy",
|
"clearAll": "Wyczyść Wszystkie Układy",
|
||||||
@ -50,6 +50,14 @@
|
|||||||
"playAlertVideos": {
|
"playAlertVideos": {
|
||||||
"label": "Odtwarzaj Filmy Alarmowe",
|
"label": "Odtwarzaj Filmy Alarmowe",
|
||||||
"desc": "Domyślnie, ostatnie alerty na panelu Na Żywo są odtwarzane jako małe zapętlone filmy. Wyłącz tę opcję, aby pokazywać tylko statyczny obraz ostatnich alertów na tym urządzeniu/przeglądarce."
|
"desc": "Domyślnie, ostatnie alerty na panelu Na Żywo są odtwarzane jako małe zapętlone filmy. Wyłącz tę opcję, aby pokazywać tylko statyczny obraz ostatnich alertów na tym urządzeniu/przeglądarce."
|
||||||
|
},
|
||||||
|
"displayCameraNames": {
|
||||||
|
"label": "Zawsze pokazuj nazwy kamer",
|
||||||
|
"desc": "Zawsze pokazuj nazwę kamery w widoku wielu kamer."
|
||||||
|
},
|
||||||
|
"liveFallbackTimeout": {
|
||||||
|
"label": "Przekroczono czas oczekiwania dla strumienia",
|
||||||
|
"desc": "W wypadku utraty strumienia wysokiej jakości, użyj trybu niskiej przepustowości po X sekund od utracenia połączenia. Sugerowana wartość: 3."
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"cameraGroupStreaming": {
|
"cameraGroupStreaming": {
|
||||||
@ -906,5 +914,222 @@
|
|||||||
"title": "Wyszukiwanie semantyczne jest zablokowane",
|
"title": "Wyszukiwanie semantyczne jest zablokowane",
|
||||||
"desc": "Wyszukiwanie semantyczne musi być włączone, aby korzystać z triggerów."
|
"desc": "Wyszukiwanie semantyczne musi być włączone, aby korzystać z triggerów."
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"cameraWizard": {
|
||||||
|
"title": "Dodaj kamerę",
|
||||||
|
"steps": {
|
||||||
|
"streamConfiguration": "Konfiguracja strumienia",
|
||||||
|
"nameAndConnection": "Nazwa i połączenie",
|
||||||
|
"probeOrSnapshot": "Sonda lub migawka",
|
||||||
|
"validationAndTesting": "Walidacja i testowanie"
|
||||||
|
},
|
||||||
|
"save": {
|
||||||
|
"success": "Zapisano ustawienia nowej kamery {{cameraName}}.",
|
||||||
|
"failure": "Błąd zapisu {{cameraName}}."
|
||||||
|
},
|
||||||
|
"testResultLabels": {
|
||||||
|
"resolution": "Rozdzielczość",
|
||||||
|
"fps": "kl./s",
|
||||||
|
"video": "Wideo",
|
||||||
|
"audio": "Audio"
|
||||||
|
},
|
||||||
|
"commonErrors": {
|
||||||
|
"noUrl": "Podaj poprawny adres URL",
|
||||||
|
"testFailed": "Negatywny wynik testu strumienia: {{error}}"
|
||||||
|
},
|
||||||
|
"step1": {
|
||||||
|
"cameraName": "Nazwa kamery",
|
||||||
|
"cameraNamePlaceholder": "np. drzwi_frontowe lub Ogród",
|
||||||
|
"host": "Host/Adres IP",
|
||||||
|
"port": "Port",
|
||||||
|
"username": "Nazwa użytkownika",
|
||||||
|
"usernamePlaceholder": "Opcjonalne",
|
||||||
|
"password": "Hasło",
|
||||||
|
"passwordPlaceholder": "Opcjonalne",
|
||||||
|
"selectTransport": "Wybierz protokół warstwy transportowej",
|
||||||
|
"cameraBrand": "Marka Kamery",
|
||||||
|
"selectBrand": "Wybierz markę kamery aby dostosować wzór adresu URL",
|
||||||
|
"customUrl": "Niestandardowy adres URL strumienia",
|
||||||
|
"brandInformation": "Informacje o marce",
|
||||||
|
"brandUrlFormat": "Dla kamer z formatem RTSP, formatuj URL jako: {{exampleUrl}}",
|
||||||
|
"customUrlPlaceholder": "rtsp://nazwa_użytkownika:hasło@host:port/scieżka",
|
||||||
|
"connectionSettings": "Ustawienia Połączenia",
|
||||||
|
"detectionMethod": "Metoda wykrywania strumienia",
|
||||||
|
"onvifPort": "Port ONVIF",
|
||||||
|
"manualMode": "Ręczny wybór",
|
||||||
|
"onvifPortDescription": "Dla kamer wspierających protokół ONVIF, port to zazwyczaj 80 lub 8080.",
|
||||||
|
"errors": {
|
||||||
|
"brandOrCustomUrlRequired": "Wybierz markę kamery oraz host/adres IP lub wybierz 'Inny' i podaj niestandardowy adres URL",
|
||||||
|
"nameRequired": "Wymagana nazwa kamery",
|
||||||
|
"nameLength": "Nazwa kamery musi mieć 64 lub mniej znaków",
|
||||||
|
"invalidCharacters": "Nazwa kamery zawiera niepoprawne znaki",
|
||||||
|
"nameExists": "Nazwa kamery jest już zajęta",
|
||||||
|
"customUrlRtspRequired": "Niestandardowe adresy URL muszą zaczynać się od \"rtsp://\". Ręczna konfiguracja wymagana jest dla strumieniów innych niż RTSP."
|
||||||
|
},
|
||||||
|
"description": "Wprowadź szczegóły kamery i wybierz autodetekcję lub ręcznie wybierz firmę.",
|
||||||
|
"probeMode": "Wykryj kamerę",
|
||||||
|
"detectionMethodDescription": "Wykryj kamerę za pomocą ONVIF (jeśli wspierane) by znaleźć adresy strumieni lub wybierz ręcznie markę kamery by wybrać predefiniowane adresy. By wpisać własny adres strumienia RTSP użyj ręcznej metody i wybierz \"Inne\".",
|
||||||
|
"useDigestAuth": "Użyj przesyłania skrótu autentykacji",
|
||||||
|
"useDigestAuthDescription": "Użyj przesyłania skrótu logowania HTTP dla ONVIF. Niektóre kamery mogą wymagać dedykowanego użytkownika i hasła ONVIF zamiast standardowego konta admin."
|
||||||
|
},
|
||||||
|
"step2": {
|
||||||
|
"testSuccess": "Test połączenia udany!",
|
||||||
|
"testFailed": "Test połączenia nieudany. Sprawdź adres źródła obrazu i spróbuj ponownie.",
|
||||||
|
"testFailedTitle": "Test Nieudany",
|
||||||
|
"streamDetails": "Szczegóły Strumienia",
|
||||||
|
"testing": {
|
||||||
|
"fetchingSnapshot": "Przygotowywanie migawki kamery...",
|
||||||
|
"probingMetadata": "Wykrywanie metadanych kamery..."
|
||||||
|
},
|
||||||
|
"deviceInfo": "Informacje o urządzeniu",
|
||||||
|
"manufacturer": "Producent",
|
||||||
|
"model": "Model",
|
||||||
|
"firmware": "Firmware",
|
||||||
|
"profiles": "Profile",
|
||||||
|
"ptzSupport": "Wsparcie PTZ",
|
||||||
|
"autotrackingSupport": "Wsparcie auto-śledzenia",
|
||||||
|
"uriCopy": "Kopiuj",
|
||||||
|
"uriCopied": "Adres URL skopiowano do schowka",
|
||||||
|
"testConnection": "Przetestuj połączenie",
|
||||||
|
"errors": {
|
||||||
|
"hostRequired": "Wymagany jest Host/Adres IP"
|
||||||
|
},
|
||||||
|
"description": "Wykryj dostępne strumienie kamery lub skonfiguruj ręcznie ustawienia na podstawie wybranej metody detekcji.",
|
||||||
|
"probing": "Wykrywanie kamery...",
|
||||||
|
"retry": "Ponów",
|
||||||
|
"probeFailed": "Błąd wykrywania kamery: {{error}}",
|
||||||
|
"probingDevice": "Wykrywanie urządzenia...",
|
||||||
|
"probeSuccessful": "Wykrywanie udane",
|
||||||
|
"probeError": "Błąd wykrywania",
|
||||||
|
"probeNoSuccess": "Niepowodzenie wykrywania",
|
||||||
|
"presets": "Ustawienia wstępne"
|
||||||
|
},
|
||||||
|
"step3": {
|
||||||
|
"streamTitle": "Strumień numer: {{number}}",
|
||||||
|
"streamUrl": "URL strumienia",
|
||||||
|
"streamUrlPlaceholder": "rtsp://nazwa_użytkownika:hasło@host:port/scieżka",
|
||||||
|
"selectStream": "Wybierz strumień",
|
||||||
|
"noStreamFound": "Nie znaleziono żadnego strumienia",
|
||||||
|
"url": "adres URL",
|
||||||
|
"resolution": "Rozdzielczość",
|
||||||
|
"selectResolution": "Wybierz rozdzielczość",
|
||||||
|
"quality": "Jakość",
|
||||||
|
"selectQuality": "wybierz jakość",
|
||||||
|
"roles": "Role",
|
||||||
|
"roleLabels": {
|
||||||
|
"detect": "Wykrywanie obiektów",
|
||||||
|
"record": "Nagrywanie",
|
||||||
|
"audio": "Dźwięk"
|
||||||
|
},
|
||||||
|
"testStream": "Przetestuj połączenie",
|
||||||
|
"testSuccess": "Test strumienia udany!",
|
||||||
|
"testFailed": "Test strumienia nieudany",
|
||||||
|
"testFailedTitle": "Test nieudany",
|
||||||
|
"connected": "Połączono",
|
||||||
|
"notConnected": "Nie połączono",
|
||||||
|
"featuresTitle": "Funkcje",
|
||||||
|
"go2rtc": "Ogranicz połączenia do kamery",
|
||||||
|
"detectRoleWarning": "Przynajmniej jeden strumień musi mieć rolę \"detect\".",
|
||||||
|
"rolesPopover": {
|
||||||
|
"title": "Role strumienia",
|
||||||
|
"detect": "Główny strumień służący do wykrywania obiektów."
|
||||||
|
},
|
||||||
|
"featuresPopover": {
|
||||||
|
"title": "Funkcje strumienia"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"step4": {
|
||||||
|
"description": "Końcowa walidacja i analiza przed zapisaniem ustawień nowej kamery. Połącz się z każdym strumieniem przed zapisaniem.",
|
||||||
|
"validationTitle": "Walidacja strumienia",
|
||||||
|
"reconnectionSuccess": "Ponowna próba połączenia udana.",
|
||||||
|
"streamUnavailable": "Podgląd strumienia niedostępny",
|
||||||
|
"connecting": "Łączenie...",
|
||||||
|
"streamTitle": "Strumień numer: {{number}}",
|
||||||
|
"valid": "Poprawny",
|
||||||
|
"connectingStream": "Łączenie",
|
||||||
|
"disconnectStream": "Rozłącz",
|
||||||
|
"estimatedBandwidth": "Przewidywana przepustowość",
|
||||||
|
"roles": "Role",
|
||||||
|
"ffmpegModuleDescription": "Jeżeli po kilku próbach strumień nadal nie ładuje się, uruchom ten tryb. Gdy włączony jest ten tryb Frigate będzie używać modułu ffmpeg z go2rtc. Może to zapewnić lepszą kompatybilność z niektórymi typami strumieniów.",
|
||||||
|
"none": "Brak",
|
||||||
|
"error": "Błąd",
|
||||||
|
"streamValidated": "Strumień numer: {{number}} przeszedł test pozytywnie.",
|
||||||
|
"streamValidationFailed": "Strumień numer: {{number}} test nieudany",
|
||||||
|
"saveAndApply": "Zapisz nową kamerę",
|
||||||
|
"saveError": "Nieprawidłowa konfiguracja. Sprawdź ustawienia.",
|
||||||
|
"issues": {
|
||||||
|
"title": "Walidacja strumienia",
|
||||||
|
"audioCodecGood": "Kodek dźwięku to {{codec}}.",
|
||||||
|
"resolutionHigh": "Rozdzielczość {{resolution}} może spowodować większe zużycie zasobów.",
|
||||||
|
"resolutionLow": "Rozdzielczość {{resolution}} może okazać się za mała aby poprawnie wykrywać małe obiekty.",
|
||||||
|
"noAudioWarning": "Nie wykryto dźwięku dla tego strumienia, nagrania również nie będą zawierać dźwięku.",
|
||||||
|
"audioCodecRecordError": "Kodek AAC jest wymagany aby uwzględnić dźwięk w nagraniach.",
|
||||||
|
"audioCodecRequired": "Strumień audio jest wymagany aby umożliwić wykrywanie dźwięku.",
|
||||||
|
"restreamingWarning": "Ograniczenie ilości połączeń do strumienia nagrań może delikatnie zwiększyć użycie procesora",
|
||||||
|
"brands": {
|
||||||
|
"reolink-rtsp": "Strumień RTSP dla kamer firmy Reolink nie jest rekomendowany. Uruchom strumień HTTP w oprogramowaniu kamery i uruchom kreator jeszcze raz."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"description": "Wykonaj poniższe kroki aby dodać nową kamerę do Frigate."
|
||||||
|
},
|
||||||
|
"cameraManagement": {
|
||||||
|
"title": "Zarządzaj kamerami",
|
||||||
|
"addCamera": "Dodaj nową kamerę",
|
||||||
|
"editCamera": "Edytuj kamerę:",
|
||||||
|
"selectCamera": "Wybierz kamerę",
|
||||||
|
"backToSettings": "Powrót do ustawień kamery",
|
||||||
|
"streams": {
|
||||||
|
"title": "Włącz / Wyłącz kamery"
|
||||||
|
},
|
||||||
|
"cameraConfig": {
|
||||||
|
"add": "Dodaj kamerę",
|
||||||
|
"edit": "Edytuj kamerę",
|
||||||
|
"description": "Skonfiguruj ustawienia kamery, wliczając strumienie wejściowe i ich role.",
|
||||||
|
"name": "Nazwa kamery",
|
||||||
|
"nameRequired": "Wymagana nazwa kamery",
|
||||||
|
"nameLength": "Nazwa kamery musi mieć 64 lub mniej znaków.",
|
||||||
|
"namePlaceholder": "np. drzwi_frontowe lub Ogród",
|
||||||
|
"enabled": "Włączone",
|
||||||
|
"ffmpeg": {
|
||||||
|
"inputs": "Strumienie wejściowe",
|
||||||
|
"path": "Ścieżka strumienia",
|
||||||
|
"pathRequired": "Ścieżka strumienia jest wymagana",
|
||||||
|
"pathPlaceholder": "rtsp://...",
|
||||||
|
"roles": "Role",
|
||||||
|
"rolesRequired": "Wymagana jest przynajmniej jedna rola",
|
||||||
|
"rolesUnique": "Każda rola ('audio', 'detect', 'record') może zostać przypisana tylko raz",
|
||||||
|
"addInput": "Dodaj strumień wejściowy",
|
||||||
|
"removeInput": "Usuń strumień wejściowy",
|
||||||
|
"inputsRequired": "Wymagany jest przynajmniej jeden strumień wejściowy"
|
||||||
|
},
|
||||||
|
"go2rtcStreams": "Strumienie go2rtc",
|
||||||
|
"streamUrls": "Adresy URL strumieni",
|
||||||
|
"addUrl": "Dodaj adres URL",
|
||||||
|
"addGo2rtcStream": "Dodaj strumień go2rtc",
|
||||||
|
"toast": {
|
||||||
|
"success": "Zapisano poprawnie kamerę {{cameraName}}"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"cameraReview": {
|
||||||
|
"review": {
|
||||||
|
"alerts": "Alerty ",
|
||||||
|
"detections": "Wykrycia "
|
||||||
|
},
|
||||||
|
"reviewClassification": {
|
||||||
|
"title": "Przegląd klasyfikacji",
|
||||||
|
"noDefinedZones": "Nie zdefiniowano żadnych stref dla tej kamery.",
|
||||||
|
"objectDetectionsTips": "Wszystkie obiekty w kategorii {{detectionsLabels}} wykryte przez kamerę {{cameraName}} będą wyświetlane jako Wykrycia niezależnie od strefy w której zostały wykryte.",
|
||||||
|
"zoneObjectDetectionsTips": {
|
||||||
|
"text": "Wszystkie obiekty w kategorii {{detectionsLabels}} nieskategoryzowane w strefie {{zone}} kamery {{cameraName}} będą wyświetlane jako Wykrycia.",
|
||||||
|
"notSelectDetections": "Wszystkie obiekty w kategorii {{detectionsLabels}} wykryte w strefie {{zone}} kamery {{cameraName}} nieskategoryzowane jako Alerty będą wyświetlane jako Wykrycia, niezależnie w której strefie zostaną wykryte.",
|
||||||
|
"regardlessOfZoneObjectDetectionsTips": "Wszystkie obiekty w kategorii {{detectionsLabels}} nieskategoryzowane dla kamery {{cameraName}} będą wyświetlane jako Wykrycia niezależnie w której strefie zostaną wykryte."
|
||||||
|
},
|
||||||
|
"unsavedChanges": "Niezapisane ustawienia klasyfikacji przeglądu dla kamery {{camera}}",
|
||||||
|
"selectAlertsZones": "Wybierz strefę dla Alertów",
|
||||||
|
"selectDetectionsZones": "Wybierz strefę dla Wykryć",
|
||||||
|
"limitDetections": "Ogranicz detekcje do konkretnych stref"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -42,7 +42,11 @@
|
|||||||
"gpuMemory": "Pamięć GPU",
|
"gpuMemory": "Pamięć GPU",
|
||||||
"gpuUsage": "Użycie GPU",
|
"gpuUsage": "Użycie GPU",
|
||||||
"npuUsage": "Użycie NPU",
|
"npuUsage": "Użycie NPU",
|
||||||
"npuMemory": "Pamięć NPU"
|
"npuMemory": "Pamięć NPU",
|
||||||
|
"intelGpuWarning": {
|
||||||
|
"message": "Statystyki układu graficznego niedostępne",
|
||||||
|
"description": "W narzędziach telemetrii i statystyki układów graficznych firmy Intel (intel_gpu_top) znajduje się znany błąd powodujący raportowanie użycia układu graficznego wynoszące 0%, nawet gdy akceleracja sprzętowa i wykrywanie obiektów działa prawidłowo korzystając ze zintegrowanego układu graficznego. To nie jest błąd oprogramowania Frigate. Restart hosta może chwilowo rozwiązać problem i pozwolić na weryfikację działania układu graficznego. Ten bład nie wpływa na wydajność systemu,"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"title": "Ogólne",
|
"title": "Ogólne",
|
||||||
"detector": {
|
"detector": {
|
||||||
|
|||||||
@ -19,19 +19,25 @@
|
|||||||
"trainingModel": "Treinamento do modelo iniciado com sucesso.",
|
"trainingModel": "Treinamento do modelo iniciado com sucesso.",
|
||||||
"deletedModel_one": "{{count}} modelo excluído com sucesso",
|
"deletedModel_one": "{{count}} modelo excluído com sucesso",
|
||||||
"deletedModel_many": "{{count}} modelos excluídos com sucesso",
|
"deletedModel_many": "{{count}} modelos excluídos com sucesso",
|
||||||
"deletedModel_other": "{{count}} modelos excluídos com sucesso"
|
"deletedModel_other": "{{count}} modelos excluídos com sucesso",
|
||||||
|
"updatedModel": "Configuração do modelo atualizada com sucesso",
|
||||||
|
"renamedCategory": "Classe renomeada para {{name}} com sucesso"
|
||||||
},
|
},
|
||||||
"error": {
|
"error": {
|
||||||
"deleteImageFailed": "Falha ao deletar:{{errorMessage}}",
|
"deleteImageFailed": "Falha ao deletar:{{errorMessage}}",
|
||||||
"deleteCategoryFailed": "Falha ao deletar classe:{{errorMessage}}",
|
"deleteCategoryFailed": "Falha ao deletar classe:{{errorMessage}}",
|
||||||
"categorizeFailed": "Falha ao categorizar imagem:{{errorMessage}}",
|
"categorizeFailed": "Falha ao categorizar imagem:{{errorMessage}}",
|
||||||
"deleteModelFailed": "Falha ao excluir o modelo: {{errorMessage}}",
|
"deleteModelFailed": "Falha ao excluir o modelo: {{errorMessage}}",
|
||||||
"trainingFailed": "Falha ao iniciar o treinamento do modelo: {{errorMessage}}"
|
"trainingFailed": "Falha ao iniciar o treinamento do modelo: {{errorMessage}}",
|
||||||
|
"trainingFailedToStart": "Falha ao iniciar o treinamento do modelo: {{errorMessage}}",
|
||||||
|
"updateModelFailed": "Falha ao atualizar modelo: {{errorMessage}}",
|
||||||
|
"renameCategoryFailed": "Falha ao renomear classe: {{errorMessage}}"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deleteCategory": {
|
"deleteCategory": {
|
||||||
"title": "Excluir Classe",
|
"title": "Excluir Classe",
|
||||||
"desc": "Tem certeza de que deseja excluir a classe {{name}}? Isso excluirá permanentemente todas as imagens associadas e exigirá o treinamento do modelo novamente."
|
"desc": "Tem certeza de que deseja excluir a classe {{name}}? Isso excluirá permanentemente todas as imagens associadas e exigirá o treinamento do modelo novamente.",
|
||||||
|
"minClassesTitle": "Não é possível apagar a classe"
|
||||||
},
|
},
|
||||||
"deleteModel": {
|
"deleteModel": {
|
||||||
"title": "Deletar modelo de classificação",
|
"title": "Deletar modelo de classificação",
|
||||||
|
|||||||
@ -88,7 +88,8 @@
|
|||||||
"failed": "Eroare la pornirea exportului: {{error}}",
|
"failed": "Eroare la pornirea exportului: {{error}}",
|
||||||
"endTimeMustAfterStartTime": "Ora de sfârșit trebuie să fie după ora de început",
|
"endTimeMustAfterStartTime": "Ora de sfârșit trebuie să fie după ora de început",
|
||||||
"noVaildTimeSelected": "Nu a fost selectat un interval de timp valid"
|
"noVaildTimeSelected": "Nu a fost selectat un interval de timp valid"
|
||||||
}
|
},
|
||||||
|
"view": "Vizualizează"
|
||||||
},
|
},
|
||||||
"fromTimeline": {
|
"fromTimeline": {
|
||||||
"saveExport": "Salvează exportul",
|
"saveExport": "Salvează exportul",
|
||||||
|
|||||||
@ -152,7 +152,12 @@
|
|||||||
"generateSuccess": "Imaginile de exemplu au fost generate cu succes",
|
"generateSuccess": "Imaginile de exemplu au fost generate cu succes",
|
||||||
"allImagesRequired_one": "Te rog să clasifici toate imaginile. {{count}} imagine rămasă.",
|
"allImagesRequired_one": "Te rog să clasifici toate imaginile. {{count}} imagine rămasă.",
|
||||||
"allImagesRequired_few": "Te rog să clasifici toate imaginile. {{count}} imagini rămase.",
|
"allImagesRequired_few": "Te rog să clasifici toate imaginile. {{count}} imagini rămase.",
|
||||||
"allImagesRequired_other": "Te rog să clasifici toate imaginile. {{count}} de imagini rămase."
|
"allImagesRequired_other": "Te rog să clasifici toate imaginile. {{count}} de imagini rămase.",
|
||||||
|
"modelCreated": "Modelul a fost creat cu succes. Folosește vizualizarea Clasificări recente pentru a adăuga imagini pentru stările lipsă, apoi antrenează modelul.",
|
||||||
|
"missingStatesWarning": {
|
||||||
|
"title": "Exemple de stări lipsă",
|
||||||
|
"description": "Nu ai selectat exemple pentru toate stările. Modelul nu va fi antrenat până când toate stările nu au imagini. După continuare, folosește vizualizarea Clasificări recente pentru a clasifica imagini pentru stările lipsă, apoi antrenează modelul."
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"deleteModel": {
|
"deleteModel": {
|
||||||
|
|||||||
@ -55,5 +55,8 @@
|
|||||||
"clickToSeek": "Apasă pentru a naviga la acest moment"
|
"clickToSeek": "Apasă pentru a naviga la acest moment"
|
||||||
},
|
},
|
||||||
"zoomIn": "Mărește",
|
"zoomIn": "Mărește",
|
||||||
"zoomOut": "Micșorează"
|
"zoomOut": "Micșorează",
|
||||||
|
"normalActivity": "Normal",
|
||||||
|
"needsReview": "Necesită revizuire",
|
||||||
|
"securityConcern": "Potențială problemă de securitate"
|
||||||
}
|
}
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user