Skip to main content
You are viewing help content for pre-release software. This document and the features it describes are subject to change.
All docs
V25.2
  • Translate Reports Inline in the WPF Document Preview

    • 3 minutes to read

    This help topic describes how to integrate the AI-powered Translate Inline command into the WPF Document Preview.

    wpf-translate-inline-ai-assistant-menu

    Unlike the Translate command, Translate Inline translates text directly on the document preview without additional dialogs. You can export or print the translated document.

    Activate an AI Assistant

    Install NuGet Packages

    Install the following NuGet packages:

    The following tutorial uses Azure OpenAI. Refer to the requirements section for information about NuGet packages required for other supported AI services.

    Register an AI Client

    The following code snippet registers an Azure OpenAI client at application startup:

    using Azure.AI.OpenAI;
    using DevExpress.AIIntegration;
    using Microsoft.Extensions.AI;
    using System.ClientModel;
    // ...
    public partial class App : Application {
        static string AzureOpenAIEndpoint { get { return "AZURE_OPENAI_ENDPOINT"; } }
        static string AzureOpenAIKey { get { return "AZURE_OPENAI_APIKEY"; } }
        static string DeploymentName { get { return "gpt-4o-mini"; } }
    
        public App() {
            IChatClient chatClient = new AzureOpenAIClient(
               new Uri(AzureOpenAIEndpoint),
               new ApiKeyCredential(AzureOpenAIKey))
                   .GetChatClient(DeploymentName).AsIChatClient();
            AIExtensionsContainerDesktop.Default.RegisterChatClient(chatClient);
        }
    }
    

    Note

    Review the following help topic for information on how to register other supported AI services: Register AI Clients.

    Create and Configure AI Assistant Behaviors

    Register DocumentTranslateInlineBehavior, specify its settings, and assign the behavior to the Document Preview control.

    The following settings are available:

    Languages
    Specifies a collection of target languages for text translation.
    Temperature
    Specifies the balance between creativity and consistency in AI responses.
    PromptAugmentation
    Specifies additional instructions that modify the prompt before processing.

    Markup:

    xmlns:dxp="http://schemas.devexpress.com/winfx/2008/xaml/printing" 
    xmlns:dxai="http://schemas.devexpress.com/winfx/2008/xaml/ai" 
    xmlns:dxmvvm="http://schemas.devexpress.com/winfx/2008/xaml/mvvm"  
    ... 
    <dxp:DocumentPreviewControl Name="preview"> 
        <dxmvvm:Interaction.Behaviors> 
            <dxai:DocumentTranslateInlineBehavior>
                <dxai:LanguageInfo Culture="de-DE"/> 
            </dxai:DocumentTranslateInlineBehavior>
        </dxmvvm:Interaction.Behaviors> 
    </dxp:DocumentPreviewControl> 
    

    Code-Behind:

    using System.Collections.Generic;
    using System.Globalization;
    using DevExpress.AIIntegration;
    using DevExpress.AIIntegration.Wpf;
    using DevExpress.Mvvm.UI.Interactivity;
    // ...
    public partial class MainWindow : Window {
        public MainWindow() {
            InitializeComponent();
            AddAIBehaviors();
        }
        void AddAIBehavior() {
            var translateBehavior = new DocumentTranslateInlineBehavior() {
                Languages = new List<LanguageInfo>() {
                    new LanguageInfo() { Culture = new CultureInfo("de-DE") }
                }
            };
            var behavior = Interaction.GetBehaviors(preview);
            behavior.Add(translateBehavior);
        }
    }
    

    Translate a Report Document

    You can access the Translate Inline command in the AI context menu of WPF Document Preview.

    Right-click on an opened report or selected report content. Select Translate Inline from the AI Assistant submenu. Select input text range (selected content, document page, or entire document) and the target language.

    wpf-translate-inline-ai-assistant-menu

    The “AI-Generated Translation” label appears next to the report’s top-left corner once the translation is completed:

    wpf-translate-inline-result

    Click Revert to Original in the AI Assistant submenu to cancel translation:

    wpf-translate-inline-revert-to-original

    The following message appears when you export a document with an AI-generated translation:

    “You are about to export a document that contains AI-generated translations. Do you want to proceed?”

    wpf-translate-inline-export-warning