|
@@ -122,19 +122,19 @@ with example(ui.label):
|
|
ui.label('some label')
|
|
ui.label('some label')
|
|
|
|
|
|
with example(ui.image):
|
|
with example(ui.image):
|
|
|
|
+
|
|
ui.image('http://placeimg.com/640/360/tech')
|
|
ui.image('http://placeimg.com/640/360/tech')
|
|
base64 = ''
|
|
base64 = ''
|
|
ui.image(base64).style('width:30px')
|
|
ui.image(base64).style('width:30px')
|
|
|
|
|
|
with example(ui.svg):
|
|
with example(ui.svg):
|
|
|
|
+
|
|
svg_content = '''
|
|
svg_content = '''
|
|
- <svg viewBox="0 0 200 200" width="100" height="100" xmlns="http://www.w3.org/2000/svg">
|
|
|
|
- <circle cx="100" cy="100" fill="yellow" r="78" stroke="black" stroke-width="3"/>
|
|
|
|
- <g class="eyes">
|
|
|
|
- <circle cx="61" cy="82" r="12"/>
|
|
|
|
- <circle cx="127" cy="82" r="12"/>
|
|
|
|
- </g>
|
|
|
|
- <path d="m136.81 116.53c.69 36.17-74.11 42-81.52-.73" style="fill:none; stroke: black; stroke-width: 5;"/>
|
|
|
|
|
|
+ <svg viewBox="0 0 200 200" width="100" height="100" xmlns="http://www.w3.org/2000/svg">
|
|
|
|
+ <circle cx="100" cy="100" r="78" fill="yellow" stroke="black" stroke-width="3" />
|
|
|
|
+ <circle cx="61" cy="82" r="12" />
|
|
|
|
+ <circle cx="127" cy="82" r="12" />
|
|
|
|
+ <path d="m136.81 116.53c.69 36.17-74.11 42-81.52-.73" style="fill:none; stroke: black; stroke-width: 5;" />
|
|
</svg>'''
|
|
</svg>'''
|
|
ui.svg(svg_content)
|
|
ui.svg(svg_content)
|
|
|
|
|
|
@@ -146,16 +146,17 @@ Use [Quasar classes](https://quasar.dev/vue-components/img) for positioning and
|
|
To overlay an svg, make the `viewBox` exactly the size of the image and provide `100%` width/height to match the actual rendered size.
|
|
To overlay an svg, make the `viewBox` exactly the size of the image and provide `100%` width/height to match the actual rendered size.
|
|
'''
|
|
'''
|
|
with example(overlay):
|
|
with example(overlay):
|
|
|
|
+
|
|
with ui.image('http://placeimg.com/640/360/nature'):
|
|
with ui.image('http://placeimg.com/640/360/nature'):
|
|
ui.label('nice').classes('absolute-bottom text-subtitle2 text-center')
|
|
ui.label('nice').classes('absolute-bottom text-subtitle2 text-center')
|
|
|
|
|
|
with ui.image('https://cdn.pixabay.com/photo/2020/07/13/12/56/mute-swan-5400675__340.jpg'):
|
|
with ui.image('https://cdn.pixabay.com/photo/2020/07/13/12/56/mute-swan-5400675__340.jpg'):
|
|
svg_content = '''
|
|
svg_content = '''
|
|
<svg viewBox="0 0 510 340" width="100%" height="100%" xmlns="http://www.w3.org/2000/svg">
|
|
<svg viewBox="0 0 510 340" width="100%" height="100%" xmlns="http://www.w3.org/2000/svg">
|
|
- <circle cx="200" cy="200" fill="none" r="100" stroke="red" stroke-width="10"/>
|
|
|
|
|
|
+ <circle cx="200" cy="200" r="100" fill="none" stroke="red" stroke-width="10" />
|
|
</svg>
|
|
</svg>
|
|
'''
|
|
'''
|
|
- ui.svg(svg_content).style('background:transparent;')
|
|
|
|
|
|
+ ui.svg(svg_content).style('background:transparent')
|
|
|
|
|
|
with example(ui.markdown):
|
|
with example(ui.markdown):
|
|
|
|
|
|
@@ -259,19 +260,22 @@ with example(ui.joystick):
|
|
lifecycle = '''### Lifecycle
|
|
lifecycle = '''### Lifecycle
|
|
|
|
|
|
You can run a function or coroutine on startup as a parallel task by passing it to `ui.on_startup`.
|
|
You can run a function or coroutine on startup as a parallel task by passing it to `ui.on_startup`.
|
|
-If NiceGui is shut down or restarted the tasks will be automatically canceled (for example when you make a code change).
|
|
|
|
-You can also execude cleanup code with `ui.on_shutdown`.
|
|
|
|
|
|
+If NiceGui is shut down or restarted, the tasks will be automatically canceled (for example when you make a code change).
|
|
|
|
+You can also execute cleanup code with `ui.on_shutdown`.
|
|
'''
|
|
'''
|
|
-with (example(lifecycle)):
|
|
|
|
|
|
+with example(lifecycle):
|
|
|
|
|
|
- count_label = ui.label('count: 0')
|
|
|
|
- count = 0
|
|
|
|
|
|
+ with ui.row() as row:
|
|
|
|
+ ui.label('count:')
|
|
|
|
+ count_label = ui.label('0')
|
|
|
|
+ count = 0
|
|
|
|
|
|
- async def update_count():
|
|
|
|
|
|
+ async def counter():
|
|
global count
|
|
global count
|
|
while True:
|
|
while True:
|
|
- count_label.text = f'count: {count}'
|
|
|
|
|
|
+ count_label.text = str(count)
|
|
count += 1
|
|
count += 1
|
|
|
|
+ await row.view.update()
|
|
await asyncio.sleep(1)
|
|
await asyncio.sleep(1)
|
|
|
|
|
|
- ui.on_startup(update_count())
|
|
|
|
|
|
+ ui.on_startup(counter())
|