如何在Windows Phone中获取表单行为,例如设置>>移动网络>> EditAPN。在此页面中,它在scrollviewer中有许多文本框。当用户点击任何文本框并获得焦点时,页面向上滚动并且页眉保持不变并显示SIP键盘。当用户从此文本框中丢失焦点时,页面将进入正常状态,SIP键盘隐藏和标题保持不变。我想实现这种行为。我搜索了很多但没有得到任何解决方案。 很奇怪在WP7中看到scrollviewer行为。 任何帮助都将是伟大而可观的。 提前致谢。 注意:如果有任何棘手的解决方案,请提供示例代码。
这是我的示例代码。
<Grid x:Name="ContentPanel" Grid.Row="1" >
<ScrollViewer x:Name="Scroller">
<StackPanel Orientation="Vertical">
<TextBlock Text="Name"/>
<TextBox x:Name="txtName" />
<TextBlock Text="Email"/>
<TextBox x:Name="txtEmail"/>
<TextBlock Text="Phone"/>
<TextBox x:Name="txtPhone" />
<TextBlock Text="Adress"/>
<TextBox x:Name="txtAddress" />
</StackPanel>
</ScrollViewer>
</Grid>
当我尝试向下滚动时,它不会完全向下移动并且似乎有弹性。
编辑: 这个例子,我已经看过,在我的案例中没用。我有4个文本框,我的重点是第一个文本框和键盘来隐藏最后一个文本框。如果用户想要转到上一个文本框并想要输入输入,则它不会完全滚动并且具有弹性。对于此用户必须按下屏幕的其他部分,然后他进入最后一个框。我在设置中的WP7应用程序中看到了 - &gt;移动网络 - &gt; EditAPN。有4-5个文本框,这些完美滚动。不知道MSFT使用哪种控件或解决方法。
答案 0 :(得分:1)
也许我错了,但为什么不使用简单的网格和listpicker控件。您将需要Windows Phone Toolkit(Nuget Here)。
网格的第一行包含标题,不会更改。 第二行包含您想要的内容(scrollview,listpicker,...)
这是一个非常基本的例子:
<phone:PhoneApplicationPage
x:Class="PhoneApp3.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d" d:DesignWidth="480" d:DesignHeight="768"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}"
Foreground="{StaticResource PhoneForegroundBrush}"
xmlns:toolkit="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone.Controls.Toolkit"
SupportedOrientations="Portrait" Orientation="Portrait"
shell:SystemTray.IsVisible="True">
<!--LayoutRoot is the root grid where all page content is placed-->
<Grid x:Name="LayoutRoot" Background="Transparent">
<Grid.RowDefinitions>
<RowDefinition Height="Auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<!--TitlePanel contains the name of the application and page title-->
<StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28">
<TextBlock x:Name="PageTitle" Text="MY HEADER" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/>
</StackPanel>
<Grid x:Name="ContentPanel" Grid.Row="1">
<toolkit:ListPicker>
<toolkit:ListPickerItem Content="aaa" />
<toolkit:ListPickerItem Content="bbb" />
<toolkit:ListPickerItem Content="ccc" />
</toolkit:ListPicker>
</Grid>
</Grid>
</phone:PhoneApplicationPage>
修改:
呈现SIP键盘时,PhoneApplicationFrame.TranslateTransform.Y设置为特定值(横向为-259,纵向为-339)。要更新布局,我们只需将上边距设置为指定值(-s),然后Silverlight布局系统将解决问题。
此example可能会对您有所帮助。