Microsoft Technologies Right-to-Left (RTL) এবং Left-to-Right (LTR) Layout Support গাইড ও নোট

393

Right-to-Left (RTL) এবং Left-to-Right (LTR) লেআউট সাপোর্ট অ্যাপ্লিকেশনের ভাষা এবং ব্যবহারকারীর অঞ্চলের ওপর নির্ভর করে। যখন আপনি একটি আন্তর্জাতিক (International) অ্যাপ্লিকেশন তৈরি করেন, তখন আপনাকে বিভিন্ন ভাষার জন্য সঠিক লেআউট সমর্থন নিশ্চিত করতে হবে। উদাহরণস্বরূপ, English, French, Spanish প্রভৃতি ভাষাগুলি Left-to-Right (LTR) লেআউট ব্যবহার করে, যখন Arabic, Hebrew, এবং Urdu প্রভৃতি ভাষাগুলি Right-to-Left (RTL) লেআউট ব্যবহার করে।

এটি বিশেষভাবে গুরুত্বপূর্ণ, কারণ ব্যবহারকারীরা তাদের নিজের ভাষার জন্য উপযুক্ত ইউজার ইন্টারফেস (UI) চাইবে এবং যদি UI সঠিকভাবে লেআউট না হয়, তবে তা ইউজার এক্সপেরিয়েন্স (UX) নষ্ট করতে পারে।


LTR এবং RTL লেআউট সাপোর্ট কিভাবে কাজ করে?

LTR এবং RTL লেআউট সাপোর্ট করার জন্য অ্যাপ্লিকেশনকে সঠিকভাবে কনফিগার করতে হবে। উইন্ডোজ অ্যাপ্লিকেশনগুলোতে সাধারণত TextFlowDirection বা FlowDirection প্রপার্টি ব্যবহার করা হয়, যা ডানদিকে বা বামদিকে টেক্সট প্রবাহ পরিচালনা করে।

১. LTR Layout

LTR (Left-to-Right) লেআউট এমন একটি লেআউট যেখানে ইউজারের ইনপুট এবং টেক্সট বাম থেকে ডানে প্রবাহিত হয়। এটি বেশিরভাগ পশ্চিমী ভাষা, যেমন ইংরেজি, স্প্যানিশ, ফরাসী, প্রভৃতির জন্য ব্যবহৃত হয়।

২. RTL Layout

RTL (Right-to-Left) লেআউট এমন একটি লেআউট যেখানে ইউজারের ইনপুট এবং টেক্সট ডান থেকে বামে প্রবাহিত হয়। এটি আরবী, হিব্রু, উর্দু ইত্যাদি ভাষার জন্য ব্যবহৃত হয়।

WinUI 3 এবং WPF-এ LTR এবং RTL সাপোর্ট

1. WinUI 3 (Windows App SDK) for RTL and LTR

WinUI 3 এবং UWP (Universal Windows Platform) অ্যাপ্লিকেশনে FlowDirection প্রপার্টি ব্যবহার করে লেআউট পরিবর্তন করা যায়। এটি TextBlock, Button, ListBox, ComboBox ইত্যাদি কন্ট্রোলের জন্য কাজ করে।

উদাহরণ: WinUI 3-এ RTL এবং LTR লেআউট

XAML:

<Window x:Class="RTL_LTR_Example.MainWindow"
        xmlns="using:Microsoft.UI.Xaml.Controls"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="RTL/LTR Layout" Height="350" Width="525">
    <Grid FlowDirection="{Binding FlowDirection}">
        <TextBlock Text="Hello, world!" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="24"/>
    </Grid>
</Window>

C# কোড:

using Microsoft.UI.Xaml;
using Microsoft.UI.Xaml.Controls;
using Windows.Globalization;

namespace RTL_LTR_Example
{
    public sealed partial class MainWindow : Window
    {
        public MainWindow()
        {
            this.InitializeComponent();
            SetFlowDirection();
        }

        private void SetFlowDirection()
        {
            var currentLanguage = ApplicationLanguages.Languages[0];
            // Check if the current language is RTL (for example, Arabic)
            if (currentLanguage == "ar")
            {
                this.FlowDirection = FlowDirection.RightToLeft;
            }
            else
            {
                this.FlowDirection = FlowDirection.LeftToRight;
            }
        }
    }
}

ব্যাখ্যা:

  • FlowDirection: উইন্ডোতে বা কন্ট্রোলগুলিতে LTR বা RTL লেআউট নির্ধারণ করে। যখন বর্তমান ভাষা আরবি (Arabic) হবে, তখন UI-টি RTL লেআউট অনুসরণ করবে, অন্যথায় LTR হবে।

2. WPF (Windows Presentation Foundation) for RTL and LTR

WPF-এ, আপনি FlowDirection প্রপার্টি ব্যবহার করে TextBlock, Button, ListBox, ComboBox ইত্যাদির জন্য RTL এবং LTR সাপোর্ট কনফিগার করতে পারেন।

উদাহরণ: WPF-এ RTL এবং LTR সাপোর্ট

XAML:

<Window x:Class="RTL_LTR_WPF.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="WPF RTL/LTR Layout" Height="350" Width="525">
    <Grid FlowDirection="{Binding FlowDirection}">
        <TextBlock Text="Hello, World!" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="24"/>
    </Grid>
</Window>

C# কোড:

using System.Windows;

namespace RTL_LTR_WPF
{
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            SetFlowDirection();
        }

        private void SetFlowDirection()
        {
            var currentLanguage = System.Globalization.CultureInfo.CurrentCulture.Name;
            // Check if the current language is RTL (e.g., Arabic)
            if (currentLanguage.StartsWith("ar"))
            {
                this.FlowDirection = System.Windows.FlowDirection.RightToLeft;
            }
            else
            {
                this.FlowDirection = System.Windows.FlowDirection.LeftToRight;
            }
        }
    }
}

ব্যাখ্যা:

  • FlowDirection: WPF-এ ব্যবহার করা হয়েছে, যা LTR বা RTL লেআউট সিলেক্ট করতে সাহায্য করে। CultureInfo.CurrentCulture.Name এর মাধ্যমে বর্তমান ভাষা চেক করা হয় এবং তার ভিত্তিতে লেআউট পরিবর্তিত হয়।

3. Auto Detection of RTL or LTR Based on Language

যেহেতু RTL এবং LTR লেআউট সাধারণত ভাষার ওপর নির্ভর করে, আপনাকে এমন একটি সিস্টেম তৈরি করতে হবে যা স্বয়ংক্রিয়ভাবে ব্যবহারকারীর ভাষার উপর ভিত্তি করে লেআউট সিলেক্ট করবে। আপনি CultureInfo বা ApplicationLanguages ব্যবহার করে এরকম কাজ করতে পারেন।

উদাহরণ: Auto Detection (Auto RTL/LTR) - WinUI 3

private void SetFlowDirection()
{
    var currentLanguage = ApplicationLanguages.Languages[0];
    if (currentLanguage == "ar" || currentLanguage == "he" || currentLanguage == "fa")
    {
        this.FlowDirection = FlowDirection.RightToLeft;  // RTL Languages
    }
    else
    {
        this.FlowDirection = FlowDirection.LeftToRight;  // LTR Languages
    }
}

উদাহরণ: Auto Detection (Auto RTL/LTR) - WPF

private void SetFlowDirection()
{
    var currentLanguage = System.Globalization.CultureInfo.CurrentCulture.Name;
    if (currentLanguage.StartsWith("ar") || currentLanguage.StartsWith("he") || currentLanguage.StartsWith("fa"))
    {
        this.FlowDirection = System.Windows.FlowDirection.RightToLeft; // RTL Languages
    }
    else
    {
        this.FlowDirection = System.Windows.FlowDirection.LeftToRight; // LTR Languages
    }
}

4. RTL and LTR Support for Text

TextBlock বা অন্যান্য টেক্সট-ভিত্তিক কন্ট্রোলগুলোতে, যদি LTR বা RTL লেআউট সঠিকভাবে সাপোর্ট না করা হয়, তবে টেক্সট সঠিকভাবে প্রদর্শিত হবে না। এজন্য আপনাকে TextAlignment এবং FlowDirection-এর ব্যবহার সঠিকভাবে করতে হবে।

উদাহরণ: RTL টেক্সটের জন্য TextAlignment

<TextBlock Text="مرحبا بالعالم" FlowDirection="RightToLeft" TextAlignment="Right"/>
  • TextAlignment="Right": RTL লেআউটে টেক্সট ডান দিকে সজ্জিত হবে।
  • FlowDirection="RightToLeft": RTL ভাষার জন্য প্রবাহ সঠিকভাবে সেট করা হবে।

Conclusion

Right-to-Left (RTL) এবং Left-to-Right (LTR) লেআউট সাপোর্ট অ্যাপ্লিকেশনটির আন্তর্জাতিককরণ (i18n) এবং স্থানিককরণ (l10n) প্রক্রিয়ার জন্য অত্যন্ত গুরুত্বপূর্ণ। FlowDirection প্রপার্টি, CultureInfo, ApplicationLanguages, এবং TextAlignment ব্যবহার করে, আপনি সহজেই LTR এবং RTL লেআউট সঠিকভাবে কনফিগার এবং প্রয়োগ করতে পারবেন। এটি অ্যাপ্লিকেশনটির ইউজার এক্সপেরিয়েন্সে উন্নতি করে এবং বিশ্বের বিভিন্ন ভাষাভাষী ব্যবহারকারীদের জন্য অ্যাপ্লিকেশনটি ব্যবহারের উপযোগী করে তোলে।

Content added By
Promotion

Are you sure to start over?

Loading...