WPF UI 界面布局 魔术棒 文字笔记识别 技能提升 布局功能扩展与自定义 继承Panel的对象,测量与排列 系列七

应用开发第一步

功能分类:页面上的功能区域划分。。。。需求分析 业务逻辑 数据流 功能模块 UI/UX 编码 测试 发布 功能开发与布局

不用显式的方式设定元素的尺寸 不使用屏幕坐标来指定位置

Grid

功能最强大,布局最灵活的容器

主要属性配置:ColumnDefinitions(ColumnDefinition)、RowDefinitions(RowDefinition)

ShowGridLines、IsSharedSizeScope(SharedSizeGroup)

给子项控件使用:Grid.Row Grid.Column

使用场景:广泛,不知道用什么布局,就用Grid,意外(WrapPanel)

StackPanel

最简单的布局容器之一

主要属性配置:Orientation-调整排列方向、FlowDirection

使用场景:图文并显、工具栏

可以Grid代替

WrapPanel

唯一一个不能被Grid替代的布局控件,水平方向排列,过程中当前子项出界了,进行折行

主要属性配置:Orientation-调整排列方向

使用场景:桌面式图标排列、搜索历史关键词排列

DockPanel

通过设置Dock停靠进行布局

主要属性配置:LastChildFill、DockPanel.Dock

使用场景:应用的主窗口布局(标题栏、状态栏、工具栏、菜单栏)

UniformGrid

另一种行列风格布局,自动生成统一一致的行列

主要属性配置:Columns、Rows 指定的是当前区域均分多少行和列,不存在指定行高和列宽

使用场景:9宫格的功能区域、图表

Canvas

通过精确坐标定位放置子元素

主要属性配置:Canvas.Left、Top、Right、Bottom

使用场景:组态、组件封装(仪表)

InkCanvas

支持任意笔画输入的画布组件

主要属性配置:

使用场景:

画笔

橡皮擦

魔术棒

其他 文字笔记识别

WPF UI InkCanvas 导师演示画板 演示 笔记 画笔 识别-CSDN博客

Border

最基础的装饰控件

主要属性配置:

使用场景:

技能提升 布局功能扩展与自定义

功能需求: 继承Panel的对象,测量与排列

后端

cs 复制代码
protected override Size MeasureOverride(Size availableSize)
{
    double total_y = 0;
    foreach (UIElement item in this.InternalChildren)
    {
        item.Measure(availableSize);
        total_y += item.DesiredSize.Height;
    }
    return new Size(availableSize.Width, total_y);
}


protected override Size ArrangeOverride(Size finalSize)
{
    double offset_y = 0;
    foreach (UIElement item in this.InternalChildren)
    {
        item.Arrange(new Rect(0, offset_y, finalSize.Width, item.DesiredSize.Height));
        offset_y += item.DesiredSize.Height;
    }
    return base.ArrangeOverride(finalSize);
}

扩展

cs 复制代码
public int ColumnSpace { get; set; } = 0;
public int RowSpace { get; set; } = 0;

protected override Size MeasureOverride(Size availableSize)
{
    //var perHeight = availableSize.Height / Math.Ceiling(this.InternalChildren.Count * 0.1 / 3);
    var perWidth = (availableSize.Width - ColumnSpace * 2) / 3;

    double total_y = 0;
    foreach (UIElement item in this.InternalChildren)
    {
        item.Measure(new Size(perWidth, availableSize.Height));
        total_y = item.DesiredSize.Height;
    }
    return new Size(availableSize.Width, total_y);
}


protected override Size ArrangeOverride(Size finalSize)
{
    double offset_y = 0;
    double offset_x = 0;
    var perWidth = (finalSize.Width - ColumnSpace * 2) / 3;

    for (int i = 1; i < this.InternalChildren.Count + 1; i++)
    {
        UIElement item = this.InternalChildren[i - 1];

        item.Arrange(new Rect(offset_x, offset_y, perWidth, item.DesiredSize.Height));

        if (i % 3 == 0)
        {
            offset_x = 0;
            offset_y += item.DesiredSize.Height + RowSpace;
        }
        else
            offset_x += perWidth + ColumnSpace;

    }
    return base.ArrangeOverride(finalSize);
}

C# WPF 3D 数据孪生 系列六-CSDN博客

WPF 3D绘图 点云 系列五-CSDN博客

WPF UI 3D 多轴 机械臂 stl 模型UI交互-CSDN博客

WPF UI 3D 基本概念 点线三角面 相机对象 材质对象与贴图 3D地球 光源 变形处理 动作交互 辅助交互插件 系列三-CSDN博客

相关推荐
老码沉思录1 小时前
React Native 全栈开发实战班 - 第四部分:用户界面进阶之动画效果实现
react native·react.js·ui
大耳猫4 小时前
主动测量View的宽高
android·ui
csucoderlee13 小时前
Android Studio的新界面New UI,怎么切换回老界面
android·ui·android studio
林子漾14 小时前
【paper】分布式无人水下航行器围捕智能目标
分布式·wpf
CodeCraft Studio15 小时前
「实战应用」如何可视化 DHTMLX Scheduler 中的资源工作量?
javascript·ui·数据可视化
OpenTiny社区16 小时前
重磅更新!Fluent Editor 开源富文本支持 LaTeX 可编辑公式啦~
前端·ui·开源·opentiny
wyh要好好学习20 小时前
C# WPF 记录DataGrid的表头顺序,下次打开界面时应用到表格中
开发语言·c#·wpf
未来的嗒嘀嗒21 小时前
探秘Sketch及其替代者:设计软件精选指南
ui
墨笺染尘缘21 小时前
Unity——对RectTransform进行操作
ui·unity·c#·游戏引擎
Python图像识别-11 天前
基于yolov8、yolov5的番茄成熟度检测识别系统(含UI界面、训练好的模型、Python代码、数据集)
python·yolo·ui