當前位置: 首頁>>代碼示例>>Python>>正文


Python Timer.update方法代碼示例

本文整理匯總了Python中utils.Timer.update方法的典型用法代碼示例。如果您正苦於以下問題:Python Timer.update方法的具體用法?Python Timer.update怎麽用?Python Timer.update使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在utils.Timer的用法示例。


在下文中一共展示了Timer.update方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: Animation

# 需要導入模塊: from utils import Timer [as 別名]
# 或者: from utils.Timer import update [as 別名]
class Animation(object):

    def __init__(self, screen, pos, images, scroll_period, duration=-1):
        """
        If duration == -1, animation goes on indefinetly.
        """

        self.screen = screen
        self.pos = pos
        self.images = [pygame.image.load(image) for image in images]
        self.image_ptr = 0
        self.scroll_period = scroll_period
        self.duration = duration
        self.active = True

        self.scroll_timer = Timer(scroll_period, self.advance_images)
        self.active_timer = Timer(duration, self.inactivate, 1)

    def update(self, time_passed):
        if self.active:
            self.scroll_timer.update(time_passed)
            self.active_timer.update(time_passed)

    def blitme(self):
        if self.active:
            self.update_rect()
            self.screen.blit(self.images[self.image_ptr], self.rect)

    def update_rect(self):
        image_w, image_h = self.images[self.image_ptr].get_size()

        self.rect = self.images[self.image_ptr].get_rect().move(
            self.pos.x - image_w / 2,
            self.pos.y - image_h / 2)

    def advance_images(self):
        self.image_ptr = (self.image_ptr + 1) % len(self.images)

    def inactivate(self):
        if self.duration >= 0:
            self.active = False
開發者ID:fifiman,項目名稱:Asteroid-Shooter,代碼行數:43,代碼來源:animation.py

示例2: RunTime

# 需要導入模塊: from utils import Timer [as 別名]
# 或者: from utils.Timer import update [as 別名]
class RunTime(object):
    def __init__(self):
        # behaviour update callbacks
        self.behav_callbacks = []
        self.init_time = time()
        self.current_time = 0
        self.timer = Timer()

    def run(self):
        while True:
            # update all the behaviours
            for cb in self.behav_callbacks:
                cb(self.current_time)
            # notify all the timer events
            self.timer.update(self.current_time)
            # TODO fps control
            sleep(0.1)
            self.current_time = time()-self.init_time

    def register(self, callback):
        self.behav_callbacks.append(callback)
開發者ID:yihuang,項目名稱:huangyilib,代碼行數:23,代碼來源:runtime.py

示例3: Game

# 需要導入模塊: from utils import Timer [as 別名]
# 或者: from utils.Timer import update [as 別名]
class Game(object):

    def __init__(self):

        pygame.init()

        self.screen = pygame.display.set_mode(
            (SCREEN_WIDTH, SCREEN_HEIGHT), 0, 32)
        self.clock = pygame.time.Clock()

        # Game states
        self.paused = 0
        self.game_over = 0
        self.running = 1
        self.keep_drawing_ship = 1

        # Game objects
        self.ship = ship.Ship(
            self.screen, (SCREEN_WIDTH / 2, SCREEN_HEIGHT / 2))
        self.asteroids = []
        self.bullets = []

        # Scoreboard
        self.score = 0
        self.scoreboard = Scoreboard(self.screen)

        # Bullet Gauge
        self.bullet_gauge = BulletGauge(self.screen, 10, self.spawn_bullet)

        # Health bar
        self.health_bar = Bar(self.screen, self.ship.max_health,
                              [30, SCREEN_HEIGHT - 20,
                               80, 10],
                              RED, WHITE)
        # Game Over Text
        self.game_over_text = GameOverText(self.screen)
        self.reduce_game_over_text_alpha = Timer(
            100, self.game_over_text.reduce_alpha)

        # Asteroid spawning
        self.since_last_asteroid = 0
        self.new_asteroid_time = 1000

        # Levels
        self.level_gen = generate_levels()
        self.level = 1
        self.level_limit = next(self.level_gen)

        self.level_text = LevelText(self.screen)

    def run(self):

        while self.running:

            time_passed = self.clock.tick(60)

            # KEYBOARD INPUT
            for event in pygame.event.get():
                if event.type == pygame.QUIT:
                    self.running = 0
                    break

                if event.type == pygame.KEYDOWN:
                    if event.key == pygame.K_ESCAPE:
                        self.running = 0
                        break
                    if event.key == pygame.K_SPACE:
                        if not self.paused and not self.game_over:
                            self.bullet_gauge.shoot()

                    if event.key == pygame.K_p:
                        self.paused = not self.paused

            if not self.paused and not self.game_over:
                self.update(time_passed)

            if self.game_over:
                self.update_game_over_sequence(time_passed)

            self.draw()

    def update(self, time_passed):
        # Send keyboard input
        self.ship.handleKeyevents(pygame.key.get_pressed())

        # Object updates
        self.ship.update(time_passed)

        for bullet in self.bullets:
            bullet.update(time_passed)

        for asteroid in self.asteroids:
            asteroid.update(time_passed, self.ship.pos)

        # Maintenance functions
        self.ship.keep_in_bounds()
        self.maintain_bullets()
        self.maintain_asteroids()

        # Collisions
#.........這裏部分代碼省略.........
開發者ID:fifiman,項目名稱:Asteroid-Shooter,代碼行數:103,代碼來源:game.py

示例4: Game

# 需要導入模塊: from utils import Timer [as 別名]
# 或者: from utils.Timer import update [as 別名]

#.........這裏部分代碼省略.........
                Color(50, 50, 50),
                (self.field_rect.left, self.field_rect.top + y * self.GRID_SIZE - 1),
                (self.field_rect.right - 1, self.field_rect.top + y * self.GRID_SIZE - 1))
        
        for x in range(self.grid_ncols + 1):
            pygame.draw.line(
                self.screen,
                Color(50, 50, 50),
                (self.field_rect.left + x * self.GRID_SIZE - 1, self.field_rect.top),
                (self.field_rect.left + x * self.GRID_SIZE - 1, self.field_rect.bottom - 1))
    
    def draw_walls(self):
        wallcolor = Color(140, 140, 140)
        
        for wall in self.walls:
            nrow, ncol = wall
            
            pos_x = self.field_rect.left + ncol * self.GRID_SIZE + self.GRID_SIZE / 2
            pos_y = self.field_rect.top + nrow * self.GRID_SIZE + self.GRID_SIZE / 2
            radius = 3
            
            pygame.draw.polygon(self.screen, wallcolor,
                [   (pos_x - radius, pos_y), (pos_x, pos_y + radius),
                    (pos_x + radius, pos_y), (pos_x, pos_y - radius)])
            
            if (nrow + 1, ncol) in self.walls:
                pygame.draw.line(self.screen, wallcolor,
                    (pos_x, pos_y), (pos_x, pos_y + self.GRID_SIZE), 3)
            if (nrow, ncol + 1) in self.walls:
                pygame.draw.line(self.screen, wallcolor,
                    (pos_x, pos_y), (pos_x + self.GRID_SIZE, pos_y), 3)
    
    def draw(self):
        self.draw_background()
        self.field_box.draw()
        
        if self.options['draw_grid']:
            self.draw_grid()
        
        self.draw_walls()
        
        self.tboard.draw()
        self.mboard.text = self.mboard_text
        self.mboard.draw()
        
        for creep in self.creeps:
            creep.draw()
        
        self.draw_portals()
        
    def run(self):
        # The main game loop
        #
        while True:
            # Limit frame speed to 30 FPS
            #
            time_passed = self.clock.tick(30)
            #~ time_passed = self.clock.tick()
            #~ print time_passed
            
            # If too long has passed between two frames, don't
            # update (the game must have been suspended for some
            # reason, and we don't want it to "jump forward"
            # suddenly)
            #
            if time_passed > 100:
                continue
            
            for event in pygame.event.get():
                if event.type == pygame.QUIT:
                    self.quit()
                elif event.type == pygame.KEYDOWN:
                    if event.key == pygame.K_SPACE:
                        self.paused = not self.paused
                    elif event.key == pygame.K_g:
                        if pygame.key.get_mods() & pygame.KMOD_CTRL:
                            self.options['draw_grid'] = not self.options['draw_grid']
                elif (  event.type == pygame.MOUSEBUTTONDOWN and
                        event.button == 1):
                    for creep in self.creeps:
                        creep.mouse_click_event(event.pos)
            
            if not self.paused:
                msg1 = 'Creeps: %d' % len(self.creeps)
                msg2 = ''

                self.mboard_text = [msg1, msg2]
                
                self.creep_spawn_timer.update(time_passed)
                
                # Update and all creeps
                for creep in self.creeps:
                    creep.update(time_passed)
                    
                self.draw()
                
            pygame.display.flip()

    def quit(self):
        sys.exit()
開發者ID:AssaultKoder95,項目名稱:code-for-blog,代碼行數:104,代碼來源:creeps.py

示例5: Game

# 需要導入模塊: from utils import Timer [as 別名]
# 或者: from utils.Timer import update [as 別名]

#.........這裏部分代碼省略.........
                                       self.field_rect.top +self.GRID_SIZE/2),
                       init_direction = (1,1),
                       speed = 0.05 ) )
        self.spawned_creep_count += 1

    def getFieldRect(self):
        return self.field_box.get_internal_rect()

    def drawBackground(self):
        img_rect = self.tile_img.get_rect()
        nrows = int(self.screen.get_height()/img_rect.height) + 1
        ncols = int(self.screen.get_width() /img_rect.width) + 1
        for y in range(nrows):
            for x in range(ncols):
                img_rect.topleft = x*img_rect.width, y*img_rect.height
                self.screen.blit(self.tile_img, img_rect)

    def drawPostals(self):
        self.entrance_rect = pygame.Rect(self.field_rect.left, self.field_rect.top,
                                         2*self.GRID_SIZE,2*self.GRID_SIZE)
        self.exit_rect = pygame.Rect(self.field_rect.right - 2*self.GRID_SIZE,
                                     self.field_rect.bottom - 2*self.GRID_SIZE,
                                     2*self.GRID_SIZE, 2*self.GRID_SIZE)
        entrance = pygame.Surface( (self.entrance_rect.w, self.entrance_rect.h) )
        entrance.fill(pygame.Color(80,200,80) )
        entrance.set_alpha(150)
        self.screen.blit(entrance,self.entrance_rect)
        exit = pygame.Surface( (self.exit_rect.w,self.exit_rect.h) )
        exit.fill( pygame.Color(80,200,80) )
        exit.set_alpha(150)
        self.screen.blit(exit,self.exit_rect)

    def drawGrid(self):
        for y in range(self.grid_nrows+1):
            pygame.draw.line(self.screen, pygame.Color(50,50,50),
                    (self.field_rect.left, self.field_rect.top+y*self.GRID_SIZE-1),
                    (self.field_rect.right, self.field_rect.top + y*self.GRID_SIZE-1) )
        for x in range(self.grid_ncols+1):
            pygame.draw.line(self.screen,pygame.Color(50,50,50),
                    (self.field_rect.left + x*self.GRID_SIZE-1,self.field_rect.top),
                    (self.field_rect.left + x*self.GRID_SIZE-1,self.field_rect.bottom-1) )
    def drawWalls(self):
        wallcolor = pygame.Color(140,140,140)
        for wall in self.walls:
            row, col = wall
            pos_x = self.field_rect.left + col*self.GRID_SIZE + self.GRID_SIZE/2
            pos_y = self.field_rect.top +  row*self.GRID_SIZE + self.GRID_SIZE/2
            radius = 3
            pygame.draw.polygon(self.screen, wallcolor,
                    [ (pos_x - radius, pos_y),(pos_x,pos_y + radius),
                      (pos_x + radius, pos_y), (pos_x,pos_y-radius) ] )
            if (row+1,col) in self.walls:
                pygame.draw.line(self.screen, wallcolor, (pos_x,pos_y),(pos_x,pos_y+self.GRID_SIZE),3 )
            if (row, col+1) in self.walls:
                pygame.draw.line(self.screen, wallcolor, (pos_x,pos_y),(pos_x+self.GRID_SIZE,pos_y),3)

    def draw(self):
        self.drawBackground()
        self.field_box.draw()
        if self.options['draw_grid']: self.drawGrid()
        self.drawWalls()
        self.tboard.draw()
        self.mboard.text = self.mboard_text
        self.mboard.draw()
        for creep in self.creeps:
            creep.draw()
        self.drawPostals()

    def onEvent(self,event):
        if event.type == pygame.QUIT:
            self.quit()
        elif event.type == pygame.KEYDOWN:
            if event.key == pygame.K_SPACE:
                self.paused = not self.paused
            elif event.key == pygame.K_g:
                if pygame.key.get_mods() & pygame.KMOD_CTRL:
                    self.options['draw_grid'] = not self.options['draw_grid']
        elif event.type == pygame.MOUSEBUTTONDOWN and event.button == 1:
            for creep in self.creeps:
                creep.mouseClickEvent(event.pos)

    def run(self):

        while True:
            time_passed = self.clock.tick(30)
            if time_passed > 100: continue
            for event in pygame.event.get():
                self.onEvent(event)
            if not self.paused:
                msg1 = 'Creeps:%d' %len(self.creeps)
                msg2 = ''
                self.mboard_text = [msg1,msg2]
                self.creep_spawn_timer.update(time_passed)
                # update and all creeps
                for creep in self.creeps:
                    creep.update(time_passed)
                self.draw()
            pygame.display.flip()
    def quit(self):
        sys.exit()
開發者ID:MeetLuck,項目名稱:works,代碼行數:104,代碼來源:creep2.py

示例6: Simulation

# 需要導入模塊: from utils import Timer [as 別名]
# 或者: from utils.Timer import update [as 別名]
class Simulation(object):
    """ 
    The main simulation entry point 
    """

    # basic defaults
    SCREEN_WIDTH, SCREEN_HEIGHT = 700, 700
    GRID_SIZE = 20, 20
    FIELD_SIZE = 500, 500
    FIELD_LIMITS = 0, 0, 600, 600
    field_bgcolor = SIM_COLORS['white']

    def __init__(self, params=None):
        pygame.init()

        if params is not None:
            self.SCREEN_HEIGHT, self.SCREEN_WIDTH = int(float(params['display']['height']) * SCALE), \
                                                    int(float(params['display']['width']) * SCALE)
            self.FIELD_LIMITS = int(float(params['field_top_left_x']) * SCALE), \
                                int(float(params['field_top_left_y']) * SCALE), \
                                int(float(params['field_bottom_right_x']) * SCALE), \
                                int(float(params['field_bottom_right_y']) * SCALE)
            self.FIELD_SIZE = self.FIELD_LIMITS[2] - self.FIELD_LIMITS[0], self.FIELD_LIMITS[3] - self.FIELD_LIMITS[1]
            self.GRID_SIZE = int(float(params['cell']['width']) * SCALE), int(float(params['cell']['height']) * SCALE)

        # zoom and centering
        self.offset = 0, 0
        self.zoom_factor = 1.0
        self._old_screen = self.SCREEN_WIDTH, self.SCREEN_HEIGHT

        # setup the screen and the box field of play
        self.initialize_screen()

        # agents
        self.agents = pygame.sprite.Group()
        self.agent_image = pygame.image.load('assets/blueagent.bmp').convert_alpha()
        self.controller = SocialForceController(self)
        # self.controller = RandomController(self)

        # time related items
        self.clock = pygame.time.Clock()
        self.paused = False
        self.simulation_timer = Timer(10, self.simulation_update)

        # create the grid
        self.setup_grid()

        # additional options (remove this)
        self.options = dict(draw_grid=True)

        # setup objects (waypoints, obstacles)
        self.waypoints = dict()
        self.obstacles = []
        self._agent_count = 0

        # initialize the time
        self.time_passed = 0


    def initialize_screen(self):
        self.screen = pygame.display.set_mode((self.SCREEN_WIDTH, self.SCREEN_HEIGHT),
                                              HWSURFACE | DOUBLEBUF | RESIZABLE, 32)
        self.field_rect_outer = Rect(self.FIELD_LIMITS[0],
                                     self.FIELD_LIMITS[1],
                                     int(self.FIELD_SIZE[0]*self.zoom_factor),
                                     int(self.FIELD_SIZE[1]*self.zoom_factor))

        self.field_box = Box(surface=self.screen,
            rect=self.field_rect_outer, 
            background_color=self.field_bgcolor
        )

        self.field_rect = self.field_box.get_internal_rect()

    def setup_grid(self):
        self.grid_nrows = self.FIELD_SIZE[1] / int(self.GRID_SIZE[0]*self.zoom_factor)
        self.grid_ncols = self.FIELD_SIZE[0] / int(self.GRID_SIZE[1]*self.zoom_factor)

    def get_agent_neighbors(self, agent, dist_range):
        neighbors = []
        for other in self.agents:
            if not agent.id == other.id:
                dist = agent.position.get_distance(other.position)
                if dist <= dist_range:
                    neighbors.append(other)

        return neighbors

    def draw_grid(self):
        for y in range(self.grid_nrows + 1):
            pygame.draw.line(
                self.screen,
                SIM_COLORS['light gray'],
                (self.field_rect.left, self.field_rect.top + y * int(self.GRID_SIZE[1]*self.zoom_factor) - 1),
                (self.field_rect.right - 1, self.field_rect.top + y * int(self.GRID_SIZE[1]*self.zoom_factor) - 1))
        
        for x in range(self.grid_ncols + 1):
            pygame.draw.line(
                self.screen,
                SIM_COLORS['light gray'],
#.........這裏部分代碼省略.........
開發者ID:hohiroki,項目名稱:crowdsim,代碼行數:103,代碼來源:crowdsim.py

示例7: test_timer

# 需要導入模塊: from utils import Timer [as 別名]
# 或者: from utils.Timer import update [as 別名]
 def test_timer():
     t = Timer()
     t2 = Timer(3)
     t.update()
     t2.update()
開發者ID:simlmx,項目名稱:python-utils,代碼行數:7,代碼來源:tests.py

示例8: Tower

# 需要導入模塊: from utils import Timer [as 別名]
# 或者: from utils.Timer import update [as 別名]
class Tower(Sprite):
    """A tower object, placed on the grid. Unwalkable. Fires projectiles at nearby creeps."""
    def __init__(self, screen, game, position=(0, 0), tower_image='images/towers/arrow_tower_1.png', projectile_image='images/projectiles/Arrow1.png', frameinterval=100, template=False):
        """ Create a new Tower.
        screen:
        The screen on which the tower is located (must be a pygame Surface object, such as pygame.display)
        game:
        This is the game object that holds information about the game world.
        tower_image:
        An image (as Pygame surface objects) for the tower.
        projectile_image:
        An image for the projectile the tower emits
        position:
        The (x, y) position of the tower.
        """
        Sprite.__init__(self)

        self.name = "Arrow Tower"
        self.description = None

        if not template:
            game._placed_tower_count += 1
            self.id = game._placed_tower_count
            game.last_placed_tower_id = self.id
        else:
            self.id = None

        self.type = 'Tower'
        self.screen = screen
        self.game = game
        self.image_list = None
        if tower_image.__class__ == "".__class__:
            self.image = pygame.image.load(tower_image).convert_alpha()
        elif tower_image.__class__ == [].__class__:
            self.image = pygame.image.load(tower_image[0]).convert_alpha()
            self.image_list = tower_image
            self.imageframeid = 0
            self.frametimer = Timer(frameinterval, self.next_frame, oneshot=False)

        self.icon = pygame.transform.scale(self.image, (30, 30))
        self.projectile_image = pygame.image.load(projectile_image).convert_alpha()
        self.orig_pos = position  #just for eventual need to know exactly which pixel it was placed at (and then it was snapped to the topleft of that tile)
        if not template:
            #Tile snapping code
            self.coordx_topleft, self.coordy_topleft = self.game.xy2coord(position) #these are used further down
            self.coord_topleft = (self.coordx_topleft, self.coordy_topleft)
            self.pos = game.coord2xy(self.coord_topleft)

        self.is_upgrade = False
        self.cost = 10

        #Fire-related
        self.damage = 4
        self.radius = 100 #Attacking range
        self.ratio = 1.0 #Ratio of the radius, used for upgrades. #is this really used by current collison detection?
        self.attack_speed = 700 #ms delay
        self.aoe = False #should be radius of area
        self.aoefactor = 0.50 #factor to multiply by damage on area attack
        self.projectileeffect = None
        self.last_fire_time = 0
        self.last_target_id = None


        #Experience-related
        self.level = 1
        self.experience = 0
        self.kills = 0
        self.experience_req = 5
        self.last_experience_req = 0
        self.delta_exp_req = self.experience_req - self.last_experience_req

        #Projectile-related
        self.projectile_speed = 0.23


        self.width, self.height = self.image.get_size()
        self.widthbycoord = ceil(self.width / float(game.GRID_SIZE)) #get the ceiling, to block all tiles the tower occupies a portion of.
        self.heightbycoord = ceil(self.height / float(game.GRID_SIZE))

        #Blocking all covered tiles
        #
        if not template:
            for extra_tile_y in range(int(self.heightbycoord)): #Block all occupied tiles
                for extra_tile_x in range(int(self.widthbycoord)):
                    self.game.gridpath.set_blocked((self.coordx_topleft + extra_tile_x, self.coordy_topleft + extra_tile_y))

            self.rect = Rect(self.pos[0], self.pos[1], self.width, self.height)
        #print("Image: ", tower_image, "projectile_image: ", projectile_image, "Position xy: ", self.pos, "Position Coord: ", self.coord_topleft)

    def draw(self, time_passed): ## If this turns out to be the better way, don't forget to change the drawing method from self.towers.draw(self.screen) to for tower in self.towers: tower.draw()
        if self.image_list:
            self.frametimer.update(time_passed)
        self.screen.blit(self.image, self.rect)

##        # The experience bar is 15x4 px.
##        #
##        experience_bar_length = 15
##        experience_bar_height = 4
##
##        experience_percentage = get_Percentage((self.experience_req - self.last_experience_req), (self.experience - self.last_experience_req)) #float fraction, like 0.333333 (equals 33.3333% )
#.........這裏部分代碼省略.........
開發者ID:ClemensFMN,項目名稱:PyTowerDefense,代碼行數:103,代碼來源:Towers.py


注:本文中的utils.Timer.update方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。