Поиск текста и выделение того же с помощью IHtmlElement в элементе управления webbrowser - PullRequest
1 голос
/ 23 февраля 2012

Я должен реализовать функцию TTS, чтобы считывать веб-страницу, открытую в веб-браузере, в то время как при чтении текста я также должен выделить работу, которую система читает, но я не могу сделать то же самое. Я просматриваю пост здесь, но не получаю фактический результат, как я хочу. а также, когда я пытаюсь этот код ниже, я получаю сообщение об ошибке "System.Runtime.InteropServices.COMException Сообщение = Исключение из HRESULT: 0x800A025E "в trg.select ()

IHTMLDocument2 currentDoc = (IHTMLDocument2)webBrowser1.Document.DomDocument;

                foreach (IHTMLElement elem in currentDoc.body.all)
                {



                            string[] splitSentences = elem.innerText.Split(" ".ToCharArray());

                            for (int i = 0; i < splitSentences.Length; i++)
                            {

                                // highlight(splitSentences[i]);

                                mshtml.IHTMLDocument2 doc = (mshtml.IHTMLDocument2)(webBrowser1.Document.DomDocument);

                                IHTMLBodyElement bodyElement = doc.body as IHTMLBodyElement;

                                IHTMLTxtRange trg = bodyElement.createTextRange();


                                if (trg.findText(splitSentences[i], 0, 0))
                                {
                                    trg.select();
                                }

                                //if (trg != null)
                                //{
                                //    String SearchString = splitSentences[i];// "Privacy"; // This is the search string you're looking for.
                                //    int wordStartOffset = 0; // This is the starting position in the HTML where the word you're looking for starts at.
                                //    int wordEndOffset = SearchString.Length;
                                //    trg.move("character", wordStartOffset);
                                //    trg.moveEnd("character", wordEndOffset);

                                //    trg.select();
                                //}


                                //mshtml.IHTMLSelectionObject sel = (mshtml.IHTMLSelectionObject)doc.selection;

                                //mshtml.IHTMLTxtRange rng = (mshtml.IHTMLTxtRange)sel.createRange();
                                //// rng.collapse(false);
                                //if (rng.findText(splitSentences[i], 1000000, 0))
                                //{
                                //    rng.select();
                                //    sound_object.Speak(splitSentences[i], SpeechLib.SpeechVoiceSpeakFlags.SVSFlagsAsync);
                                //}
                                //sound_object.Speak(splitSentences[i], SpeechLib.SpeechVoiceSpeakFlags.SVSFlagsAsync);


                    }
                    Thread.Sleep(2000);
                }

я знаю, что этот код не собирается найти текст в элементе, он найдет текст на всей странице, я хочу просто выяснить, как он будет работать, но он не работает,

Пожалуйста, предложите что-нибудь полезное.

Ответы [ 2 ]

1 голос
/ 29 декабря 2015

Вы можете использовать следующий код:

    IHTMLTxtRange rng = null;
    private bool FindString(HtmlElement elem, string str)
    {           
        bool strFound = false;
        try
        {
            if (rng != null)
            {
                rng.collapse(false);
                strFound = rng.findText(str, 1000000000, 0);
                if (strFound)
                {
                    rng.select();
                    rng.scrollIntoView(true);
                }
            }
            if (rng == null)
            {
                IHTMLDocument2 doc =
                       elem.Document.DomDocument as IHTMLDocument2;

                IHTMLBodyElement body = doc.body as IHTMLBodyElement;

                rng = body.createTextRange();
                rng.moveToElementText(elem.DomElement as IHTMLElement);
                strFound = rng.findText(str, 1000000000, 0);
                if (strFound)
                {
                    rng.select();
                    rng.scrollIntoView(true);
                }

            }
        }
        catch 
        {

        }
        return strFound;
    }
1 голос
/ 23 февраля 2012

Этот пример кода может помочь мне подумать - Форумы MSDN: диалог поиска WebBrowser

    private string GetSelection()
    {
        IHTMLDocument2 doc = (IHTMLDocument2)browserInstance.Document;
        IHTMLSelectionObject sel = doc.selection;
        IHTMLTxtRange range = (IHTMLTxtRange)sel.createRange();
        return range.text;
    }
    private bool FindFirst(string text)
    {
        IHTMLDocument2 doc = (IHTMLDocument2)browserInstance.Document;
        IHTMLSelectionObject sel = (IHTMLSelectionObject)doc.selection;
        sel.empty(); // get an empty selection, so we start from the beginning
        IHTMLTxtRange rng = (IHTMLTxtRange)sel.createRange();
        if (rng.findText(text, 1000000000, 0))
        {
            rng.select();
            return true;
        }

        return false;
    }
    private bool FindNext(string text)
    {
        IHTMLDocument2 doc = (IHTMLDocument2)browserInstance.Document;
        IHTMLSelectionObject sel = (IHTMLSelectionObject)doc.selection;
        IHTMLTxtRange rng = (IHTMLTxtRange)sel.createRange();
        rng.collapse(false); // collapse the current selection so we start from the end of the previous range
        if (rng.findText(text, 1000000000, 0))
        {
            rng.select();
            return true;
        }

        return false;
    }
...