xaml, wpf, stack panel Jak zrobić żeby elementy po lewej były na lewo, a te po prawej były na prawo?

0
<Window x:Class="PolaczenieTCPKlient.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:PolaczenieTCPKlient"
        mc:Ignorable="d"
        Title="Polaczenie TCP - Klient" Height="350" Width="525">
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="*"/>
            <RowDefinition Height="3*"/>
        </Grid.RowDefinitions>
        <StackPanel Margin="15" VerticalAlignment="Top" Grid.Row="0" Orientation="Horizontal">
            <Label Content="Adres:"/>
            <TextBox MinWidth="200"/>
            <Label Content="Port:"/>
            <TextBox MinWidth="90"/>
        </StackPanel>
        <StackPanel Grid.Row="1" Orientation="Vertical">
            <RichTextBox Margin="30,0" MinHeight="180"/>
            <Button Margin="25" Content="Polacz" Width="120"/>
        </StackPanel>
    </Grid>
</Window>
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;

namespace PolaczenieTCPKlient
{
    /// <summary>
    /// Interaction logic for MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
        }
    }
}
 

Mam tu prostą aplikację w C#, która póki co jeszcze nic nie robi. Chciałbym żeby na samej górze aplikacji label Adres z textboxem był po lewej stronie w StackPanelu, a label Port z textboxem był po prawej stronie StackPanelu. Jak to zrobić? Próbowałem różnych HorizontalAligment ale to nie pomagało.

0

watpie zeby ktos zrozumial co masz na mysli. Narysuj co chcesz osiagnac.

0

Pokazałem na załączniku jak wygląda moja aplikacja. Chciałbym przesunąć te 2 elementy które zaznaczyłem do prawej krawędzi.

1

Wrzuć w UniformGrid

1
<Window x:Class="WpfApplication1.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        Title="MainWindow" Height="350" Width="525">
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="*"/>
            <RowDefinition Height="3*"/>
        </Grid.RowDefinitions>
        <Grid.ColumnDefinitions>
            <ColumnDefinition/>
            <ColumnDefinition/>
        </Grid.ColumnDefinitions>
        <StackPanel Grid.Column="0" Grid.Row="0" Orientation="Horizontal">
            <Label Content="Adres:" VerticalAlignment="Center"/>
            <TextBox MinWidth="200" VerticalAlignment="Center"/>
        </StackPanel>
        <StackPanel Grid.Column="1" Grid.Row="0" Orientation="Horizontal" FlowDirection="RightToLeft">
            <TextBox MinWidth="90" VerticalAlignment="Center" FlowDirection="LeftToRight"/>
            <Label Content="Port:" VerticalAlignment="Center" />
            
        </StackPanel>
            <StackPanel Grid.Row="1" Orientation="Vertical" Grid.ColumnSpan="2">
            <RichTextBox Margin="30,0" MinHeight="180"/>
            <Button Margin="25" Content="Polacz" Width="120"/>
        </StackPanel>
    </Grid>
</Window> 
1

W pierwszym row zrób grida a w nim kolumny:

<Grid.ColumnDefinitions>
<ColumnDefinition Width="Auto" />
<ColumnDefinition Width="*" />
<ColumnDefinition Width="Auto" />
</Grid.ColumnDefinitions>

Środkowa kolumna jest pusta, w pozostałe 2 wrzuć swoje TextBoxy.

1 użytkowników online, w tym zalogowanych: 0, gości: 1