Mercurial > fife-parpg
view tests/swig_tests/video_tests.py @ 100:69a7d40ccf62
added hashing to pool to improve techdemo loading time
author | jasoka@33b003aa-7bff-0310-803a-e67f0ece8222 |
---|---|
date | Tue, 22 Jul 2008 13:07:51 +0000 |
parents | 4a0efb7baf70 |
children | d2f1e81fbe2c |
line wrap: on
line source
#!/usr/bin/env python from swig_test_utils import * from serializers.xmlanimation import XMLAnimationLoader class TestVideo(unittest.TestCase): def setUp(self): self.engine = getEngine() def tearDown(self): del self.engine def testSimpleAnimation(self): pool = self.engine.getAnimationPool() animationloader = XMLAnimationLoader(self.engine.getImagePool(), self.engine.getVFS()) pool.addResourceLoader(animationloader) id = pool.addResourceFromFile('tests/data/wolf_walk/wolf_walk_sw.xml') animation = pool.getAnimation(id) self.engine.initializePumping() backend = self.engine.getRenderBackend() gettime = self.engine.getTimeManager().getTime starttime = gettime() for i in xrange(50): image = animation.getFrameByTimestamp(gettime() - starttime) if not image: image = animation.getFrame(0) starttime = gettime() #print fife.Rect(0,0,image.getWidth(),image.getHeight()) image.render(fife.Rect(0,0,image.getWidth(),image.getHeight()), 255) self.engine.pump() self.engine.finalizePumping() def testDrawLine(self): points = ( (1,1), (50,20), (20,50), (200,500), (500,200), (100,200), (10,10), (70,40), (80,30), (300,520), (340,220), (170,600), ) self.engine.initializePumping() be = self.engine.getRenderBackend() for i in xrange(20): prevPt = fife.Point(*points[1]) for pt in points[1:]: curPt = fife.Point(*pt) be.drawLine(prevPt, curPt, 100, 100, 100) prevPt = curPt self.engine.pump() self.engine.finalizePumping() TEST_CLASSES = [TestVideo] if __name__ == '__main__': unittest.main()