def test_3D_single_duration_no_loop(self): from lepton.texturizer import FlipBookTexturizer coord_sets = [ (0,0,0, 1,0,0, 1,1,0, 0,1,0), (0,0,0.5, 1,0,0.5, 1,1,0.5, 0,1,0.5), (0,0,1, 1,0,1, 1,1,1, 0,1,1), ] fbtex = FlipBookTexturizer(0, coords=coord_sets, duration=0.12, dimension=3, loop=False, ) self.assertEqual(fbtex.tex_dimension, 3) self.assertAlmostEqual(fbtex.duration, 0.12) self.failIf(fbtex.loop) group = self._make_group(10) age = 0.0 for p in group: p.age = age % 0.4 age += 0.07 times = [0.12, 0.24, 0.36] for f in range(5): coords = tuple(fbtex.generate_tex_coords(group)) self.failUnless(len(coords) >= len(group) * 12, (len(coords), len(group))) i = 0 for p, t in zip(group, times): c = 0 while c < 2 and p.age > times[c]: c += 1 self.assertEqual(coords[i:i+12], coord_sets[c], "f=%s i=%s c=%s age=%s: %s != %s" % (f, i, c, p.age, coords[i:i+12], coord_sets[c])) i += 12 group.update(0.055)
def test_2D_single_duration_loop(self): from lepton.texturizer import FlipBookTexturizer coord_sets = [ (0, 0, 0.5, 0, 0.5, 0.5, 0, 0.5), (0.5, 0, 1, 0, 1, 0.5, 0.5, 0.5), (0, 0.5, 0.5, 0.5, 0.5, 1, 0, 1), (0.5, 0.5, 1, 0.5, 1, 1, 0.5, 1), ] fbtex = FlipBookTexturizer( 0, coords=coord_sets, duration=0.1, ) self.failUnless(fbtex.loop) self.assertAlmostEqual(fbtex.duration, 0.1) self.assertEqual(fbtex.tex_dimension, 2) group = self._make_group(10) age = 0.0 for p in group: p.age = age age += 0.06 coords = tuple(fbtex.generate_tex_coords(group)) self.failUnless( len(coords) >= len(group) * 8, (len(coords), len(group))) self.assertEqual(coords[:8], coord_sets[0]) self.assertEqual(coords[8:16], coord_sets[0]) self.assertEqual(coords[16:24], coord_sets[1]) self.assertEqual(coords[24:32], coord_sets[1]) self.assertEqual(coords[32:40], coord_sets[2]) self.assertEqual(coords[40:48], coord_sets[3]) self.assertEqual(coords[48:56], coord_sets[3]) self.assertEqual(coords[56:64], coord_sets[0]) self.assertEqual(coords[64:72], coord_sets[0]) self.assertEqual(coords[72:80], coord_sets[1]) # Next frame group.update(0.05) coords = tuple(fbtex.generate_tex_coords(group)) self.assertEqual(coords[:8], coord_sets[0]) self.assertEqual(coords[8:16], coord_sets[1]) self.assertEqual(coords[16:24], coord_sets[1]) self.assertEqual(coords[24:32], coord_sets[2]) self.assertEqual(coords[32:40], coord_sets[2]) self.assertEqual(coords[40:48], coord_sets[3]) self.assertEqual(coords[48:56], coord_sets[0]) self.assertEqual(coords[56:64], coord_sets[0]) self.assertEqual(coords[64:72], coord_sets[1]) self.assertEqual(coords[72:80], coord_sets[1])
def test_2D_single_duration_loop(self): from lepton.texturizer import FlipBookTexturizer coord_sets = [ (0,0, 0.5,0, 0.5,0.5, 0,0.5), (0.5,0, 1,0, 1,0.5, 0.5,0.5), (0,0.5, 0.5,0.5, 0.5,1, 0,1), (0.5,0.5, 1,0.5, 1,1, 0.5,1), ] fbtex = FlipBookTexturizer(0, coords=coord_sets, duration=0.1, ) self.failUnless(fbtex.loop) self.assertAlmostEqual(fbtex.duration, 0.1) self.assertEqual(fbtex.tex_dimension, 2) group = self._make_group(10) age = 0.0 for p in group: p.age = age age += 0.06 coords = tuple(fbtex.generate_tex_coords(group)) self.failUnless(len(coords) >= len(group) * 8, (len(coords), len(group))) self.assertEqual(coords[:8], coord_sets[0]) self.assertEqual(coords[8:16], coord_sets[0]) self.assertEqual(coords[16:24], coord_sets[1]) self.assertEqual(coords[24:32], coord_sets[1]) self.assertEqual(coords[32:40], coord_sets[2]) self.assertEqual(coords[40:48], coord_sets[3]) self.assertEqual(coords[48:56], coord_sets[3]) self.assertEqual(coords[56:64], coord_sets[0]) self.assertEqual(coords[64:72], coord_sets[0]) self.assertEqual(coords[72:80], coord_sets[1]) # Next frame group.update(0.05) coords = tuple(fbtex.generate_tex_coords(group)) self.assertEqual(coords[:8], coord_sets[0]) self.assertEqual(coords[8:16], coord_sets[1]) self.assertEqual(coords[16:24], coord_sets[1]) self.assertEqual(coords[24:32], coord_sets[2]) self.assertEqual(coords[32:40], coord_sets[2]) self.assertEqual(coords[40:48], coord_sets[3]) self.assertEqual(coords[48:56], coord_sets[0]) self.assertEqual(coords[56:64], coord_sets[0]) self.assertEqual(coords[64:72], coord_sets[1]) self.assertEqual(coords[72:80], coord_sets[1])
def test_3D_duration_list_no_loop(self): from lepton.texturizer import FlipBookTexturizer coord_sets = [ (0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0), (0, 0, 0.5, 1, 0, 0.5, 1, 1, 0.5, 0, 1, 0.5), (0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 1, 1), ] durations = [0.4, 0.4, 0.5] times = [] t = 0 for d in durations: t += d times.append(t) fbtex = FlipBookTexturizer( 0, coords=coord_sets, duration=durations, dimension=3, loop=False, ) self.assertEqual(fbtex.tex_dimension, 3) self.failIf(fbtex.loop) for d, expected in zip(fbtex.duration, durations): self.assertAlmostEqual(d, expected, 6) group = self._make_group(10) age = 0.0 for p in group: p.age = age % 0.5 age += 0.07 for f in range(5): coords = tuple(fbtex.generate_tex_coords(group)) self.failUnless( len(coords) >= len(group) * 12, (len(coords), len(group))) i = 0 for p, t in zip(group, times): c = 0 while c < 2 and p.age > times[c]: c += 1 self.assertEqual( coords[i:i + 12], coord_sets[c], "f=%s i=%s c=%s age=%s: %s != %s" % (f, i, c, p.age, coords[i:i + 12], coord_sets[c])) i += 12 group.update(0.17)
def test_2D_duration_list_loop(self): from lepton.texturizer import FlipBookTexturizer coord_sets = [ (0, 0, 0.5, 0, 0.5, 0.5, 0, 0.5), (0.5, 0, 1, 0, 1, 0.5, 0.5, 0.5), (0, 0.5, 0.5, 0.5, 0.5, 1, 0, 1), (0.5, 0.5, 1, 0.5, 1, 1, 0.5, 1), ] durations = (0.12, 0.3, 0.2, 0.15) times = [] t = 0 for d in durations: t += d times.append(t) fbtex = FlipBookTexturizer( 0, coords=coord_sets, duration=durations, ) self.failUnless(fbtex.loop) for d, expected in zip(fbtex.duration, durations): self.assertAlmostEqual(d, expected) group = self._make_group(10) age = 0.0 for p in group: p.age = age % 2.0 age += 0.7 for f in range(5): coords = tuple(fbtex.generate_tex_coords(group)) self.failUnless( len(coords) >= len(group) * 8, (len(coords), len(group))) i = 0 for p, t in zip(group, times): age = p.age % times[-1] c = 0 while c < 3 and age > times[c]: c += 1 self.assertEqual( coords[i:i + 8], coord_sets[c], "f=%s i=%s c=%s age=%s: %s != %s" % (f, i, c, p.age, coords[i:i + 8], coord_sets[c])) i += 8 group.update(0.2)
def test_3D_duration_list_no_loop(self): from lepton.texturizer import FlipBookTexturizer coord_sets = [ (0,0,0, 1,0,0, 1,1,0, 0,1,0), (0,0,0.5, 1,0,0.5, 1,1,0.5, 0,1,0.5), (0,0,1, 1,0,1, 1,1,1, 0,1,1), ] durations = [0.4, 0.4, 0.5] times = [] t = 0 for d in durations: t += d times.append(t) fbtex = FlipBookTexturizer(0, coords=coord_sets, duration=durations, dimension=3, loop=False, ) self.assertEqual(fbtex.tex_dimension, 3) self.failIf(fbtex.loop) for d, expected in zip(fbtex.duration, durations): self.assertAlmostEqual(d, expected, 6) group = self._make_group(10) age = 0.0 for p in group: p.age = age % 0.5 age += 0.07 for f in range(5): coords = tuple(fbtex.generate_tex_coords(group)) self.failUnless(len(coords) >= len(group) * 12, (len(coords), len(group))) i = 0 for p, t in zip(group, times): c = 0 while c < 2 and p.age > times[c]: c += 1 self.assertEqual(coords[i:i+12], coord_sets[c], "f=%s i=%s c=%s age=%s: %s != %s" % (f, i, c, p.age, coords[i:i+12], coord_sets[c])) i += 12 group.update(0.17)
def test_2D_duration_list_loop(self): from lepton.texturizer import FlipBookTexturizer coord_sets = [ (0,0, 0.5,0, 0.5,0.5, 0,0.5), (0.5,0, 1,0, 1,0.5, 0.5,0.5), (0,0.5, 0.5,0.5, 0.5,1, 0,1), (0.5,0.5, 1,0.5, 1,1, 0.5,1), ] durations = (0.12, 0.3, 0.2, 0.15) times = [] t = 0 for d in durations: t += d times.append(t) fbtex = FlipBookTexturizer(0, coords=coord_sets, duration=durations, ) self.failUnless(fbtex.loop) for d, expected in zip(fbtex.duration, durations): self.assertAlmostEqual(d, expected) group = self._make_group(10) age = 0.0 for p in group: p.age = age % 2.0 age += 0.7 for f in range(5): coords = tuple(fbtex.generate_tex_coords(group)) self.failUnless(len(coords) >= len(group) * 8, (len(coords), len(group))) i = 0 for p, t in zip(group, times): age = p.age % times[-1] c = 0 while c < 3 and age > times[c]: c += 1 self.assertEqual(coords[i:i+8], coord_sets[c], "f=%s i=%s c=%s age=%s: %s != %s" % (f, i, c, p.age, coords[i:i+8], coord_sets[c])) i += 8 group.update(0.2)
def test_3D_single_duration_no_loop(self): from lepton.texturizer import FlipBookTexturizer coord_sets = [ (0, 0, 0, 1, 0, 0, 1, 1, 0, 0, 1, 0), (0, 0, 0.5, 1, 0, 0.5, 1, 1, 0.5, 0, 1, 0.5), (0, 0, 1, 1, 0, 1, 1, 1, 1, 0, 1, 1), ] fbtex = FlipBookTexturizer( 0, coords=coord_sets, duration=0.12, dimension=3, loop=False, ) self.assertEqual(fbtex.tex_dimension, 3) self.assertAlmostEqual(fbtex.duration, 0.12) self.failIf(fbtex.loop) group = self._make_group(10) age = 0.0 for p in group: p.age = age % 0.4 age += 0.07 times = [0.12, 0.24, 0.36] for f in range(5): coords = tuple(fbtex.generate_tex_coords(group)) self.failUnless( len(coords) >= len(group) * 12, (len(coords), len(group))) i = 0 for p, t in zip(group, times): c = 0 while c < 2 and p.age > times[c]: c += 1 self.assertEqual( coords[i:i + 12], coord_sets[c], "f=%s i=%s c=%s age=%s: %s != %s" % (f, i, c, p.age, coords[i:i + 12], coord_sets[c])) i += 12 group.update(0.055)