IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Couleur ligne avec long non RGB (Convertir Couleur Long en RGB) [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de bastou93
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2010
    Messages
    217
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 217
    Par défaut Couleur ligne avec long non RGB (Convertir Couleur Long en RGB)
    Bonjour a tous,

    J'ai un petit problème de personnalisation d'un graphique, je m'explique:

    Je voudrai faire un aperçu à l'utilisateur des couleurs des séries qu'il à choisit; pour cela je lui trace un graphique "démo" ou il peut choisir le type: Aire, histo, ligne, camembert.

    Pour tous cela marche niquel sauf Courbe; en effet je n'arrive pas à partir des long que je stock à donner la couleur à la ligne de la série.

    Ex pour l'aire je fais ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    With Grf.Chart
     For i=1 to 10 
      .SeriesCollection.NewSeries
      with .SeriesCollection(i)
       .Value = Array(11-i,11-i)
       .Interior.Pattern = CLng(collectColor(i)("Pattern"))
       .Interior.PatternColor = CLng(collectColor(i)("PatternColor"))
       .Interior.Color = CLng(collectColor(i)("Color"))
      end with
     next i
    end with
    Voila pour info collectColor est une collection 2D ou on retrouve d'abord autant de collection que de graphe ici 10 puis une collection contennant 3 éléments key: Pattern qui vaut 1,13... un long
    Color et PatternColor qui vaut par exemple 0 pour du noir, 255 rouge..etc

    La ou cela se gatte c'est pour les lignes:

    Ce code ci fonctionne, cependant je stock tout en long et non RGB
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    With Grf.Chart
     For i=1 to 10 
      .SeriesCollection.NewSeries
      with .SeriesCollection(i)
       .Value = Array(11-i,11-i)
       .Format.Line.ForeColor.RGB = RGB(128,0,0)
      end with
     next i
    end with
    j'ai tester pas mal de truc rien n'y fais exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    With Grf.Chart
     For i=1 to 10 
      .SeriesCollection.NewSeries
      with .SeriesCollection(i)
       .Value = Array(11-i,11-i)
       .Format.Line.ForeColor = 0
      end with
     next i
    end with
    Merci de votre aide

    Bastien

  2. #2
    Membre éclairé Avatar de bastou93
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2010
    Messages
    217
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 217
    Par défaut
    Bonjour a tous,

    J'ai beau regarder, je n'ai pas trouver, la seul piste que j'ai c'est de convertir le long en valeur RGB je suppose que le rouge correspond au bit de poids faible vu que rouge = 255 en long.
    A voir mais je trouve cela galere

    Merci a tous
    Bastien

  3. #3
    Membre éclairé Avatar de bastou93
    Homme Profil pro
    Étudiant
    Inscrit en
    Août 2010
    Messages
    217
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 217
    Par défaut
    Bon je me suis résigné à faire la fonction moi même et donc passer pas la méthode RGB voici le code si cela peut en aider:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    Private Function ConvertLongtoRGB(LongColorValue as Long) as Collection
     
    Dim R as Long
    Dim G as Long
    Dim B as Long
     
    R = LongColorValue Mod 256
    G = (LongColorValue \ 256) Mod 256
    B = (LongColorValue \ 256 \ 256) Mod 256
     
    Set ConvertLongtoRGB = new Collection
    ConvertLongtoRGB.Add R,"R"
    ConvertLongtoRGB.Add G,"G"
    ConvertLongtoRGB.Add B,"B"
     
    end function
    je l'ai fais en collection pour récupérer comme ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    SeriesCollection(1).Format.Line.ForeColor.RGB = RGB( ConvertLongtoRGB(12611584)("R"), ConvertLongtoRGB(12611584)("G"),ConvertLongtoRGB(12611584)("B"))
    Voila si il y a de l'optimisation n'hésitez pas

    Bastien

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Toutes versions] Insérer lignes avec cellules non vides
    Par esstin dans le forum Excel
    Réponses: 4
    Dernier message: 11/08/2010, 18h23
  2. Convertir des long issus de C++ en long pour java
    Par sylverspoon dans le forum Entrée/Sortie
    Réponses: 3
    Dernier message: 07/10/2009, 00h25
  3. Comment changer les couleurs des lignes avec displaytag
    Par rlnd23 dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 09/10/2006, 13h52
  4. Lignes avec différentes couleurs
    Par hbzied dans le forum AWT/Swing
    Réponses: 1
    Dernier message: 02/05/2006, 09h30
  5. [Image]Convertir couleurs images avec palette donnée
    Par matique dans le forum Bibliothèques et frameworks
    Réponses: 5
    Dernier message: 08/02/2006, 17h51

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo