diff --git a/archconf2020/__init__.py b/archconf2020/__init__.py
new file mode 100644
index 0000000..4690ed7
--- /dev/null
+++ b/archconf2020/__init__.py
@@ -0,0 +1,371 @@
+#!/usr/bin/python3
+
+import easing
+import renderlib
+
+# URL to Schedule-XML
+scheduleUrl = "https://conf.archlinux.org/schedule2020.xml"
+
+
+def introFrames(args):
+ # fade in logo
+ frames = 1 * renderlib.fps
+ for i in range(0, frames):
+ yield (
+ (
+ "logo",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0, 1, frames),
+ ),
+ ("conf_title", "style", "opacity", 0),
+ ("title", "style", "opacity", 0),
+ ("subtitle", "style", "opacity", 0),
+ ("persons", "style", "opacity", 0),
+ ("id", "style", "opacity", 0),
+ )
+ # fade in conf_title
+ frames = 1 * renderlib.fps
+ for i in range(0, frames):
+ yield (
+ (
+ "conf_title",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0, 1, frames),
+ ),
+ ("title", "style", "opacity", 0),
+ ("subtitle", "style", "opacity", 0),
+ ("persons", "style", "opacity", 0),
+ ("id", "style", "opacity", 0),
+ )
+
+ # show conf_title and logo for 1 second
+ frames = 1 * renderlib.fps
+ for i in range(0, frames):
+ yield (
+ ("logo", "style", "opacity", 1),
+ ("conf_title", "style", "opacity", 1),
+ ("title", "style", "opacity", 0),
+ ("subtitle", "style", "opacity", 0),
+ ("persons", "style", "opacity", 0),
+ ("id", "style", "opacity", 0),
+ )
+
+ # move logo and conf_title to right
+ frames = 2 * renderlib.fps
+ for i in range(0, frames):
+ xshift = (i + 1) * 135 / frames
+ yield (
+ ("logo", "style", "opacity", 1),
+ ("conf_title", "style", "opacity", 1),
+ ("title", "style", "opacity", 0),
+ ("subtitle", "style", "opacity", 0),
+ ("persons", "style", "opacity", 0),
+ ("id", "style", "opacity", 0),
+ ("logo", "attr", "transform", f"translate({xshift}, 0)"),
+ ("conf_title", "attr", "transform", f"translate({xshift}, 0)"),
+ )
+
+ # fade in title, subtitle, persons and id
+ frames = 2 * renderlib.fps
+ for i in range(0, frames):
+ yield (
+ ("title", "style", "opacity", easing.easeInQuad(i, 0, 1, frames)),
+ (
+ "subtitle",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0, 1, frames),
+ ),
+ (
+ "persons",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0, 1, frames),
+ ),
+ ("id", "style", "opacity", easing.easeInQuad(i, 0, 1, frames)),
+ (
+ "logo",
+ "attr",
+ "transform",
+ f"translate({xshift}, 0)",
+ ),
+ (
+ "conf_title",
+ "attr",
+ "transform",
+ f"translate({xshift}, 0)",
+ ),
+ )
+ # show whole image for 2 seconds
+ frames = 2 * renderlib.fps
+ for i in range(0, frames):
+ yield (
+ ("title", "style", "opacity", 1),
+ ("subtitle", "style", "opacity", 1),
+ ("persons", "style", "opacity", 1),
+ ("id", "style", "opacity", 1),
+ (
+ "logo",
+ "attr",
+ "transform",
+ f"translate({xshift}, 0)",
+ ),
+ (
+ "conf_title",
+ "attr",
+ "transform",
+ f"translate({xshift}, 0)",
+ ),
+ )
+
+
+def backgroundFrames(parameters):
+ frames = 20 * renderlib.fps
+ for i in range(0, frames):
+ xshift = (i + 1) * 300 / frames
+ yshift = (i + 1) * (150 / frames)
+ yield (
+ (
+ "logo_pattern",
+ "attr",
+ "transform",
+ "translate(%.4f, %.4f)" % (xshift, yshift),
+ ),
+ )
+
+ frames = 20 * renderlib.fps
+ for i in range(0, frames):
+ xshift = 300 - ((i + 1) * (300 / frames))
+ yshift = 150 - ((i + 1) * (150 / frames))
+ yield (
+ (
+ "logo_pattern",
+ "attr",
+ "transform",
+ "translate(%.4f, %.4f)" % (xshift, yshift),
+ ),
+ )
+
+
+def outroFrames(args):
+ # fadein outro graphics
+ frames = 3 * renderlib.fps
+ for i in range(0, frames):
+ yield (
+ (
+ "logo",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.01, 1, frames),
+ ),
+ (
+ "conf_title",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.01, 1, frames),
+ ),
+ (
+ "c3voclogo",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.01, 1, frames),
+ ),
+ (
+ "c3voctext",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.01, 1, frames),
+ ),
+ (
+ "bysalogo",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.01, 1, frames),
+ ),
+ (
+ "bysatext",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.01, 1, frames),
+ ),
+ )
+ frames = 3 * renderlib.fps
+ for i in range(0, frames):
+ yield (
+ ("logo", "style", "opacity", 1),
+ ("conf_title", "style", "opacity", 1),
+ ("c3voclogo", "style", "opacity", 1),
+ ("c3voctext", "style", "opacity", 1),
+ ("bysalogo", "style", "opacity", 1),
+ ("bysatext", "style", "opacity", 1),
+ )
+
+
+def pauseFrames(args):
+ # fade heartgroups
+ frames = int(0.5 * renderlib.fps)
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.25, 0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 1, -0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.25, 0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 1, -0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.25, 0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 1, -0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.25, 0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 1, -0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 0.25, 0.75, frames),
+ ),
+ )
+ for i in range(0, frames):
+ yield (
+ (
+ "group",
+ "style",
+ "opacity",
+ easing.easeInQuad(i, 1, -0.75, frames),
+ ),
+ )
+
+
+def debug():
+ render( # noqa
+ "intro.svg",
+ "../intro.ts",
+ introFrames,
+ {
+ "$id": 7776,
+ "$title": "StageWar live!",
+ "$subtitle": "Metal Konzert",
+ "$persons": "www.stagewar.de",
+ },
+ )
+
+ render("outro.svg", "../outro.ts", outroFrames) # noqa
+
+ render("background.svg", "../background.ts", backgroundFrames) # noqa
+
+ render("pause.svg", "../pause.ts", pauseFrames) # noqa
+
+
+def tasks(queue, args, idlist, skiplist):
+ # iterate over all events extracted from the schedule xml-export
+ for event in renderlib.events(scheduleUrl):
+ if not (idlist == []):
+ if 000000 in idlist:
+ print("skipping id (%s [%s])" % (event["title"], event["id"]))
+ continue
+ if int(event["id"]) not in idlist:
+ print("skipping id (%s [%s])" % (event["title"], event["id"]))
+ continue
+
+ # generate a task description and put them into the queue
+ queue.put(
+ renderlib.Rendertask(
+ infile="intro.svg",
+ outfile=str(event["id"]) + ".ts",
+ sequence=introFrames,
+ parameters={
+ "$id": event["id"],
+ "$title": event["title"],
+ "$subtitle": event["subtitle"],
+ "$persons": event["personnames"],
+ },
+ )
+ )
+
+ # place a task for the outro into the queue
+ if "out" not in skiplist:
+ queue.put(
+ renderlib.Rendertask(
+ infile="outro.svg", outfile="outro.ts", sequence=outroFrames
+ )
+ )
+
+ # place the pause-sequence into the queue
+ if "pause" not in skiplist:
+ queue.put(
+ renderlib.Rendertask(
+ infile="pause.svg", outfile="pause.ts", sequence=pauseFrames
+ )
+ )
+
+ # place the background-sequence into the queue
+ if "bg" not in skiplist:
+ queue.put(
+ renderlib.Rendertask(
+ infile="background.svg",
+ outfile="background.ts",
+ sequence=backgroundFrames,
+ )
+ )
diff --git a/archconf2020/artwork/archlinux-logo-with-text.svg b/archconf2020/artwork/archlinux-logo-with-text.svg
new file mode 100644
index 0000000..5fd0716
--- /dev/null
+++ b/archconf2020/artwork/archlinux-logo-with-text.svg
@@ -0,0 +1,156 @@
+
+
+
+
diff --git a/archconf2020/artwork/archlinux-logo.svg b/archconf2020/artwork/archlinux-logo.svg
new file mode 100644
index 0000000..2c65e8b
--- /dev/null
+++ b/archconf2020/artwork/archlinux-logo.svg
@@ -0,0 +1,131 @@
+
+
diff --git a/archconf2020/artwork/background.svg b/archconf2020/artwork/background.svg
new file mode 100644
index 0000000..22c8043
--- /dev/null
+++ b/archconf2020/artwork/background.svg
@@ -0,0 +1,2679 @@
+
+
diff --git a/archconf2020/artwork/by-sa.svg b/archconf2020/artwork/by-sa.svg
new file mode 100644
index 0000000..60b44e3
--- /dev/null
+++ b/archconf2020/artwork/by-sa.svg
@@ -0,0 +1,74 @@
+
+
+
\ No newline at end of file
diff --git a/archconf2020/artwork/intro.svg b/archconf2020/artwork/intro.svg
new file mode 100644
index 0000000..683b104
--- /dev/null
+++ b/archconf2020/artwork/intro.svg
@@ -0,0 +1,306 @@
+
+
diff --git a/archconf2020/artwork/outro.svg b/archconf2020/artwork/outro.svg
new file mode 100644
index 0000000..1f0c0e7
--- /dev/null
+++ b/archconf2020/artwork/outro.svg
@@ -0,0 +1,9986 @@
+
+
diff --git a/archconf2020/artwork/pause.svg b/archconf2020/artwork/pause.svg
new file mode 100644
index 0000000..66fb5c3
--- /dev/null
+++ b/archconf2020/artwork/pause.svg
@@ -0,0 +1,344 @@
+
+
diff --git a/divoc-hs/__init__.py b/divoc-hs/__init__.py
new file mode 100644
index 0000000..1cd54e9
--- /dev/null
+++ b/divoc-hs/__init__.py
@@ -0,0 +1,131 @@
+#!/usr/bin/python3
+
+from renderlib import *
+from easing import *
+
+# URL to Schedule-XML
+scheduleUrl = 'https://git.chaotikum.org/divoc/fahrplan/raw/master/fahrplan.xml'
+
+
+def clamp(n, i, a):
+ return max(min(n, a), i)
+
+
+def introFrames(args):
+ frames = int(.5*fps)
+ for i in range(0, frames):
+ yield (
+ ('logo', 'style', 'opacity', easeInQuad(i, 0, 1, frames)),
+ ('title', 'style', 'opacity', 0),
+ ('subtitle', 'style', 'opacity', 0),
+ ('personnames', 'style', 'opacity', 0),
+ ('id', 'style', 'opacity', 0),
+ )
+ frames = int(.5*fps)
+ for i in range(0, frames):
+ yield (
+ ('title', 'style', 'opacity', 0),
+ ('personnames', 'style', 'opacity', 0),
+ ('subtitle', 'style', 'opacity', 0),
+ ('id', 'style', 'opacity', 0),
+ )
+ frames = int(1*fps)
+ for i in range(0, frames):
+ scale = easeInOutQuad(i, 1.0, -0.8, frames-1)
+ dx = easeInOutQuad(i, 0, 1550, frames-1)
+ dy = easeInOutQuad(i, 0, 875, frames-1)
+ yield (
+ ('logo', 'attr', 'transform', f'translate({dx}, {dy}) scale({scale},{scale})'),
+ ('title', 'style', 'opacity', 0),
+ ('subtitle', 'style', 'opacity', 0),
+ ('personnames', 'style', 'opacity', 0),
+ ('id', 'style', 'opacity', 0),
+ )
+ step = 0.33
+ steps = step * fps
+ frames = int(4 * steps)
+ for i in range(0, frames):
+ yield (
+ ('logo', 'attr', 'transform', f'translate(1550, 875) scale(.2,.2)'),
+ ('title', 'style', 'opacity', easeInQuad(clamp(i, 0, fps), 0, 1, fps)),
+ ('subtitle', 'style', 'opacity', easeInQuad(clamp(i - 1*steps, 0, fps), 0, 1, fps)),
+ ('personnames', 'style', 'opacity', easeInQuad(clamp(i - 2*steps, 0, fps), 0, 1, fps)),
+ ('id', 'style', 'opacity', easeInQuad(clamp(i - 3*steps, 0, fps), 0, 1, fps)),
+ )
+ frames = int(5*fps)
+ for i in range(0, frames):
+ yield (
+ ('logo', 'attr', 'transform', f'translate(1550, 875) scale(.2,.2)'),
+ )
+
+
+def outroFrames(args):
+#fadein outro graphics
+ frames = 3*fps
+ for i in range(0, frames):
+ yield(())
+
+
+def debug():
+ render('divoc-hs-intro.svg',
+ '../divoc-hs-intro.ts',
+ introFrames,
+ {
+ '$id': 7776,
+ '$title': 'StageWar live! mit vielen Wörtern extra lang das wird jetzt echt zu viel',
+ '$subtitle': 'Metal Konzert mit vielen Wörtern extra lang das wird jetzt echt zu viel',
+ '$personnames': 'www.stagewar.de mit vielen Wörtern extra lang das wird jetzt echt zu viel'
+ }
+ )
+
+ render('divoc-hs-outro.svg',
+ '../divoc-hs-outro.ts',
+ outroFrames
+ )
+
+ # render(
+ # 'background.svg',
+ # '../background.ts',
+ # backgroundFrames
+ # )
+ #
+ # render('pause.svg',
+ # '../pause.ts',
+ # pauseFrames
+ # )
+
+
+def tasks(queue, args, idlist, skiplist):
+ # iterate over all events extracted from the schedule xml-export
+ for event in events(scheduleUrl):
+ # if event['room'] not in ('Chirurgie (Saal 1.04)', 'Kreißsaal (Saal 1.11)'):
+ # print("skipping room %s (%s [%s])" % (event['room'], event['title'], event['id']))
+ # continue
+ # if not (idlist==[]):
+ # if 000000 in idlist:
+ # print("skipping id (%s [%s])" % (event['title'], event['id']))
+ # continue
+ # if int(event['id']) not in idlist:
+ # print("skipping id (%s [%s])" % (event['title'], event['id']))
+ # continue
+
+ # generate a task description and put them into the queue
+ queue.put(Rendertask(
+ infile = 'divoc-hs-intro.svg',
+ outfile = str(event['id'])+".ts",
+ sequence = introFrames,
+ parameters = {
+ '$id': event['id'],
+ '$title': event['title'],
+ '$subtitle': event['subtitle'],
+ '$personnames': event['personnames']
+ }
+ ))
+
+ # place a task for the outro into the queue
+ if not "out" in skiplist:
+ queue.put(Rendertask(
+ infile = 'divoc-hs-outro.svg',
+ outfile = 'divoc-hs-outro.ts',
+ sequence = outroFrames
+ ))
diff --git a/divoc-hs/artwork/ArchivoBlack-Regular.ttf b/divoc-hs/artwork/ArchivoBlack-Regular.ttf
new file mode 100644
index 0000000..16a1d8c
Binary files /dev/null and b/divoc-hs/artwork/ArchivoBlack-Regular.ttf differ
diff --git a/divoc-hs/artwork/OFL.txt b/divoc-hs/artwork/OFL.txt
new file mode 100644
index 0000000..8894736
--- /dev/null
+++ b/divoc-hs/artwork/OFL.txt
@@ -0,0 +1,93 @@
+Copyright 2017 The Archivo Black Project Authors (https://github.com/Omnibus-Type/ArchivoBlack)
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+This license is copied below, and is also available with a FAQ at:
+http://scripts.sil.org/OFL
+
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the
+copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+"Author" refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components,
+in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled,
+redistributed and/or sold with any software, provided that each copy
+contains the above copyright notice and this license. These can be
+included either as stand-alone text files, human-readable headers or
+in the appropriate machine-readable metadata fields within text or
+binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font
+Name(s) unless explicit written permission is granted by the corresponding
+Copyright Holder. This restriction only applies to the primary font name as
+presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+Software shall not be used to promote, endorse or advertise any
+Modified Version, except to acknowledge the contribution(s) of the
+Copyright Holder(s) and the Author(s) or with their explicit written
+permission.
+
+5) The Font Software, modified or unmodified, in part or in whole,
+must be distributed entirely under this license, and must not be
+distributed under any other license. The requirement for fonts to
+remain under this license does not apply to any document created
+using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are
+not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/divoc-hs/artwork/divoc-hs-intro.svg b/divoc-hs/artwork/divoc-hs-intro.svg
new file mode 100644
index 0000000..c7343a3
--- /dev/null
+++ b/divoc-hs/artwork/divoc-hs-intro.svg
@@ -0,0 +1,577 @@
+
+
diff --git a/divoc-hs/artwork/divoc-hs-outro.svg b/divoc-hs/artwork/divoc-hs-outro.svg
new file mode 100644
index 0000000..6e2ca1d
--- /dev/null
+++ b/divoc-hs/artwork/divoc-hs-outro.svg
@@ -0,0 +1,144 @@
+
\ No newline at end of file
diff --git a/divoc-ptt/__init__.py b/divoc-ptt/__init__.py
new file mode 100644
index 0000000..f7092df
--- /dev/null
+++ b/divoc-ptt/__init__.py
@@ -0,0 +1,127 @@
+#!/usr/bin/python3
+
+from renderlib import *
+from easing import *
+
+# URL to Schedule-XML
+scheduleUrl = 'https://talks.mrmcd.net/ptt/schedule/export/schedule.xml'
+
+
+def clamp(n, i, a):
+ return max(min(n, a), i)
+
+
+def introFrames(args):
+ frames = int(.5*fps)
+ for i in range(0, frames):
+ yield (
+ ('pttlogo', 'style', 'opacity', easeInQuad(i, 0, 1, frames)),
+ ('title', 'style', 'opacity', 0),
+ ('personnames', 'style', 'opacity', 0),
+ ('id', 'style', 'opacity', 0),
+ )
+ frames = int(.5*fps)
+ for i in range(0, frames):
+ yield (
+ ('title', 'style', 'opacity', 0),
+ ('personnames', 'style', 'opacity', 0),
+ ('id', 'style', 'opacity', 0),
+ )
+ frames = int(1*fps)
+ for i in range(0, frames):
+ scale = easeInOutQuad(i, 1.0, -0.8, frames-1)
+ dx = easeInOutQuad(i, 0, 1550, frames-1)
+ dy = easeInOutQuad(i, 0, 875, frames-1)
+ yield (
+ ('pttlogo', 'attr', 'transform', f'translate({dx}, {dy}) scale({scale},{scale})'),
+ ('title', 'style', 'opacity', 0),
+ ('personnames', 'style', 'opacity', 0),
+ ('id', 'style', 'opacity', 0),
+ )
+ step = 0.5
+ steps = step * fps
+ frames = int(4 * steps)
+ for i in range(0, frames):
+ yield (
+ ('pttlogo', 'attr', 'transform', f'translate(1550, 875) scale(.2,.2)'),
+ ('title', 'style', 'opacity', easeInQuad(clamp(i, 0, fps), 0, 1, fps)),
+ ('personnames', 'style', 'opacity', easeInQuad(clamp(i - 1*steps, 0, fps), 0, 1, fps)),
+ ('id', 'style', 'opacity', easeInQuad(clamp(i - 2*steps, 0, fps), 0, 1, fps)),
+ )
+ frames = int(5*fps)
+ for i in range(0, frames):
+ yield (
+ ('pttlogo', 'attr', 'transform', f'translate(1550, 875) scale(.2,.2)'),
+ )
+
+
+def outroFrames(args):
+#fadein outro graphics
+ frames = 3*fps
+ for i in range(0, frames):
+ yield(())
+
+
+def debug():
+ render('divoc-ptt-intro.svg',
+ '../divoc-ptt-intro.ts',
+ introFrames,
+ {
+ '$id': 7776,
+ '$title': 'StageWar live! mit vielen Wörtern extra lang das wird jetzt echt zu viel',
+ '$subtitle': 'Metal Konzert mit vielen Wörtern extra lang das wird jetzt echt zu viel',
+ '$personnames': 'www.stagewar.de mit vielen Wörtern extra lang das wird jetzt echt zu viel'
+ }
+ )
+
+ render('divoc-ptt-outro.svg',
+ '../divoc-ptt-outro.ts',
+ outroFrames
+ )
+
+ # render(
+ # 'background.svg',
+ # '../background.ts',
+ # backgroundFrames
+ # )
+ #
+ # render('pause.svg',
+ # '../pause.ts',
+ # pauseFrames
+ # )
+
+
+def tasks(queue, args, idlist, skiplist):
+ # iterate over all events extracted from the schedule xml-export
+ for event in events(scheduleUrl):
+ # if event['room'] not in ('Chirurgie (Saal 1.04)', 'Kreißsaal (Saal 1.11)'):
+ # print("skipping room %s (%s [%s])" % (event['room'], event['title'], event['id']))
+ # continue
+ # if not (idlist==[]):
+ # if 000000 in idlist:
+ # print("skipping id (%s [%s])" % (event['title'], event['id']))
+ # continue
+ # if int(event['id']) not in idlist:
+ # print("skipping id (%s [%s])" % (event['title'], event['id']))
+ # continue
+
+ # generate a task description and put them into the queue
+ queue.put(Rendertask(
+ infile = 'divoc-ptt-intro.svg',
+ outfile = str(event['id'])+".ts",
+ sequence = introFrames,
+ parameters = {
+ '$id': event['id'],
+ '$title': event['title'],
+ '$subtitle': event['subtitle'],
+ '$personnames': event['personnames']
+ }
+ ))
+
+ # place a task for the outro into the queue
+ if not "out" in skiplist:
+ queue.put(Rendertask(
+ infile = 'divoc-ptt-outro.svg',
+ outfile = 'divoc-ptt-outro.ts',
+ sequence = outroFrames
+ ))
diff --git a/divoc-ptt/artwork/ArchivoBlack-Regular.ttf b/divoc-ptt/artwork/ArchivoBlack-Regular.ttf
new file mode 100644
index 0000000..16a1d8c
Binary files /dev/null and b/divoc-ptt/artwork/ArchivoBlack-Regular.ttf differ
diff --git a/divoc-ptt/artwork/OFL.txt b/divoc-ptt/artwork/OFL.txt
new file mode 100644
index 0000000..8894736
--- /dev/null
+++ b/divoc-ptt/artwork/OFL.txt
@@ -0,0 +1,93 @@
+Copyright 2017 The Archivo Black Project Authors (https://github.com/Omnibus-Type/ArchivoBlack)
+
+This Font Software is licensed under the SIL Open Font License, Version 1.1.
+This license is copied below, and is also available with a FAQ at:
+http://scripts.sil.org/OFL
+
+
+-----------------------------------------------------------
+SIL OPEN FONT LICENSE Version 1.1 - 26 February 2007
+-----------------------------------------------------------
+
+PREAMBLE
+The goals of the Open Font License (OFL) are to stimulate worldwide
+development of collaborative font projects, to support the font creation
+efforts of academic and linguistic communities, and to provide a free and
+open framework in which fonts may be shared and improved in partnership
+with others.
+
+The OFL allows the licensed fonts to be used, studied, modified and
+redistributed freely as long as they are not sold by themselves. The
+fonts, including any derivative works, can be bundled, embedded,
+redistributed and/or sold with any software provided that any reserved
+names are not used by derivative works. The fonts and derivatives,
+however, cannot be released under any other type of license. The
+requirement for fonts to remain under this license does not apply
+to any document created using the fonts or their derivatives.
+
+DEFINITIONS
+"Font Software" refers to the set of files released by the Copyright
+Holder(s) under this license and clearly marked as such. This may
+include source files, build scripts and documentation.
+
+"Reserved Font Name" refers to any names specified as such after the
+copyright statement(s).
+
+"Original Version" refers to the collection of Font Software components as
+distributed by the Copyright Holder(s).
+
+"Modified Version" refers to any derivative made by adding to, deleting,
+or substituting -- in part or in whole -- any of the components of the
+Original Version, by changing formats or by porting the Font Software to a
+new environment.
+
+"Author" refers to any designer, engineer, programmer, technical
+writer or other person who contributed to the Font Software.
+
+PERMISSION & CONDITIONS
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of the Font Software, to use, study, copy, merge, embed, modify,
+redistribute, and sell modified and unmodified copies of the Font
+Software, subject to the following conditions:
+
+1) Neither the Font Software nor any of its individual components,
+in Original or Modified Versions, may be sold by itself.
+
+2) Original or Modified Versions of the Font Software may be bundled,
+redistributed and/or sold with any software, provided that each copy
+contains the above copyright notice and this license. These can be
+included either as stand-alone text files, human-readable headers or
+in the appropriate machine-readable metadata fields within text or
+binary files as long as those fields can be easily viewed by the user.
+
+3) No Modified Version of the Font Software may use the Reserved Font
+Name(s) unless explicit written permission is granted by the corresponding
+Copyright Holder. This restriction only applies to the primary font name as
+presented to the users.
+
+4) The name(s) of the Copyright Holder(s) or the Author(s) of the Font
+Software shall not be used to promote, endorse or advertise any
+Modified Version, except to acknowledge the contribution(s) of the
+Copyright Holder(s) and the Author(s) or with their explicit written
+permission.
+
+5) The Font Software, modified or unmodified, in part or in whole,
+must be distributed entirely under this license, and must not be
+distributed under any other license. The requirement for fonts to
+remain under this license does not apply to any document created
+using the Font Software.
+
+TERMINATION
+This license becomes null and void if any of the above conditions are
+not met.
+
+DISCLAIMER
+THE FONT SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT
+OF COPYRIGHT, PATENT, TRADEMARK, OR OTHER RIGHT. IN NO EVENT SHALL THE
+COPYRIGHT HOLDER BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
+INCLUDING ANY GENERAL, SPECIAL, INDIRECT, INCIDENTAL, OR CONSEQUENTIAL
+DAMAGES, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+FROM, OUT OF THE USE OR INABILITY TO USE THE FONT SOFTWARE OR FROM
+OTHER DEALINGS IN THE FONT SOFTWARE.
diff --git a/divoc-ptt/artwork/divoc-ptt-intro.svg b/divoc-ptt/artwork/divoc-ptt-intro.svg
new file mode 100644
index 0000000..acec719
--- /dev/null
+++ b/divoc-ptt/artwork/divoc-ptt-intro.svg
@@ -0,0 +1,419 @@
+
+
diff --git a/divoc-ptt/artwork/divoc-ptt-outro.svg b/divoc-ptt/artwork/divoc-ptt-outro.svg
new file mode 100644
index 0000000..2725df4
--- /dev/null
+++ b/divoc-ptt/artwork/divoc-ptt-outro.svg
@@ -0,0 +1,112 @@
+
\ No newline at end of file
diff --git a/sotm2020/__init__.py b/sotm2020/__init__.py
new file mode 100644
index 0000000..df64e9a
--- /dev/null
+++ b/sotm2020/__init__.py
@@ -0,0 +1,200 @@
+#!/usr/bin/python3
+
+import subprocess
+from renderlib import *
+from easing import *
+
+# URL to Schedule-XML
+scheduleUrl = 'https://pretalx.com/fossgis2020/schedule/export/schedule.xml'
+
+# For (really) too long titles
+titlemap = {
+ #708: "Neue WEB-Anwendungen des LGRB Baden-Württemberg im Überblick"
+}
+
+
+def outroFrames(params):
+ # 8 Sekunden
+
+ # 2 Sekunden Fadein Text
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('banderole', 'style', 'opacity', "%.4f" % easeOutCubic(i, 0, 1, frames) ),
+ ('license', 'style', 'opacity', 0)
+ )
+
+ # 2 Sekunde Fadein Lizenz-Logo
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('banderole', 'style', 'opacity', 1),
+ ('license', 'style', 'opacity', "%.4f" % (float(i)/frames))
+ )
+
+ # 4 Sekunde stehen bleiben
+ frames = 4*fps
+ for i in range(0, frames):
+ yield (
+ ('banderole', 'style', 'opacity', 1),
+ ('license', 'style', 'opacity', 1)
+ )
+
+def introFrames(params):
+ # 7 Sekunden
+
+ # 2 Sekunden Text 1
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('box-und-text1', 'style', 'opacity', "%.4f" % easeOutCubic(i, 0, 1, frames)),
+ ('url', 'style', 'opacity', "%.4f" % easeOutCubic(i, 0, 1, frames)),
+ ('text1', 'style', 'opacity', "%.4f" % 1),
+ ('text2', 'style', 'opacity', 0)
+ )
+
+ # 1 Sekunde Fadeout Text 1
+ frames = 1*fps
+ for i in range(0, frames):
+ yield (
+ ('box-und-text1', 'style', 'opacity', 1),
+ ('url', 'style', 'opacity', 1),
+ ('text1', 'style', 'opacity', "%.4f" % (1-(float(i)/frames))),
+ ('text2', 'style', 'opacity', 0)
+ )
+
+ # 2 Sekunden Text 2
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('box-und-text1', 'style', 'opacity', 1),
+ ('url', 'style', 'opacity', 1),
+ ('text1', 'style', 'opacity', 0),
+ ('text2', 'style', 'opacity', "%.4f" % easeOutCubic(i, 0, 1, frames))
+ )
+
+ # 2 Sekunden stehen bleiben
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('box-und-text1', 'style', 'opacity', 1),
+ ('url', 'style', 'opacity', 1),
+ ('text1', 'style', 'opacity', 0),
+ ('text2', 'style', 'opacity', 1)
+ )
+
+def pauseFrames(params):
+ # 12 Sekunden
+
+ # 2 Sekunden Text1 stehen
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('text1', 'style', 'opacity', 1),
+ ('text2', 'style', 'opacity', 0)
+ )
+
+ # 2 Sekunden Fadeout Text1
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('text1', 'style', 'opacity', "%.4f" % (1-easeOutCubic(i, 0, 1, frames))),
+ ('text2', 'style', 'opacity', 0)
+ )
+
+ # 2 Sekunden Fadein Text2
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('text1', 'style', 'opacity', 0),
+ ('text2', 'style', 'opacity', "%.4f" % easeOutCubic(i, 0, 1, frames))
+ )
+
+ # 2 Sekunden Text2 stehen
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('text1', 'style', 'opacity', 0),
+ ('text2', 'style', 'opacity', 1)
+ )
+
+ # 2 Sekunden Fadeout Text2
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('text1', 'style', 'opacity', 0),
+ ('text2', 'style', 'opacity', "%.4f" % (1-easeOutCubic(i, 0, 1, frames)))
+ )
+
+ # 2 Sekunden Fadein Text1
+ frames = 2*fps
+ for i in range(0, frames):
+ yield (
+ ('text1', 'style', 'opacity', "%.4f" % (easeOutCubic(i, 0, 1, frames))),
+ ('text2', 'style', 'opacity', 0)
+ )
+
+def debug():
+ render(
+ 'intro.svg',
+ '../intro.ts',
+ introFrames,
+ {
+ '$id': 904,
+ '$title': 'Was ist Open Source, wie funktioniert das?',
+ '$subtitle': 'Die Organisation der Open Geo- und GIS-Welt. Worauf man achten sollte.',
+ '$personnames': 'Arnulf Christl, Astrid Emde, Dominik Helle, Till Adams'
+ }
+ )
+
+ render(
+ 'outro.svg',
+ '../outro.ts',
+ outroFrames
+ )
+
+ render('pause.svg',
+ '../pause.ts',
+ pauseFrames
+ )
+
+def tasks(queue, args, idlist, skiplist):
+ # iterate over all events extracted from the schedule xml-export
+ for event in events(scheduleUrl):
+ if event['room'] not in ('HS Anatomie', 'HS Rundbau', 'HS Weismannhaus'):
+ print("skipping room %s (%s)" % (event['room'], event['title']))
+ continue
+
+
+ if (event['id'] in idlist or not idlist) and not 'intro' in skiplist:
+ # generate a task description and put them into the queue
+ queue.put(Rendertask(
+ infile = 'intro.svg',
+ outfile = str(event['id'])+".ts",
+ sequence = introFrames,
+ parameters = {
+ '$id': event['id'],
+ '$title': event['title'],
+ '$url': event['url'],
+ #'$subtitle': event['subtitle'],
+ '$personnames': event['personnames']
+ }
+ ))
+
+ if not 'outro' in skiplist:
+ # place a task for the outro into the queue
+ queue.put(Rendertask(
+ infile = 'outro.svg',
+ outfile = 'outro.ts',
+ sequence = outroFrames
+ ))
+
+ if not 'pause' in skiplist:
+ # place the pause-sequence into the queue
+ queue.put(Rendertask(
+ infile = 'pause.svg',
+ outfile = 'pause.ts',
+ sequence = pauseFrames
+ ))
+
+
diff --git a/sotm2020/artwork/by-sa.svg b/sotm2020/artwork/by-sa.svg
new file mode 100644
index 0000000..f850297
--- /dev/null
+++ b/sotm2020/artwork/by-sa.svg
@@ -0,0 +1,199 @@
+
+
+
diff --git a/sotm2020/artwork/intro.svg b/sotm2020/artwork/intro.svg
new file mode 100644
index 0000000..e0ad092
--- /dev/null
+++ b/sotm2020/artwork/intro.svg
@@ -0,0 +1,262 @@
+
+
+
+
diff --git a/sotm2020/artwork/outro.svg b/sotm2020/artwork/outro.svg
new file mode 100644
index 0000000..4bafe68
--- /dev/null
+++ b/sotm2020/artwork/outro.svg
@@ -0,0 +1,354 @@
+
+
+
+
diff --git a/sotm2020/artwork/pause.svg b/sotm2020/artwork/pause.svg
new file mode 100644
index 0000000..d1342ee
--- /dev/null
+++ b/sotm2020/artwork/pause.svg
@@ -0,0 +1,199 @@
+
+
+
+
diff --git a/sotm2020/artwork/sotm2020logo.png b/sotm2020/artwork/sotm2020logo.png
new file mode 100644
index 0000000..917b20f
Binary files /dev/null and b/sotm2020/artwork/sotm2020logo.png differ
diff --git a/sotm2020/artwork/uct.jpg b/sotm2020/artwork/uct.jpg
new file mode 100644
index 0000000..f00da7a
Binary files /dev/null and b/sotm2020/artwork/uct.jpg differ