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

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

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

    Informations forums :
    Inscription : Janvier 2017
    Messages : 300
    Points : 265
    Points
    265
    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 : 257
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
    Vous ne pouvez pas faire confiance à un code que vous n'avez pas totalement rédigé vous-même.
    Ce n’est pas un bogue - c’est une fonctionnalité non documentée.

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

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

    Informations forums :
    Inscription : Janvier 2017
    Messages : 300
    Points : 265
    Points
    265
    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 : 220
Taille : 693,3 Ko
    Vous ne pouvez pas faire confiance à un code que vous n'avez pas totalement rédigé vous-même.
    Ce n’est pas un bogue - c’est une fonctionnalité non documentée.

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

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

    Informations forums :
    Inscription : Janvier 2017
    Messages : 300
    Points : 265
    Points
    265
    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
    Vous ne pouvez pas faire confiance à un code que vous n'avez pas totalement rédigé vous-même.
    Ce n’est pas un bogue - c’est une fonctionnalité non documentée.

  4. #4
    Expert éminent sénior
    Avatar de ShaiLeTroll
    Homme Profil pro
    Développeur C++\Delphi
    Inscrit en
    Juillet 2006
    Messages
    13 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    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 : 13 563
    Points : 25 165
    Points
    25 165
    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 434
    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 434
    Points : 5 846
    Points
    5 846
    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
    Nous souhaitons la vérité et nous trouvons qu'incertitude. [...]
    Nous sommes incapables de ne pas souhaiter la vérité et le bonheur, et sommes incapables ni de certitude ni de bonheur.
    Blaise Pascal
    PS : n'oubliez pas le tag

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

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

    Informations forums :
    Inscription : Janvier 2017
    Messages : 300
    Points : 265
    Points
    265
    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
    Vous ne pouvez pas faire confiance à un code que vous n'avez pas totalement rédigé vous-même.
    Ce n’est pas un bogue - c’est une fonctionnalité non documentée.

  7. #7
    Expert confirmé
    Avatar de anapurna
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    3 434
    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 434
    Points : 5 846
    Points
    5 846
    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;
    Nous souhaitons la vérité et nous trouvons qu'incertitude. [...]
    Nous sommes incapables de ne pas souhaiter la vérité et le bonheur, et sommes incapables ni de certitude ni de bonheur.
    Blaise Pascal
    PS : n'oubliez pas le tag

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

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

    Informations forums :
    Inscription : Janvier 2017
    Messages : 300
    Points : 265
    Points
    265
    Par défaut
    J'ai fait des recherches du côté de LMDRichEdit, en espérant obtenir un peu plus d'éléments avec ce composant., Mes riens de plus que le TRichEdit coté SpellChecking.

    Après, il y a peut-être une autre alternative : ce serait d'intercepter l'ouverture du PopupMenu du SpellChecking.
    Vous ne pouvez pas faire confiance à un code que vous n'avez pas totalement rédigé vous-même.
    Ce n’est pas un bogue - c’est une fonctionnalité non documentée.

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

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

    Informations forums :
    Inscription : Janvier 2017
    Messages : 300
    Points : 265
    Points
    265
    Par défaut
    Peut-être en récupérant le Message.hWnd du PopupMenu il y peut-être un truc a faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    type
      TRichEdit = class(Vcl.ComCtrls.TRichEdit)
      protected
        procedure WMContextMenu(var Message: TWMContextMenu); message WM_CONTEXTMENU;
      end;
     
    procedure TRichEdit.WMContextMenu(var Message: TWMContextMenu);
    begin
      // Message.hWnd 
      inherited;
    end;
    Vous ne pouvez pas faire confiance à un code que vous n'avez pas totalement rédigé vous-même.
    Ce n’est pas un bogue - c’est une fonctionnalité non documentée.

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

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

    Informations forums :
    Inscription : Janvier 2017
    Messages : 300
    Points : 265
    Points
    265
    Par défaut
    J'ai trouvé cette solution-là , vu que le SpellChecking se présente avant la demande d'ouverture du PopUpMenu1 on lui laisse la place, s'il se présente pas ont réattribue le PopUpMenu1 au Control.

    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
     
    type
      TCustomRE = class(TCustomRichEdit);
     
    procedure TForm1.RichEditMouseDown(Sender: TObject; Button: TMouseButton; Shift: TShiftState;
      X, Y: Integer);
    begin
      case Button of
        mbRight:
          begin
            if (Screen.ActiveControl is TCustomRichEdit) and
              not Assigned(TCustomRE(Screen.ActiveControl).PopupMenu) then
              TCustomRE(Screen.ActiveControl).PopupMenu := PopupMenu1
            else
              TCustomRE(Screen.ActiveControl).PopupMenu := nil;
          end;
      end;
    end;
    Nom : Video_2024_05_01-1_edit_0.gif
Affichages : 135
Taille : 1,32 Mo
    Vous ne pouvez pas faire confiance à un code que vous n'avez pas totalement rédigé vous-même.
    Ce n’est pas un bogue - c’est une fonctionnalité non documentée.

+ 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, 22h58
  2. TRichEdit défilement de texte automatique
    Par bloops dans le forum C++Builder
    Réponses: 2
    Dernier message: 11/06/2003, 11h13
  3. [Composants] TRichEdit: Une police pour chaque ligne
    Par naili dans le forum C++Builder
    Réponses: 3
    Dernier message: 16/03/2003, 15h59
  4. TRichEdit Position du caret
    Par AlainR dans le forum Composants VCL
    Réponses: 6
    Dernier message: 25/10/2002, 10h42
  5. TMemo et TRichEdit
    Par Invité dans le forum C++Builder
    Réponses: 6
    Dernier message: 09/10/2002, 20h37

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