diff --git a/mm17/__init__.py b/mm17/__init__.py
new file mode 100644
index 0000000..42ff9fb
--- /dev/null
+++ b/mm17/__init__.py
@@ -0,0 +1,129 @@
+#!/usr/bin/python3
+
+from renderlib import *
+from easing import *
+
+# URL to Schedule-XML
+scheduleUrl = 'https://c3voc.de/share/schedules/mm17.xml'
+
+def introFrames(args):
+#show for 1 second
+ frames = 1*fps
+ for i in range(0, frames):
+ yield (
+ ('title', 'style', 'opacity', 0),
+ ('persons', 'style', 'opacity', 0),
+ ('persons2', 'style', 'opacity', 0),
+ )
+
+#fade in 2 seconds
+ frames = 2*fps
+ for i in range(0, frames):
+ yield(
+ ('title', 'style', 'opacity', easeInQuad(i, 0, 1, frames)),
+ ('persons', 'style', 'opacity', easeInQuad(i, 0, 1, frames)),
+ ('persons2', 'style', 'opacity', easeInQuad(i, 0, 1, frames)),
+ )
+
+#show for 5 seconds
+ frames = 5*fps
+ for i in range(0, frames):
+ yield(
+ ('title', 'style', 'opacity', 1),
+ ('persons', 'style', 'opacity', 1),
+ ('persons2', 'style', 'opacity', 1),
+ )
+
+def backgroundFrames(arg):
+#show for 1 second
+ frames = 1*fps
+ for i in range(0, frames):
+ yield tuple()
+
+def outroFrames(args):
+# show for 6 seconds
+ frames = 6*fps
+ for i in range(0, frames):
+ yield tuple()
+
+def pauseFrames(args):
+# show for 1 second
+ frames = 1*fps
+ for i in range(0, frames):
+ yield tuple()
+
+def debug():
+ render('intro.svg',
+ '../intro.ts',
+ introFrames,
+ {
+ '$title': 'Make Munich Vortag',
+ '$persons1': 'MM17 1',
+ '$persons2': 'MM17 2'
+ }
+ )
+
+ render('outro.svg',
+ '../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 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 = 'intro.svg',
+ outfile = str(event['id'])+".ts",
+ sequence = introFrames,
+ parameters = {
+ '$id': event['id'],
+ '$title': event['title'],
+ '$persons1': event['personnames'].upper(),
+ '$persons2': event['personnames2'].upper()
+ }
+ ))
+
+ # place a task for the outro into the queue
+ if not "out" in skiplist:
+ queue.put(Rendertask(
+ infile = 'outro.svg',
+ outfile = 'outro.ts',
+ sequence = outroFrames
+ ))
+
+ # place the pause-sequence into the queue
+ if not "pause" in skiplist:
+ queue.put(Rendertask(
+ infile = 'pause.svg',
+ outfile = 'pause.ts',
+ sequence = pauseFrames
+ ))
+
+ # place the background-sequence into the queue
+ if not "bg" in skiplist:
+ queue.put(Rendertask(
+ infile = 'background.svg',
+ outfile = 'background.ts',
+ sequence = backgroundFrames
+ ))
diff --git a/mm17/artwork/Hintergrund-komplett1920x1080RGB_V2.jpg b/mm17/artwork/Hintergrund-komplett1920x1080RGB_V2.jpg
new file mode 100644
index 0000000..0cd374f
Binary files /dev/null and b/mm17/artwork/Hintergrund-komplett1920x1080RGB_V2.jpg differ
diff --git a/mm17/artwork/background.svg b/mm17/artwork/background.svg
new file mode 100644
index 0000000..0629f6f
--- /dev/null
+++ b/mm17/artwork/background.svg
@@ -0,0 +1,66 @@
+
+
+
+
diff --git a/mm17/artwork/intro.svg b/mm17/artwork/intro.svg
new file mode 100644
index 0000000..b5c06f6
--- /dev/null
+++ b/mm17/artwork/intro.svg
@@ -0,0 +1,157 @@
+
+
+
+
\ No newline at end of file
diff --git a/mm17/artwork/outro.svg b/mm17/artwork/outro.svg
new file mode 100644
index 0000000..9a0e627
--- /dev/null
+++ b/mm17/artwork/outro.svg
@@ -0,0 +1,186 @@
+
+
+
+
\ No newline at end of file
diff --git a/mm17/artwork/pause.svg b/mm17/artwork/pause.svg
new file mode 100644
index 0000000..d164c00
--- /dev/null
+++ b/mm17/artwork/pause.svg
@@ -0,0 +1,106 @@
+
+
+
+
\ No newline at end of file
diff --git a/renderlib.py b/renderlib.py
index 33cfcf1..4a3dd7e 100644
--- a/renderlib.py
+++ b/renderlib.py
@@ -195,11 +195,21 @@ def events(scheduleUrl, titlemap={}):
# iterate events on that day in this room
for event in room.iter('event'):
# aggregate names of the persons holding this talk
+ persons = []
personnames = []
+ personnames2 = []
if event.find('persons') is not None:
for person in event.find('persons').iter('person'):
personname = re.sub( '\s+', ' ', person.text ).strip()
- personnames.append(personname)
+ personname = personname.split(",")[0]
+ persons.append(personname)
+
+ i = iter(persons)
+ personnames = [ next(i) ]
+ try:
+ personnames2 = [ next(i) ]
+ except StopIteration:
+ pass
id = int(event.get('id'))
@@ -220,8 +230,8 @@ def events(scheduleUrl, titlemap={}):
'id': id,
'title': title,
'subtitle': subtitle,
- 'persons': personnames,
- 'personnames': ', '.join(personnames),
+ 'personnames': ''.join(personnames),
+ 'personnames2': ''.join(personnames2),
'room': room.attrib['name'],
}