新时尚Windows8开发(20):FlipView控件

2024-03-20 01:08

本文主要是介绍新时尚Windows8开发(20):FlipView控件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

FlipView控件和我们常见到的ListView、ListBox控件很像,今天拿它来吹一吹,是因为这个控件还挺新鲜的。

 

要说用文字来介绍这个控件,还真不够生动也欠缺活泼,不过,其实这个控件咱们还是见得不少的,如果你经常到应用商店下载应用的话,你肯定见过。就是这个:

 

就是这玩意儿,左右各有一个按钮用来导航视图,每次只能查看一个视图,比较适合用于图片浏览。

 

废话少说,我们来做两个实例,第一个是手动添加项,第二个是数据绑定的。

 

好的,先做第一个,很简单,我们在FlipView中放三个项,每个项的内容就是一个Image,看看下面的XAML就会明白了。

    <Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">
<FlipView Margin="300,150">
<FlipViewItem>
<Image
Stretch="Uniform"
Source="http://pica.nipic.com/2008-01-17/2008117205617816_2.jpg"/>
</FlipViewItem>
<FlipViewItem>
<Image
Stretch="Uniform"
Source="http://pic4.nipic.com/20090914/1593169_000535237178_2.jpg"/>
</FlipViewItem>
<FlipViewItem>
<Image
Stretch="Uniform"
Source="http://www.zwtuu.com.cn/upload/2008_10/08102721166304.jpg"/>
</FlipViewItem>
</FlipView>
</Grid>


然后,我们运行一下。

 

好的,现在来看看第二个例子,数据绑定的。

既然要数据绑定了,肯定要数据源的了。因此,我们先伪造一些数据,注意,这数据是伪造的,如有雷同,纯属自然造化。

    public class Student
{
public string Name { get; set; }
public int Age { get; set; }
public string Sex { get; set; }
public string Email { get; set; }
public string Remark { get; set; }
}
public class TestDataSource : System.Collections.ObjectModel.ObservableCollection<Student>
{
public TestDataSource()
{
this.Add(new Student
{
Name = "小赵",
Age = 20,
Sex = "男",
Email = "rubbish@163.com",
Remark = "此人人品低下,经常在公共场所撒尿。"
});
this.Add(new Student
{
Name = "小王",
Age = 18,
Email = "kaozhu@163.com",
Sex = "女",
Remark = "胆大心细脸皮厚。"
});
this.Add(new Student
{
Name = "小刘",
Age = 21,
Email = "ak800@foxmail.com",
Sex = "男",
Remark = "这厮是牛人啊。"
});
}
}


然后,在XAML中进行绑定UI。

<Page
x:Class="FlipViewExample2.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="using:FlipViewExample2"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d">
<Page.Resources>
<Style x:Key="t1" TargetType="TextBlock">
<Setter Property="FontSize" Value="20"/>
<Setter Property="FontWeight" Value="Bold"/>
<Setter Property="VerticalAlignment" Value="Top"/>
<Setter Property="Margin" Value="3,2,6,2"/>
</Style>
<Style x:Key="t2" TargetType="TextBlock">
<Setter Property="FontSize" Value="19"/>
<Setter Property="Margin" Value="3.2,2,3,2"/>
<Setter Property="TextWrapping" Value="Wrap"/>
</Style>
<Style x:Key="jlipviewItemStyle" TargetType="FlipViewItem">
<Setter Property="HorizontalContentAlignment" Value="Center"/>
<Setter Property="VerticalContentAlignment" Value="Center"/>
</Style>
</Page.Resources>
<Grid Background="{StaticResource ApplicationPageBackgroundThemeBrush}">
<FlipView x:Name="fv" Width="500" Height="150" VerticalAlignment="Center" HorizontalAlignment="Center" ItemContainerStyle="{StaticResource jlipviewItemStyle}">
<FlipView.ItemTemplate>
<DataTemplate>
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="auto"/>
<ColumnDefinition Width="*"/>
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="auto"/>
<RowDefinition Height="auto"/>
<RowDefinition Height="auto"/>
<RowDefinition Height="auto"/>
<RowDefinition Height="auto"/>
</Grid.RowDefinitions>
<TextBlock Style="{StaticResource t1}" Grid.Column="0" Grid.Row="0" Text="姓名:"/>
<TextBlock Style="{StaticResource t2}" Grid.Column="1" Grid.Row="0" Text="{Binding Name}"/>
<TextBlock Style="{StaticResource t1}" Grid.Column="0" Grid.Row="1" Text="年龄:"/>
<TextBlock Style="{StaticResource t2}" Grid.Column="1" Grid.Row="1" Text="{Binding Age}"/>
<TextBlock Style="{StaticResource t1}" Grid.Column="0" Grid.Row="2" Text="性别:"/>
<TextBlock Style="{StaticResource t2}" Grid.Column="1" Grid.Row="2" Text="{Binding Sex}"/>
<TextBlock Style="{StaticResource t1}" Grid.Column="0" Grid.Row="3" Text="电邮:"/>
<TextBlock Style="{StaticResource t2}" Grid.Column="1" Grid.Row="3" Text="{Binding Email}"/>
<TextBlock Style="{StaticResource t1}" Grid.Column="0" Grid.Row="4" Text="备注:"/>
<TextBlock Style="{StaticResource t2}" Grid.Column="1" Grid.Row="4" Text="{Binding Remark}"/>
</Grid>
</DataTemplate>
</FlipView.ItemTemplate>
</FlipView>
</Grid>
</Page>


切换到代码视图,在MainPage类的构造函数中加入以下代码,设置FlipView的数据源。

        public MainPage()
{
this.InitializeComponent();
TestDataSource source = new TestDataSource();
this.fv.ItemsSource = source;
}


如果一切正常,运行后,你应该能看到以下效果。

 

 

这篇关于新时尚Windows8开发(20):FlipView控件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/827800

相关文章

VSCode开发中有哪些好用的插件和快捷键

《VSCode开发中有哪些好用的插件和快捷键》作为全球最受欢迎的编程工具,VSCode的快捷键体系是提升开发效率的核心密码,:本文主要介绍VSCode开发中有哪些好用的插件和快捷键的相关资料,文中... 目录前言1、vscode插件1.1 Live-server1.2 Auto Rename Tag1.3

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版