GetWordLineIndex Method (GdPictureOCR)
                In This Topic
            
            Returns the index of the line, which incorporates the specified word, that is a part of a specified OCR result.
            
            
            Syntax
            
            
            
            
            'Declaration
 
Public Function GetWordLineIndex( _
   ByVal  As String, _
   ByVal  As Integer _
) As Integer
             
        
            
            public int GetWordLineIndex( 
   string ,
   int 
)
             
        
            
            public function GetWordLineIndex( 
    : String;
    : Integer
): Integer; 
             
        
            
            public function GetWordLineIndex( 
    : String,
    : int
) : int;
             
        
            
            public: int GetWordLineIndex( 
   string* ,
   int 
) 
             
        
            
            public:
int GetWordLineIndex( 
   String^ ,
   int 
) 
             
        
             
        
            Parameters
- OCRResultID
- The unique result identifier of the executed OCR process obtained by the GdPictureOCR.RunOCR method.
- WordIdx
- The 0-based index of the word within the specified OCR result. It must be a value between 0 and GdPictureOCR.GetWordCount(OCRResultID) - 1.
Return Value
The index of the line, which involves the required word. Please always use the 
GdPictureOCR.GetStat method to determine if this method has been successful.
 
            
            
            
            
            
            Example
How to determine, which word belongs to which line in the OCR result.
            
             
    
	
		Dim caption As String = "Example: GetWordLineIndex"
Dim gdpictureOCR As GdPictureOCR = New GdPictureOCR()
Dim gdpicturePDF As GdPicturePDF = New GdPicturePDF()
'Load the PDF document.
If gdpicturePDF.LoadFromFile("input.pdf", False) = GdPictureStatus.OK Then
    'Select the first page.
    gdpicturePDF.SelectPage(1)
    'Render this page to a 200 DPI image.
    Dim image As Integer = gdpicturePDF.RenderPageToGdPictureImage(200, True)
    'Setting up the image is mandatory.
    If (gdpicturePDF.GetStat() = GdPictureStatus.OK) AndAlso
       (gdpictureOCR.SetImage(image) = GdPictureStatus.OK) Then
        'Set up the OCR parameters.
        gdpictureOCR.ResourcesFolder = "C:\Path\To\GdPicture.NET 14\Redist\OCR"
        gdpictureOCR.AddLanguage(OCRLanguage.English)
        gdpictureOCR.OCRMode = OCRMode.FavorAccuracy
        'Set up the OCR context and the character list.
        gdpictureOCR.Context = OCRContext.OCRContextSingleBlock
        gdpictureOCR.CharacterSet = "0123456789"
        'Set up the area to be processed by the OCR.
        gdpictureOCR.SetROI(100, 100, 200, 50)
        'Run the OCR process to recognize the phone number.
        Dim resID As String = gdpictureOCR.RunOCR()
        If gdpictureOCR.GetStat() = GdPictureStatus.OK Then
            Dim message As String = ""
            Dim lineCount As Integer = gdpictureOCR.GetTextLineCount(resID)
            If gdpictureOCR.GetStat() = GdPictureStatus.OK Then
                message = message + "The number of all recognized text lines: " + lineCount.ToString() + vbCrLf
                Dim wordCount As Integer = gdpictureOCR.GetWordCount(resID)
                If gdpictureOCR.GetStat() = GdPictureStatus.OK Then
                    message = message + "The number of all recognized words: " + wordCount.ToString() + vbCrLf
                    For i As Integer = 0 To wordCount - 1
                        message = message + "The word nr." + i.ToString() + " is included in the line nr." +
                                            gdpictureOCR.GetWordLineIndex(resID, i).ToString() + "." + vbCrLf
                    Next
                    MessageBox.Show(message, caption)
                    'Continue with analyzing the result ...
                Else
                    MessageBox.Show("The GetWordCount() method has failed with the status: " + gdpictureOCR.GetStat().ToString(), caption)
                End If
            Else
                MessageBox.Show("The GetTextLineCount() method has failed with the status: " + gdpictureOCR.GetStat().ToString(), caption)
            End If
        Else
            MessageBox.Show("The error occurred when running the OCR. Status: " + gdpictureOCR.GetStat().ToString(), caption)
        End If
        'Release the image.
        GdPictureDocumentUtilities.DisposeImage(image)
    Else
        MessageBox.Show("The error occurred when creating or setting up the image. Status: " + gdpicturePDF.GetStat().ToString() + "/" + gdpictureOCR.GetStat().ToString(), caption)
    End If
    'Close the document.
    gdpicturePDF.CloseDocument()
Else
    MessageBox.Show("The file can't be loaded. Status: " + gdpicturePDF.GetStat().ToString(), caption)
End If
'Release resources.
gdpictureOCR.ReleaseOCRResults()
gdpictureOCR.Dispose()
gdpicturePDF.Dispose()
	 
	
		string caption = "Example: GetWordLineIndex";
GdPictureOCR gdpictureOCR = new GdPictureOCR();
GdPicturePDF gdpicturePDF = new GdPicturePDF();
//Load the PDF document.
if (gdpicturePDF.LoadFromFile("input.pdf", false) == GdPictureStatus.OK)
{
    //Select the first page.
    gdpicturePDF.SelectPage(1);
    //Render this page to a 200 DPI image.
    int image = gdpicturePDF.RenderPageToGdPictureImage(200, true);
    if ((gdpicturePDF.GetStat() == GdPictureStatus.OK) &&
        (gdpictureOCR.SetImage(image) == GdPictureStatus.OK)) //Setting up the image is mandatory.
    {
        //Set up the OCR parameters.
        gdpictureOCR.ResourcesFolder = "C:\\Path\\To\\GdPicture.NET 14\\Redist\\OCR";
        gdpictureOCR.AddLanguage(OCRLanguage.English);
        gdpictureOCR.OCRMode = OCRMode.FavorAccuracy;
        //Set up the OCR context and the character list.
        gdpictureOCR.Context = OCRContext.OCRContextSingleBlock;
        gdpictureOCR.CharacterSet = "0123456789";
        //Set up the area to be processed by the OCR.
        gdpictureOCR.SetROI(100, 100, 200, 50);
        //Run the OCR process to recognize the phone number.
        string resID = gdpictureOCR.RunOCR();
        if (gdpictureOCR.GetStat() == GdPictureStatus.OK)
        {
            string message = "";
            int lineCount = gdpictureOCR.GetTextLineCount(resID);
            if (gdpictureOCR.GetStat() == GdPictureStatus.OK)
            {
                message = message + "The number of all recognized text lines: " + lineCount.ToString() + "\n";
                int wordCount = gdpictureOCR.GetWordCount(resID);
                if (gdpictureOCR.GetStat() == GdPictureStatus.OK)
                {
                    message = message + "The number of all recognized words: " + wordCount.ToString() + "\n";
                    for (int i = 0; i < wordCount; i++)
                    {
                        message = message + "The word nr." + i.ToString() + " is included in the line nr." +
                                            gdpictureOCR.GetWordLineIndex(resID, i).ToString() + ".\n";
                    }
                    MessageBox.Show(message, caption);
                    //Continue with analyzing the result ...
                }
                else
                    MessageBox.Show("The GetWordCount() method has failed with the status: " + gdpictureOCR.GetStat().ToString(), caption);
            }
            else
                MessageBox.Show("The GetTextLineCount() method has failed with the status: " + gdpictureOCR.GetStat().ToString(), caption);
        }
        else
            MessageBox.Show("The error occurred when running the OCR. Status: " + gdpictureOCR.GetStat().ToString(), caption);
        //Release the image.
        GdPictureDocumentUtilities.DisposeImage(image);
    }
    else
        MessageBox.Show("The error occurred when creating or setting up the image. Status: " + gdpicturePDF.GetStat().ToString() + "/" + gdpictureOCR.GetStat().ToString(), caption);
    //Close the document.
    gdpicturePDF.CloseDocument();
}
else
    MessageBox.Show("The file can't be loaded. Status: " + gdpicturePDF.GetStat().ToString(), caption);
//Release resources.
gdpictureOCR.ReleaseOCRResults();
gdpictureOCR.Dispose();
gdpicturePDF.Dispose();
	 
	
 
Example
How to determine, which word belongs to which line in the OCR result.
            
            Dim caption As String = "Example: GetWordLineIndex"
            Dim gdpictureOCR As GdPictureOCR = New GdPictureOCR()
            Dim gdpicturePDF As GdPicturePDF = New GdPicturePDF()
            'Load the PDF document.
            If gdpicturePDF.LoadFromFile("input.pdf", False) = GdPictureStatus.OK Then
                'Select the first page.
                gdpicturePDF.SelectPage(1)
                'Render this page to a 200 DPI image.
                Dim image As Integer = gdpicturePDF.RenderPageToGdPictureImage(200, True)
                'Setting up the image is mandatory.
                If (gdpicturePDF.GetStat() = GdPictureStatus.OK) AndAlso
                   (gdpictureOCR.SetImage(image) = GdPictureStatus.OK) Then
                    'Set up the OCR parameters.
                    gdpictureOCR.ResourcesFolder = "C:\Path\To\GdPicture.NET 14\Redist\OCR"
                    gdpictureOCR.AddLanguage(OCRLanguage.English)
                    gdpictureOCR.OCRMode = OCRMode.FavorAccuracy
                    'Set up the OCR context and the character list.
                    gdpictureOCR.Context = OCRContext.OCRContextSingleBlock
                    gdpictureOCR.CharacterSet = "0123456789"
                    'Set up the area to be processed by the OCR.
                    gdpictureOCR.SetROI(100, 100, 200, 50)
                    'Run the OCR process to recognize the phone number.
                    Dim resID As String = gdpictureOCR.RunOCR()
                    If gdpictureOCR.GetStat() = GdPictureStatus.OK Then
                        Dim message As String = ""
                        Dim lineCount As Integer = gdpictureOCR.GetTextLineCount(resID)
                        If gdpictureOCR.GetStat() = GdPictureStatus.OK Then
                            message = message + "The number of all recognized text lines: " + lineCount.ToString() + vbCrLf
                            Dim wordCount As Integer = gdpictureOCR.GetWordCount(resID)
                            If gdpictureOCR.GetStat() = GdPictureStatus.OK Then
                                message = message + "The number of all recognized words: " + wordCount.ToString() + vbCrLf
                                For i As Integer = 0 To wordCount - 1
                                    message = message + "The word nr." + i.ToString() + " is included in the line nr." +
                                                        gdpictureOCR.GetWordLineIndex(resID, i).ToString() + "." + vbCrLf
                                Next
                                MessageBox.Show(message, caption)
                                'Continue with analyzing the result ...
                            Else
                                MessageBox.Show("The GetWordCount() method has failed with the status: " + gdpictureOCR.GetStat().ToString(), caption)
                            End If
                        Else
                            MessageBox.Show("The GetTextLineCount() method has failed with the status: " + gdpictureOCR.GetStat().ToString(), caption)
                        End If
                    Else
                        MessageBox.Show("The error occurred when running the OCR. Status: " + gdpictureOCR.GetStat().ToString(), caption)
                    End If
                    'Release the image.
                    GdPictureDocumentUtilities.DisposeImage(image)
                Else
                    MessageBox.Show("The error occurred when creating or setting up the image. Status: " + gdpicturePDF.GetStat().ToString() + "/" + gdpictureOCR.GetStat().ToString(), caption)
                End If
                'Close the document.
                gdpicturePDF.CloseDocument()
            Else
                MessageBox.Show("The file can't be loaded. Status: " + gdpicturePDF.GetStat().ToString(), caption)
            End If
            'Release resources.
            gdpictureOCR.ReleaseOCRResults()
            gdpictureOCR.Dispose()
            gdpicturePDF.Dispose()
            string caption = "Example: GetWordLineIndex";
            GdPictureOCR gdpictureOCR = new GdPictureOCR();
            GdPicturePDF gdpicturePDF = new GdPicturePDF();
            //Load the PDF document.
            if (gdpicturePDF.LoadFromFile("input.pdf", false) == GdPictureStatus.OK)
            {
                //Select the first page.
                gdpicturePDF.SelectPage(1);
                //Render this page to a 200 DPI image.
                int image = gdpicturePDF.RenderPageToGdPictureImage(200, true);
                if ((gdpicturePDF.GetStat() == GdPictureStatus.OK) &&
                    (gdpictureOCR.SetImage(image) == GdPictureStatus.OK)) //Setting up the image is mandatory.
                {
                    //Set up the OCR parameters.
                    gdpictureOCR.ResourcesFolder = "C:\\Path\\To\\GdPicture.NET 14\\Redist\\OCR";
                    gdpictureOCR.AddLanguage(OCRLanguage.English);
                    gdpictureOCR.OCRMode = OCRMode.FavorAccuracy;
                    //Set up the OCR context and the character list.
                    gdpictureOCR.Context = OCRContext.OCRContextSingleBlock;
                    gdpictureOCR.CharacterSet = "0123456789";
                    //Set up the area to be processed by the OCR.
                    gdpictureOCR.SetROI(100, 100, 200, 50);
                    //Run the OCR process to recognize the phone number.
                    string resID = gdpictureOCR.RunOCR();
                    if (gdpictureOCR.GetStat() == GdPictureStatus.OK)
                    {
                        string message = "";
                        int lineCount = gdpictureOCR.GetTextLineCount(resID);
                        if (gdpictureOCR.GetStat() == GdPictureStatus.OK)
                        {
                            message = message + "The number of all recognized text lines: " + lineCount.ToString() + "\n";
                            int wordCount = gdpictureOCR.GetWordCount(resID);
                            if (gdpictureOCR.GetStat() == GdPictureStatus.OK)
                            {
                                message = message + "The number of all recognized words: " + wordCount.ToString() + "\n";
                                for (int i = 0; i < wordCount; i++)
                                {
                                    message = message + "The word nr." + i.ToString() + " is included in the line nr." +
                                                        gdpictureOCR.GetWordLineIndex(resID, i).ToString() + ".\n";
                                }
                                MessageBox.Show(message, caption);
                                //Continue with analyzing the result ...
                            }
                            else
                                MessageBox.Show("The GetWordCount() method has failed with the status: " + gdpictureOCR.GetStat().ToString(), caption);
                        }
                        else
                            MessageBox.Show("The GetTextLineCount() method has failed with the status: " + gdpictureOCR.GetStat().ToString(), caption);
                    }
                    else
                        MessageBox.Show("The error occurred when running the OCR. Status: " + gdpictureOCR.GetStat().ToString(), caption);
                    //Release the image.
                    GdPictureDocumentUtilities.DisposeImage(image);
                }
                else
                    MessageBox.Show("The error occurred when creating or setting up the image. Status: " + gdpicturePDF.GetStat().ToString() + "/" + gdpictureOCR.GetStat().ToString(), caption);
                //Close the document.
                gdpicturePDF.CloseDocument();
            }
            else
                MessageBox.Show("The file can't be loaded. Status: " + gdpicturePDF.GetStat().ToString(), caption);
            //Release resources.
            gdpictureOCR.ReleaseOCRResults();
            gdpictureOCR.Dispose();
            gdpicturePDF.Dispose();
            
            
            See Also