wp7 弹出窗口阻止弹出窗口中的文本框

发布于 2025-01-07 10:30:23 字数 2208 浏览 1 评论 0原文

我有一个在主页上打开的弹出窗口,其中有几个文本框。当您将注意力集中在下方的文本框时,键盘会将其从视图中遮挡起来。通常文本框会滑入视图。我不知道为什么这里没有发生这种情况。

请帮忙!

<UserControl x:Class="Controls.EditControl"
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:SampleData="clr-namespace:SampleData" 
mc:Ignorable="d"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}"
Foreground="{StaticResource PhoneForegroundBrush}"
Height="800" Width="480"
d:DataContext="{d:DesignData ../SampleData/sampleEditPopup.xaml}">

<Grid x:Name="LayoutRoot" Background="#FF000000" Opacity="0.995">
    <StackPanel Margin="0,20,0,0" Orientation="Horizontal" VerticalAlignment="Top">
        <TextBlock TextWrapping="Wrap" Text="Name" HorizontalAlignment="Left" Height="26" Margin="15,10,0,10" Width="110" TextAlignment="Right"/>
        <TextBox x:Name="tb_name" 
            TextWrapping="Wrap" 
            Width="340" Height="75"
            Margin="10,13,15,12"
            InputScope="Text" MaxLength="1000" 
            Text="{Binding Title, Mode=TwoWay}"/>
    </StackPanel>
    <StackPanel Orientation="Horizontal" Margin="0,150,0,0" VerticalAlignment="Top">
        <TextBlock TextWrapping="Wrap" Text="Description" HorizontalAlignment="Left" Height="26" Margin="15,40,0,10" Width="110" VerticalAlignment="Top" TextAlignment="Right"/>
        <TextBox x:Name="tb_description" 
            TextWrapping="Wrap" 
            Width="340" Height="254" 
            Margin="10,13,15,12"
            InputScope="Text" MaxLength="1000" 
            Text="{Binding Description, Mode=TwoWay}"/>
    </StackPanel>
</Grid>

这是打开它的代码:

EditControl ec = new EditControl();
ec.Title = cm.Title;
ec.Description = cm.Description;

//sets appbar icons for accepting values
setEditIcons();

Popup edit = new Popup() { Child = ec, Tag = this };
edit.Closed += new EventHandler(edit_Closed);
edit.IsOpen = true;

I have a popup that opens on the MainPage with a couple of textboxes. When ever you focus on the lower textbox the keyboard obscures it from view. Usually the textboxes slide into view. i don't know why that is not happening here.

please help!

<UserControl x:Class="Controls.EditControl"
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:SampleData="clr-namespace:SampleData" 
mc:Ignorable="d"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}"
Foreground="{StaticResource PhoneForegroundBrush}"
Height="800" Width="480"
d:DataContext="{d:DesignData ../SampleData/sampleEditPopup.xaml}">

<Grid x:Name="LayoutRoot" Background="#FF000000" Opacity="0.995">
    <StackPanel Margin="0,20,0,0" Orientation="Horizontal" VerticalAlignment="Top">
        <TextBlock TextWrapping="Wrap" Text="Name" HorizontalAlignment="Left" Height="26" Margin="15,10,0,10" Width="110" TextAlignment="Right"/>
        <TextBox x:Name="tb_name" 
            TextWrapping="Wrap" 
            Width="340" Height="75"
            Margin="10,13,15,12"
            InputScope="Text" MaxLength="1000" 
            Text="{Binding Title, Mode=TwoWay}"/>
    </StackPanel>
    <StackPanel Orientation="Horizontal" Margin="0,150,0,0" VerticalAlignment="Top">
        <TextBlock TextWrapping="Wrap" Text="Description" HorizontalAlignment="Left" Height="26" Margin="15,40,0,10" Width="110" VerticalAlignment="Top" TextAlignment="Right"/>
        <TextBox x:Name="tb_description" 
            TextWrapping="Wrap" 
            Width="340" Height="254" 
            Margin="10,13,15,12"
            InputScope="Text" MaxLength="1000" 
            Text="{Binding Description, Mode=TwoWay}"/>
    </StackPanel>
</Grid>

and here is the code to open it:

EditControl ec = new EditControl();
ec.Title = cm.Title;
ec.Description = cm.Description;

//sets appbar icons for accepting values
setEditIcons();

Popup edit = new Popup() { Child = ec, Tag = this };
edit.Closed += new EventHandler(edit_Closed);
edit.IsOpen = true;

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

信愁 2025-01-14 10:30:23

从用户体验的角度来看,我强烈建议不要使用任何具有超过 1 或 2 个按钮的部分弹出窗口/覆盖层。只是 WP7 中没有做到这一点。如果您有一份表格希望人们填写,请将其移至其自己的页面。要么让用户导航到该页面,要么在当前页面之前引入一个新的临时页面(无法导航回)。

您将遇到的问题不仅仅是带有表单覆盖的屏幕键盘。您需要将 AppBar 更改为具有用于任何数据输入的“V”和“X”按钮,您需要管理焦点不滑回覆盖/弹出窗口下方,您需要确保“返回” “按钮关闭弹出窗口等。IMO

最好的方法是简单且一致的用户体验。

from a UX perspective I'd heavily recommend against having any partial popup/overlay that has more than 1 or 2 buttons. It's just not done in WP7. If you have a form you'd like folks to fill out move it to its own page. Either by letting the user navigate to that page, or by introducing a new transient page (that cannot be navigated back into) prior to the current page.

You'll have more problems than just the on-screen keyboard in with form overlays. You'll need to change the AppBar to have "V" and "X" buttons for any data entry, you'll need to manage focus not slipping back into under the overlay/popup, you'll need to make sure the "back" button closes the popup, etc.

IMO The best approach is a simple and consistent UX.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文