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

Composants VCL Delphi Discussion :

TRichEdit CHARFORMAT2A CFU_UNDERLINEWAVE


Sujet :

Composants VCL Delphi

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre expérimenté
    Avatar de XeGregory
    Homme Profil pro
    Passionné par la programmation
    Inscrit en
    Janvier 2017
    Messages
    592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Passionné par la programmation
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2017
    Messages : 592
    Billets dans le blog
    1
    Par défaut TRichEdit CHARFORMAT2A CFU_UNDERLINEWAVE
    Bonjour,

    Afin de repérer les mots mal orthographiés dans TRichEdit Spellchecking lorsqu'une sélection est effectué, je voudrais vérifier si la sélection comporte une ligne ondulée.

    J'utilise CHARFORMAT2A pour récupéré la valeur du type bUnderlineType

    Nom : Capture.PNG
Affichages : 413
Taille : 42,7 Ko

    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
    20
    { MisspelledWord }
    procedure MisspelledWord(RichEdit: TRichEdit);
    const
      CFU_UNDERLINEWAVE = 8; { Ligne ondulée }
    var
      Format2A: CHARFORMAT2A;
    begin
      FillChar(Format2A, SizeOf(Format2A), 0);
     
      with Format2A do
      begin
        cbSize := SizeOf(Format2A);
        RichEdit.Perform(EM_GETCHARFORMAT, SCF_SELECTION, LPARAM(@Format2A));
     
        Form1.Caption := 'bUnderlineType = ' + IntToStr(bUnderlineType);
     
        if bUnderlineType = CFU_UNDERLINEWAVE then
          ShowMessage('Mot mal orthographié !');
      end;
    end;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    procedure TForm1.RichEditMouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState;
      X, Y: Integer);
    begin
      MisspelledWord(RichEdit);
    end;
    Le hic, c'est que je ne parviens pas à récupérer la valeur du type bUnderlineType, Cela me renvoie toujours la valeur 1.

    Auriez-vous une petite idée ? Merci

  2. #2
    Membre expérimenté
    Avatar de XeGregory
    Homme Profil pro
    Passionné par la programmation
    Inscrit en
    Janvier 2017
    Messages
    592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Passionné par la programmation
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2017
    Messages : 592
    Billets dans le blog
    1
    Par défaut
    En appliquant la ligne ondulée avec EM_SETCHARFORMAT, j'arrive bien a récupéré la valeur du type bUnderlineType, donc ça fonctionne depuis le début.

    Toutefois, je ne peux toujours pas récupérer la valeur du type bUnderlineType sur les lignes ondulées rouges du SpellChecking, comme si elle se trouvait en surface du RichEdit.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    var
      Format2A: CHARFORMAT2A;
    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
    { SET_UnderlineWare }
    procedure SET_UnderlineWare(RichEdit: TRichEdit);
    const
      CFU_UNDERLINEWAVE = 8; { Ligne ondulée }
    begin
      FillChar(Format2A, SizeOf(Format2A), 0);
     
      with Format2A do
      begin
        cbSize := SizeOf(Format2A);
        dwMask := CFM_UNDERLINETYPE;
        dwEffects := CFM_UNDERLINE;
        bUnderlineType := CFU_UNDERLINEWAVE;
     
        RichEdit.Perform(EM_SETCHARFORMAT, SCF_SELECTION, LPARAM(@Format2A));
      end;
    end;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    { GET_UnderlineType}
    procedure GET_UnderlineType(RichEdit: TRichEdit);
    begin
      FillChar(Format2A, SizeOf(Format2A), 0);
     
      with Format2A do
      begin
        cbSize := SizeOf(Format2A);
        RichEdit.Perform(EM_GETCHARFORMAT, SCF_SELECTION, LPARAM(@Format2A));
        Form1.Caption := 'bUnderlineType = ' + IntToStr(bUnderlineType);
      end;
    end;
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    procedure TForm1.RichEditMouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState;
      X, Y: Integer);
    begin
      case Button of
        mbLeft:
          GET_UnderlineType(RichEdit);
     
        mbRight:
          SET_UnderlineWare(RichEdit);
      end;
    end;
    Nom : Video_2024_04_28-1_edit_0.gif
Affichages : 375
Taille : 693,3 Ko

  3. #3
    Membre expérimenté
    Avatar de XeGregory
    Homme Profil pro
    Passionné par la programmation
    Inscrit en
    Janvier 2017
    Messages
    592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Passionné par la programmation
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2017
    Messages : 592
    Billets dans le blog
    1
    Par défaut
    Cette méthode visait à attribuer un TPopupMenu lorsqu'une sélection est effectuée.
    Le problème avec le SpellChecking lorsqu'il est activé, pour avoir le menu des suggestions de correction, il faut définir le RichEdit.PopupMenu := nil.

    Donc je me suis dit si j'arrive à récupérer la valeur de cette ligne ondulée je pouvais peut-être gérer les TPopupMenu

    Si ( Ligne Ondulée ) et (SpellChecking = True) Alors RichEdit.PopupMenu := nil Sauf RichEdit.PopupMenu := PopupMenu1

    ou

    Si ( GET_UnderlineType = 1 ) Alors RichEdit.PopupMenu := PopupMenu1 Sauf RichEdit.PopupMenu := nil
    Mais cela me semble beaucoup plus complexe que ça

  4. #4
    Expert éminent
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    14 124
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Développeur C++\Delphi
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juillet 2006
    Messages : 14 124
    Par défaut
    Il existe le CallBack de EM_SETAUTOCORRECTPROC, dommage qu'il n'existe pas un Callback pour la détection qui indiquerait la position du Mot en erreur


    As-tu essayé avec ITextFont::GetUnderline à tomWave ?
    Il faut travailler sur le ITextDocument obtenu par un RichEdit.Perform EM_GETOLEINTERFACE
    Aide via F1 - FAQ - Guide du développeur Delphi devant un problème - Pensez-y !
    Attention Troll Méchant !
    "Quand un homme a faim, mieux vaut lui apprendre à pêcher que de lui donner un poisson" Confucius
    Mieux vaut se taire et paraître idiot, Que l'ouvrir et de le confirmer !
    L'ignorance n'excuse pas la médiocrité !

    L'expérience, c'est le nom que chacun donne à ses erreurs. (Oscar Wilde)
    Il faut avoir le courage de se tromper et d'apprendre de ses erreurs

  5. #5
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 496
    Par défaut
    salut

    comme le dis shailetroll il existe une fonctions et des message depuis quelque temps deja

    les message mis en œuvre

    EM_GETAUTOCORRECTPROC = (WM_USER + 233)
    EM_SETAUTOCORRECTPROC = (WM_USER + 234)
    EM_CALLAUTOCORRECTPROC = (WM_USER + 255)

    La fonction callback est du type
    TAutoCorrectProc = function(LangId : WORD;PszBefore,PszAfter : PWChar;CchAfter : LongInt;PCchReplaced : Pointer): integer;


    dans tout ceci il n'y a pas de notion de position

  6. #6
    Membre expérimenté
    Avatar de XeGregory
    Homme Profil pro
    Passionné par la programmation
    Inscrit en
    Janvier 2017
    Messages
    592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 37
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Passionné par la programmation
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2017
    Messages : 592
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par ShaiLeTroll Voir le message
    As-tu essayé avec ITextFont::GetUnderline à tomWave ?
    Il faut travailler sur le ITextDocument obtenu par un RichEdit.Perform EM_GETOLEINTERFACE
    Non j'ai pas recherché de ce côté-la, j'ai pris exemple le TRichEdit, mes je dispose du LMDRichEdit qui lui donne accès au TextDocument & TextDocument2 TOM2
    Je vais rechercher de ce côté-là.

    Merci ShaiLeTroll & Anapurna

  7. #7
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 496
    Par défaut
    Salut

    il faut peut être passer par la redéfinition du wnproc
    comme nous le faisions à l'époque pour activer les liens cliquable

    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
    20
    21
    procedure TForm1.WndProc(var Message: TMessage);
    var
      p: TENLink;
      strURL: string;
    begin
      if (Message.Msg = WM_NOTIFY) then
      begin
        if (PNMHDR(Message.lParam).code = EN_LINK) then
        begin
          p := TENLink(Pointer(TWMNotify(Message).NMHdr)^);
          if (p.Msg = WM_LBUTTONDOWN) then
          begin
            SendMessage(RichEdit1.Handle, EM_EXSETSEL, 0, Longint(@(p.chrg)));
            strURL := RichEdit1.SelText;
            ShellExecute(Handle, 'open', PChar(strURL), 0, 0, SW_SHOWNORMAL);
          end
        end;
      end;
     
      inherited;
    end;

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

Discussions similaires

  1. TRichEdit et OEM_CHARSET
    Par chtiot dans le forum Composants VCL
    Réponses: 8
    Dernier message: 27/09/2003, 23h58
  2. TRichEdit défilement de texte automatique
    Par bloops dans le forum C++Builder
    Réponses: 2
    Dernier message: 11/06/2003, 12h13
  3. [Composants] TRichEdit: Une police pour chaque ligne
    Par naili dans le forum C++Builder
    Réponses: 3
    Dernier message: 16/03/2003, 16h59
  4. TRichEdit Position du caret
    Par AlainR dans le forum Composants VCL
    Réponses: 6
    Dernier message: 25/10/2002, 11h42
  5. TMemo et TRichEdit
    Par Invité dans le forum C++Builder
    Réponses: 6
    Dernier message: 09/10/2002, 21h37

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