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

JavaFX Discussion :

Transform et CSS


Sujet :

JavaFX

  1. #1
    Membre averti
    Homme Profil pro
    Autodidacte
    Inscrit en
    Décembre 2005
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Autodidacte

    Informations forums :
    Inscription : Décembre 2005
    Messages : 30
    Par défaut Transform et CSS
    Bonjour,

    En tentant de faire un système de zoom basique sur une carte composée de shape, j'ai constaté que les styles étaient impactés par la transformation ...

    Ce comportement est effectivement spécifié dans la doc (mea culpa mais je ne l'ai lue qu'après). Je me demandais s'il était prévu dans les évolutions futures des nuances comme de rendre optionnellement les styles indépendants d'une shape qui subit une transfo (au hasard )...

    Sinon existe-t-il des contournements autres que de recalculer les coordonnées des shapes à chaque fois ? ou d'avoir recours à un dessin sur un Canvas comme je l'avais codé pour Swing ?

    Merci d'avance pour vos retours...

    Chak!

  2. #2
    Membre très actif
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2007
    Messages
    643
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Mai 2007
    Messages : 643
    Par défaut
    qu'appel tu des styles impactés par la transformation exactement ?

  3. #3
    Membre averti
    Homme Profil pro
    Autodidacte
    Inscrit en
    Décembre 2005
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Autodidacte

    Informations forums :
    Inscription : Décembre 2005
    Messages : 30
    Par défaut
    Citation Envoyé par miltone Voir le message
    qu'appel tu des styles impactés par la transformation exactement ?
    Si j'ai une shape quelconque dont je fixe le stroke-width dans une feuille css, lorsque j'applique une transformation type Scale, mon épaisseur de trait est également impactée... Cela fait penser à un zoom sur une image alors que le résultat recherché serait un truc à la GMaps ou lors du zoom, certaines parties se dilatent mais où la limite reste de la même épaisseur.

    Bref, aujourd'hui,
    - ou je reprends mon travail Swing en l'appliquant à un Canvas,
    - ou je dois bidouiller un scale "maison",
    - ou je dois appliquer au cas par cas, par exemple, un setStrokeWidth avec l'inverse du facteur de zoom...

    Dans tous les cas, il y a perte de temps ou de fonctionnalités...

    Chak!

  4. #4
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 900
    Billets dans le blog
    54
    Par défaut
    Vi c'est la même chose qui se passe en Java2D quand on reste en vectoriel et qu'on fait un graphics.scale() ou qu'on applique une AffineTransform qui fasse un scale.

    La 3eme solution me semble la plus facile à mettre en oeuvre :
    • ou setStrokeWidth(size);
    • ou setStyle("-fx-stroke-width: size;");


    EDIT - correction syntaxe CSS.
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  5. #5
    Membre averti
    Homme Profil pro
    Autodidacte
    Inscrit en
    Décembre 2005
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Autodidacte

    Informations forums :
    Inscription : Décembre 2005
    Messages : 30
    Par défaut
    Citation Envoyé par bouye Voir le message
    Vi c'est la même chose qui se passe en Java2D quand on reste en vectoriel et qu'on fait un graphics.scale() ou qu'on applique une AffineTransform qui fasse un scale.

    La 3eme solution me semble la plus facile à mettre en oeuvre :
    • ou setStrokeWidth(size);
    • ou setStyle("-fx-stroke-width size;");
    Merci Bouye,

    Pour la version Swing, je redessinais à chaque zoom/déplacement donc mon épaisseur restait conservée puisque le AffineTransform n'était finalement appliqué qu'à la Shape.

    Concernant la version actuelle, je pense effectivement tester la 3ème solution puisque, a priori, c'est celle qui demandera le moins d'effort . Par contre, je me demande les conséquences lorsque je switche sur une feuille CSS différente (la fonctionnalité JavaFX que je souhaite vraiment conserver)... Je verrai bien...

    En tout cas, l'idée de pouvoir désactiver optionnellement la connexion Transform/CSS me semblerait utile...

    Chak!

  6. #6
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 900
    Billets dans le blog
    54
    Par défaut
    Normalement, en java2D la mise à l'échelle s'applique quand on fait fill(shape) et draw(shape) (avec donc la largeur du stroke qui varie dans le second cas).

    Il faudra attendre que l'API pour avoir les valeurs settées par les CSS soit enfin dispo mais c'était pas prévu avant JavaFX 8 si mes souvenirs de quand ils en ont parlé à la JavaOne 2012 sont corrects donc désormais pas avant 2014 (en espérant qu'ils n'avaient pas mentionné JavaFX 9 , paske là on est pas rendu).
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

Discussions similaires

  1. Transformer un CSS en Compass
    Par lemirandais dans le forum Mise en page CSS
    Réponses: 0
    Dernier message: 03/05/2014, 23h06
  2. Transformer tableau html en html/css
    Par Myogtha dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 15/11/2006, 10h01
  3. Réponses: 1
    Dernier message: 13/09/2006, 15h12
  4. [XML - CSS - XSLT] Non-transformation ET non-mise en forme !?
    Par ghohm dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 18/05/2006, 17h44
  5. Transformation d'un tableau html en CSS
    Par titou250 dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 27/09/2005, 16h55

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