• 新建显示病人信息控件PatientElement
    Add-->NewItem-->WPF-->UserControl(WPF),名称:PatientElement.xmal

  • <UserControl x:Class="WPF_OPDrug.PatientElement"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    mc:Ignorable="d"
    d:DesignHeight="" d:DesignWidth="">
    <Grid Margin="">
    <Border BorderThickness="" Background="CadetBlue" BorderBrush="DarkGray"> <StackPanel Orientation="Horizontal" >
    <Image Name="image_photo" Height="" Width="" Source=""></Image>
    <StackPanel Orientation="Vertical">
    <StackPanel Orientation="Horizontal">
    <TextBlock Name="block_PatName" Text="{Binding GivenName}" VerticalAlignment="Center" Margin="1,5" FontSize=""></TextBlock>
    <TextBlock Name="block_PatId" Text="{Binding Id}" VerticalAlignment="Center" Margin="2,5" FontSize="" Foreground="Navy"/>
    <TextBlock Name="block_Sex" Text="{Binding SexId}" VerticalAlignment="Center" Margin="1,5" FontSize="" Foreground="Navy"></TextB
    </StackPanel>
    <StackPanel>
    <TextBlock Name="block_Age" Text="{Binding Birthday}" VerticalAlignment="Center" Margin="2,5" FontSize="" Foreground="Navy"></TextBlock>
    <TextBlock Name="block_condition" Margin="5,0" FontSize="" Foreground="Navy" Width="auto" TextWrapping="Wrap">病情</TextBlock>
    </StackPanel>
    </StackPanel>
    </StackPanel>
    </Border>
    </Grid>
    </UserControl>
  • 在DataOP.cs中写函数从数据库model中获取信息获取
  •  /// <summary>
    /// 获取patient的必要个人信息
    /// </summary>
    ///
    public List<Patient> GetPatInfor()
    {
    var patient = (from p in his.Patient
    select new
    {
    GivenName = p.GivenName,
    Id=p.Id,
    SexId = p.SexId,
    Birthday = p.Birthday
    }).ToList().Select(o => new Patient
    {
    GivenName = o.GivenName,
    Id = o.Id,
    SexId = o.SexId,
    Birthday = o.Birthday
    }).ToList();
    return patient;
    }
  • 显示病人信息的PatientWin.xmal
  • <Window x:Class="WPF_OPDrug.PatientWin"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="PatientWin" WindowState="Maximized" Background="CadetBlue">
    <Grid>
    <Border Name="queryBorder" BorderThickness="">
    <Grid Name="grid_Query">
    </Grid>
    </Border>
    </Grid>
    </Window>
  • 病人信息先行后列显示
  • /// <summary>
    /// //上下滑动显示,先行后列
    /// </summary>
    private void AddUpToDown()
    {
    List<Patient> pat = dataOP.GetPatInfor();
    int count = pat.Count;
    //定义行数=屏幕宽度/控件宽度;列数=病人总数/行数
    int cols = (int)(Convert.ToDouble(SystemParameters.WorkArea.Width) / );
    int rows = Convert.ToInt32(Math.Ceiling(Convert.ToDouble(count) / cols));
    //为grid_Query添加行
    for (int ri = ; ri < rows; ri++)
    {
    RowDefinition row = new RowDefinition();
    row.Height = new GridLength();
    grid_Query.RowDefinitions.Add(row);
    }
    //为grid_Query添加列
    for(int ci=;ci<cols;ci++)
    {
    ColumnDefinition col=new ColumnDefinition();
    col.Width = new GridLength();
    grid_Query.ColumnDefinitions.Add(col);
    } int colNum = ;
    int rowNum = ; for (int i = ; i < count; i++)
    {
    PatientElement patient = new PatientElement();
    patient.block_PatName.Text = pat[i].GivenName.ToString();
    patient.block_PatId.Text = pat[i].Id.ToString();
    patient.block_Sex.Text = pat[i].SexId.ToString();
    patient.block_Age.Text = Convert.ToDateTime(pat[i].Birthday).ToString(); if (colNum == cols)
    {
    rowNum++;
    colNum = ;
    }
    patient.SetValue(Grid.ColumnProperty, colNum);
    patient.SetValue(Grid.RowProperty, rowNum);
    colNum++;
    grid_Query.Children.Add(patient);
    }
    }
  • 病人信息先列后行显示
  • /// <summary>
    /// 左右滑动,先列后行
    /// </summary>
    /// <returns></returns>
    private void AddLeftToRight()
    {
    List<Patient> pat = dataOP.GetPatInfor();
    int count = pat.Count; //由于每行要放置病人信息控件个数:即每行最多能放的个数
    int rows = (int)(Convert.ToDouble(SystemParameters.WorkArea.Height) / ); //*定义行数
    int cols = Convert.ToInt32(Math.Ceiling(Convert.ToDouble(count) / rows));//*定义列数 //为queryGrid添加rows行
    for (int ri = ; ri < rows; ri++)
    {
    RowDefinition rd = new RowDefinition();
    rd.Height = new GridLength();
    grid_Query.RowDefinitions.Add(rd);
    }
    //为queryGrid添加cols列
    for (int ci = ; ci <cols; ci++)
    {
    ColumnDefinition cd = new ColumnDefinition();
    cd.Width = new GridLength();
    grid_Query.ColumnDefinitions.Add(cd);
    } int rowNum = ;
    int colNum = ; for (int i = ;i < count; i++)
    {
    PatientElement patient = new PatientElement();
    patient.block_PatName.Text = pat[i].GivenName.ToString();
    patient.block_PatId.Text = pat[i].Id.ToString();
    patient.block_Sex.Text = pat[i].SexId.ToString();
    patient.block_Age.Text = pat[i].Birthday.ToString(); if (rowNum == rows)
    {
    colNum++;
    rowNum = ;
    }
    patient.SetValue(Grid.ColumnProperty, colNum);
    patient.SetValue(Grid.RowProperty, rowNum);
    rowNum++;
    grid_Query.Children.Add(patient);
    }
    }

WPF:行列显示的更多相关文章

  1. WPF 图片显示中的保留字符问题

    在WPF中显示一张图片,本是一件再简单不过的事情.一张图片,一行XAML代码即可. 但是前段时间遇到了一件奇怪的事: 开发机上运行正常的程序,在某些客户机器上却显示不了图片,而且除了这个问题,其它运行 ...

  2. 在WPF中显示动态GIF

    在我们寻求帮助的时候,最不愿意听到的答复是:很抱歉,在当前版本的产品中还没有实现该功能... 在WPF中显示动态的GIF图像时便遇到了这样的问题,WPF中强大的Image控件却不支持动态的GIF(其只 ...

  3. WPF 循环显示列表

    原文:WPF 循环显示列表 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/SANYUNI/article/details/79423707 项目需要 ...

  4. WPF 窗体显示最前端

    原文:WPF 窗体显示最前端 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/jjx0224/article/details/8782845 如何做一 ...

  5. WPF 远程显示原图 当前主页面 工具栏 一个Window页面的元素适用一个效果

    http://www.jb51.net/article/98384.htm 1.wpf远程显示原图: Stretch="Fill" + ; 主要是因为那个950和650,据显示位置 ...

  6. WPF 托盘显示

    本文告诉大家如何在 WPF 实现在托盘显示,同时托盘可以右击打开菜单,双击执行指定的代码 NotifyIcon WPF 通过 Nuget 安装 Hardcodet.NotifyIcon.Wpf 可以快 ...

  7. 在WPF中显示GIF图片并实现循环播放

    WPF中有一个MediaElement媒体控件,可以来播放媒体,同时也可以显示GIF图片.但看到网上有些人说用MediaElement不能加载作为资源或内嵌的资源的GIF图片,我猜他们一定是在前台用X ...

  8. 【Python学习】解决pandas中打印DataFrame行列显示不全的问题

    在使用pandas的DataFrame打印时,如果表太长或者太宽会自动只给前后一些行列,但有时候因为一些需要,可能想看到所有的行列. 所以只需要加一下的代码就行了. #显示所有列 pd.set_opt ...

  9. Winform WPF 窗体显示位置

    WinForm 窗体显示位置 窗体显示的位置首先由窗体的StartPosition决定,FormStartPosition这个枚举值由如下几种情况 // 摘要: // 窗体的位置由 System.Wi ...

随机推荐

  1. UVA 1291 十四 Dance Dance Revolution

    Dance Dance Revolution Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Su ...

  2. 第一次写python爬虫

    花了4天终于把写完了把国内的几个漏洞平台爬完了,第一次写py,之前一直都在说学习,然后这周任务是把国内的漏洞信息爬取一下.花了1天学PY,剩下的1天一个.期间学习到了很多.总结如下: ======== ...

  3. windows跟linux文件共享

    方法一:windows下的winscp工具 前提条件:windows能够ping通linux:linux关闭防火墙,/etc/init.d/iptables stop 在windows下运行winsc ...

  4. CUBRID学习笔记 45 REPLACE DELETE MERGE 教程

    c#,net,cubrid,教程,学习,笔记欢迎转载 ,转载时请保留作者信息.本文版权归本人所有,如有任何问题,请与我联系wang2650@sohu.com . 过错 ------ 官方文档是英文的, ...

  5. Nginx基础知识之————多模块(非覆盖安装、RTMP在线人数实例安装测试)

    说明:已经安装好的nginx,需要添加一个未被编译安装的模块,需要怎么弄呢? 具体:这里以安装第三方nginx-rtmp-module和nginx-accesskey-2.0.3模块为例,nginx的 ...

  6. HIHO线段树(成段)

    #include <stdio.h> #define lson l,mid,id<<1 #define rson mid+1,r,id<<1|1 ; ],lazy[ ...

  7. MySQL Server 5.7解压版缺少文件无法启动

    如题: 一般认为5.7中mysql目录下 缺少data/mysql/目录,导致无法启动: 解决方案: 重新安装5.6即可: 1.删除5.7中安装的服务: 到mysql\bin目录下运行:mysqld ...

  8. [转载] tcp那些事2

    原文: http://coolshell.cn/articles/11609.html 这篇文章是下篇,所以如果你对TCP不熟悉的话,还请你先看看上篇<TCP的那些事儿(上)> 上篇中,我 ...

  9. javaMail编写案列

    package common.impl; import java.util.Properties; import javax.mail.BodyPart; import javax.mail.Mess ...

  10. 在PC端或移动端应用中接入商业QQ的方法

    今天看博友的博客学习了一种很有用的方法: 在页面中需要接入企业的QQ,访问网址:http://shang.qq.com/widget/consult.php.(就是API接口),然后你只需要登录你的Q ...