X-Git-Url: https://scm.cri.mines-paristech.fr/git/minwii.git/blobdiff_plain/570d6a4559218a337ea8e49649a9c4303d9db214..da27397af045e89d82771d70851ec7cc9d158f70:/src/app/widgets/column.py?ds=sidebyside diff --git a/src/app/widgets/column.py b/src/app/widgets/column.py index 3d8b986..bf1fb90 100755 --- a/src/app/widgets/column.py +++ b/src/app/widgets/column.py @@ -18,19 +18,23 @@ from config import ON_BOTTOM_LUMINANCE from config import ON_SATURATION from config import ON_COLUMN_OVERSIZING from config import ON_COLUMN_ALPHA -from config import FONT +from config import LYRICS_FONT, NOTES_FONT from config import FONT_COLOR +import events class Column(pygame.sprite.DirtySprite) : + ''' colonne utilisée pour l'affichage d'une touche du clavier de jeu. + ''' - def __init__(self, group, hue, rect, tone, atBorder) : + def __init__(self, group, index, hue, rect, tone) : pygame.sprite.DirtySprite.__init__(self, group) + self.index = index self.state = False # nom de l'intonation self.tone = tone - toneName = FONT.render(tone.nom, True, FONT_COLOR) + toneName = NOTES_FONT.render(tone.nom, True, FONT_COLOR) # état off : surface unie et nom de l'intonation sur = pygame.surface.Surface(rect.size) @@ -51,11 +55,6 @@ class Column(pygame.sprite.DirtySprite) : onLeft = rect.centerx - onWidth / 2 rectOn = pygame.Rect((onLeft, 0), (onWidth, rect.height)) - - self.atBorder = atBorder - if self.atBorder : - setattr(rectOn, self.atBorder, getattr(rect, self.atBorder)) - self.surOn = gradients.vertical(rectOn.size, topRgba, bottomRgba) w, h = rectOn.w, rectOn.h toneRect = pygame.Rect(((w - tw) / 2, h - th), (tw, th)) @@ -76,16 +75,20 @@ class Column(pygame.sprite.DirtySprite) : if syllabus : sur = sur.copy() rect = self.rectOn - renderedSyl = FONT.render(syllabus, True, FONT_COLOR) + renderedSyl = LYRICS_FONT.render(syllabus, True, FONT_COLOR) sw, sh, = renderedSyl.get_size() w, h = self.rectOn.w, self.rectOn.h if sw > self.rectOn.w : sur = pygame.transform.scale(sur, (sw, h)) rect = rect.inflate(sw - w, 0) - if self.atBorder : - setattr(rect, self.atBorder, getattr(self.rectOn, self.atBorder)) w = sw + + screenWidth = group.dispWidth + if rect.left < 0 : + rect.left = 0 + elif rect.right > screenWidth : + rect.right = screenWidth sylRect = pygame.Rect(((w - sw) / 2, (h - sh) / 2), (sw, sh)) sur.blit(renderedSyl, sylRect) @@ -96,6 +99,9 @@ class Column(pygame.sprite.DirtySprite) : group.change_layer(self, BACKGROUND_LAYER) self.image = self.surOff self.rect = self.rectOff + self.state = state - self.dirty = 1 + self.dirty = 1 + evt = pygame.event.Event(events.COLSTATECHANGE, column=self, state=state, syllabus=syllabus) + pygame.event.post(evt)