Introduction
TagMetaView
is a widget in Supervisely that displays a single TagMeta and provides a convenient way to view the name, color, and tag value type.
Function signature
tag_meta_view = TagMetaView(
tag_meta=sly.TagMeta("Animal", sly.TagValueType.ANY_STRING, color=[255, 0, 0]),
show_type_text=True,
limit_long_names=False,
widget_id=None
)
Parameters
Parameters
Type
Description
If True
display tag value type
If False
show the entire tag name if the name is quite lengthy
tag_meta
Supervisely tag meta
type: TagMeta
tag_meta = sly.TagMeta(
name="Animal",
value_type=sly.TagValueType.ANY_STRING,
color=[255, 0, 0]
)
tag_meta_view = TagMetaView(tag_meta=tag_meta)
show_type_text
If True
display tag value type next to tag name.
type: bool
default value: True
tag_meta = sly.TagMeta(
name="Animal",
value_type=sly.TagValueType.ANY_STRING,
color=[255, 0, 0]
)
tag_meta_view = TagMetaView(tag_meta=tag_meta, show_shape_text=False)
limit_long_names
If False
show the entire tag name if the name is quite lengthy
type: bool
default value: False
tag_meta = sly.TagMeta(
name="Animal",
value_type=sly.TagValueType.ANY_STRING,
color=[255, 0, 0]
)
tag_meta_view = TagMetaView(
tag_meta=tag_meta,
show_shape_icon=True,
limit_long_names=True
)
widget_id
ID of the widget.
type: str
default value: None
Mini App Example
You can find this example in our Github repository:
supervisely-ecosystem/ui-widgets-demos/media/013_tag_meta_view/src/main.py
Import libraries
import os
import supervisely as sly
from dotenv import load_dotenv
from supervisely.app.widgets import Card, Container, Field, TagMetaView, ProjectThumbnail
Init API client
First, we load environment variables with credentials and init API for communicating with Supervisely Instance:
load_dotenv("local.env")
load_dotenv(os.path.expanduser("~/supervisely.env"))
api = sly.Api()
Initialize Project ID
we will use
project_id = sly.env.project_id()
Get Project info and meta from server
project_info = api.project.get_info_by_id(id=project_id)
project_meta = api.project.get_meta(id=project_id)
project_meta = sly.ProjectMeta.from_json(project_meta)
Prepare TagMeta
for each tag in project
Get TagMetas from project meta
tag_metas = project_meta.tag_metas
Initialize TagMetaView
widget
In this tutorial we will create list of TagMetaView
objects for each tag in project.
tag_meta_view = [
TagMetaView(
tag_meta=tag_meta,
show_type_text=True,
limit_long_names=False,
)
for tag_meta in tag_metas
]
Create app layout
Prepare a layout for app using Card
, Field
widgets with the content
parameter and place widgets that we've just created in the Container
widget.
tag_metas_container = Container(widgets=tag_meta_view)
tag_metas_field = Field(
content=tag_metas_container,
title="Project tags:",
)
# create widget ProjectThumbnail
project_thumbnail = ProjectThumbnail(project_info)
card = Card(
title="TagMetaView",
content=Container(widgets=[project_thumbnail, tag_metas_field]),
)
layout = Container(widgets=[card])
Create app using layout
Create an app object with layout parameter.
app = sly.Application(layout=layout)