zoukankan      html  css  js  c++  java
  • 理解MeasureOverride和ArrangeOverride

    1、MeasureOverride测量方法,ArrangeOverride排列方法。

    2、当自己写容器时会用到这两个方法,需要在自定义类中重写MeasureOverride和ArrangeOverride(名字也能看出)

    //测量
    public
    class NavigationPanel:Panel {
         // availableSize为this(NavigationPanel)的大小
    protected override Size MeasureOverride(Size availableSize) {
            //初始化一个Size Size size
    = new Size();
            //遍历this下的所有子控件
    for (int i = 0; i < this.InternalChildren.Count; i++) {
              //取出一个控件,取名:child
    var child = this.InternalChildren[i];
              //***********************************
              //测量 child 的 大小
              //*Measure方法会递归遍历child下所有子容器的MeasureOverride方法获得大小
              //*********************************** child.Measure(availableSize);
              //child所需大小           size
    = child.DesiredSize;
              //当size大于availableSize时,会被裁剪【父容器裁剪子容器 -- 不难理解】
              //************************************
              //*延伸:当this(NavigationPanel)的大小为Auto时(availableSize大小为Auto时),子容器也为Auto时,那么this的大小怎么定?
              //答:这要看this的父容器大小,this父容器会给this一个Size,如果父容器也为Auto,那么整个窗体都为Auto大小
              //************************************ }
    return base.MeasureOverride(size); } //排列 protected override Size ArrangeOverride(Size finalSize) {
           // finalSize为MeasureOverride方法的返回值
    var thisWidth = finalSize.Width; for (int i = 0; i < this.InternalChildren.Count; i++) { var child = this.InternalChildren[i]; var poingX = thisWidth - child.DesiredSize.Width; if (poingX > 0) {
                //给子控件排列位置,可以查看Arrange方法原注释 child.Arrange(
    new Rect(new Point(poingX, 0), child.DesiredSize)); } else { child.Arrange(new Rect(new Point(0, 0), child.DesiredSize)); } } return base.ArrangeOverride(finalSize); } }
  • 相关阅读:
    PHP之Trait详解
    PHP中__call()方法与重载解析
    PHP Closure(闭包)类详解
    PHP 核心特性
    回调函数
    php的各种 I/O流 以及用法
    关于php的buffer(缓冲区)
    php的运行原理、cgi对比fastcgi以及php-cgi和php-fpm之间的联系区别
    低功耗设计入门(一)——低功耗设计目的与功耗的类型
    从CMOS到触发器(一)
  • 原文地址:https://www.cnblogs.com/ilison/p/12523839.html
Copyright © 2011-2022 走看看