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

OpenOffice & LibreOffice Discussion :

[Macro] Modifier la plage de donnée d'un graphique [LibreOffice][Tableur]


Sujet :

OpenOffice & LibreOffice

  1. #1
    Membre régulier
    Avatar de madvic
    Homme Profil pro
    Inscrit en
    Mai 2003
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations forums :
    Inscription : Mai 2003
    Messages : 101
    Points : 92
    Points
    92
    Par défaut [Macro] Modifier la plage de donnée d'un graphique
    Dans cette FAQ
    http://openoffice-libreoffice.develo...r-un-graphique

    Pour moi, la méthode pour modifier la plage source n'existe pas (ou plus : LO ou OP ?)

    'Spécifie la nouvelle plage de données source
    oChart.ChartRangeAddress = "Feuille1.$A$1:.$B25"
    J'ai trouvé le champ UsedRangeRepresentations dans lequel est stocké en tableau, les entêtes et plage de données.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    oChart.UsedRangeRepresentations
    Le souci c'est que je n'arrive pas à écrire dans ce champ..

    Y a t-il une méthode que j'ai loupé ?

  2. #2
    Membre régulier
    Avatar de madvic
    Homme Profil pro
    Inscrit en
    Mai 2003
    Messages
    101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Deux Sèvres (Poitou Charente)

    Informations forums :
    Inscription : Mai 2003
    Messages : 101
    Points : 92
    Points
    92
    Par défaut
    Enfin compris :

    Mes données était videz, je ne sais pourquoi, donc :

    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
    17
    18
    19
    Dim ch As Object, lesZones As Variant, adrZ As Object
    maFeuille = ThisComponent.Sheets.getByPosition(2)
    ' on suppose que la feuille comporte un seul diagramme !
    lesZones = maFeuille.Charts(0).Ranges
     
    ' Si la zone n'est pas vide on la modifie
    If UBound(lesZones) >= 0  Then
        adrZ = lesZones(0) ' dans cet exemple on a une seule zone
        adrZ.StartRow = 0
        adrZ.StartColumn = 3
        adrZ.EndRow = 12  ' réduire la zone
        adrZ.EndColumn = 58
        lesZones(0) = adrZ
        fTCD.Charts(0).Ranges = lesZones()
    Else
    'Sinon on la créée
        LaZone = maFeuille.getCellRangeByPosition(0, 3, 12, 58)
        maFeuille.Charts(0).setRanges( Array(LaZone.getRangeAddress()) )
    EndIf

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 05/01/2015, 15h29
  2. [XL-2010] Sélection de plusieurs plages de données pour un graphique : erreur macro
    Par Piixx_e dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 09/12/2013, 11h05
  3. [XL-2010] Macro modification des plages de données graphiques
    Par FP789 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 24/08/2013, 10h42
  4. generaliser une macro sur une plage de données
    Par Eausport dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 06/07/2011, 10h49
  5. [C#] pilotage excel: définir plage de données d'un graphique
    Par cortex024 dans le forum Windows Forms
    Réponses: 1
    Dernier message: 27/03/2006, 17h34

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