zoukankan      html  css  js  c++  java
  • WPF DatePicker 正确放大字体的姿势

    1、问题引出

    在我们开发的过程中,有时需要对控件字体进行放大,如果是一个TextBox,大家都很熟练,不就是设置FontSize吗,这个简单,那对于DatePicker控件呢?

    2、不完美解决方案

    很多人又会说不是一样的道理吗,你看分分钟就搞定

    但是不懂大家有没有发现,放大的仅仅只是文本值,下面的弹出框的字体和右侧日历图标都是没有变大的,这样给用户的是一种很别扭的感觉。

    3、完美的解决方案

    既然这种方案有问题,那有其它的解决方案吗?答案肯定是有的。

    答案就在微软的官方文档:自定义新的WPF Calendar控件 

     文中介绍了两种解决方案

    方案1:使用LayoutTransform属性,效果如下

     方案2:使用ViewBox,效果如下:

     示例代码

    <Window x:Class="WpfApp3.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:WpfApp3"
            mc:Ignorable="d"
            Title="MainWindow" Height="450" Width="800">
        <Grid>
            <DatePicker Width="200" HorizontalAlignment="Left" FontSize="30" VerticalAlignment="Top" Margin="10"/>
    
            <Viewbox Visibility="Visible" Stretch="Uniform" Width="300" Height="42"  HorizontalAlignment="Left"  VerticalAlignment="Top" Margin="10,90,0,0">
                <DatePicker Width="150"/>
            </Viewbox>
    
            <DatePicker Visibility="Hidden" Width="150" HorizontalAlignment="Left" VerticalAlignment="Top" Margin="10,170,0,0">
                <DatePicker.LayoutTransform>
                    <ScaleTransform  ScaleX="1.7" ScaleY="1.7"/>
                </DatePicker.LayoutTransform>
            </DatePicker>
        </Grid>
    </Window>
    View Code
  • 相关阅读:
    Power Strings P5019
    Floyd模板题 P1704
    【训练题】强连通分量缩点 P1679
    字符串hash模板题 P5018
    Dijkstra模板题 P1710
    【训练题】分队 P1672
    二分图模板题 P1631
    【训练题】无序字母对 P1675
    KMP模板题 P1537
    马路 树链剖分/线段树/最近公共祖先(LCA)
  • 原文地址:https://www.cnblogs.com/zhangqibao/p/13304094.html
Copyright © 2011-2022 走看看