ASP.NET2.0自定义控件开发(4) ----给控件添加树状属性

本文介绍了一种自定义的ASP.NET Web控件LabelTextBox,该控件集成了Label和TextBox的功能,并支持多种TextBox模式,如单行、多行及密码输入。通过设置属性可以灵活调整控件的外观。

4.给控件添加树状属性 

 


using System;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.ComponentModel;

namespace CustomControls
{
    
/// <summary>
    
/// Summary description for LabelTextBox
    
/// </summary>

    public class LabelTextBox : Control
    
{
        
private string _labelText="LabelText";
        
private string _textBoxText = "";
        
private SizeInfo _size;

        [Browsable(
true),
         Description(
"获取和设置Label文本"),
         DefaultValue(
"LabelText"),
         Category(
"Appearance")
        ]
        
public virtual string Title
        
{
            
get return _labelText; }
            
set { _labelText = value; }
        }


        [Browsable(
true),
         Description(
"获取和设置TextBox文本"),
         DefaultValue(
""),
         Category(
"Appearance")
        ]
        
public virtual string Text
        
{
            
get return _textBoxText; }
            
set { _textBoxText = value; }
        }


        [Browsable(
true),
         Description(
"获取和设置TextBox的显示方式"),
         DefaultValue(
""),
         Category(
"Appearance")
        ]
        
public virtual TextBoxMode TextMode
        
{
            
get
            
{
                
object _textMode = ViewState["TextMode"];
                
if (_textMode == null)
                    
return TextBoxMode.SingleLine;
                
else
                    
return (TextBoxMode)_textMode;
            }

            
set
            
{
                ViewState[
"TextMode"= value;
            }

        }


        [Browsable(
true),
         Description(
"获取和设置控件的大小"),
         DesignerSerializationVisibility(DesignerSerializationVisibility.Content),
         NotifyParentProperty(
true),
         Category(
"Appearance")
        ]
        
public virtual SizeInfo Size
        
{
            
get 
            
{
                
if (_size == null)
                    _size 
= new SizeInfo();
                
return _size;
            }

        }


        
protected override void Render(HtmlTextWriter writer)
        
{
            Page.VerifyRenderingInServerForm(
this);

            
if (TextMode == TextBoxMode.SingleLine)
            
{
                writer.Write(
"<table style='width:180px;height:25px;border-width:0;'>");
                writer.Write(
"<tr>");
                writer.Write(
"<td><strong>" + _labelText + "</strong></td>");
                writer.Write(
"<td><input name='TextBox' id='TextBox' type='text' /></td>");
                writer.Write(
"</tr>");
                writer.Write(
"</table>");
            }

            
else if (TextMode == TextBoxMode.MultiLine)
            
{
                writer.Write(
"<table style='width:180px;height:25px;border-width:0;'>");
                writer.Write(
"<tr valign='top'>");
                writer.Write(
"<td><strong>" + _labelText + "</strong></td>");
                writer.Write(
"<td><textarea name='TextBox' id='TextBox' /></td>");
                writer.Write(
"</tr>");
                writer.Write(
"</table>");
            }

            
else if (TextMode == TextBoxMode.Password)
            
{
                writer.Write(
"<table style='width:180px;height:25px;border-width:0;'>");
                writer.Write(
"<tr>");
                writer.Write(
"<td><strong>" + _labelText + "</strong></td>");
                writer.Write(
"<td><input name='TextBox' id='TextBox' type='password' /></td>");
                writer.Write(
"</tr>");
                writer.Write(
"</table>");
            }


            
base.Render(writer);
        }

    }


    [TypeConverter(
typeof(ExpandableObjectConverter))]
    
public class SizeInfo
    
{
        
private int _width;
        
private int _height;

        [NotifyParentProperty(
true)]
        
public int Width
        
{
            
get return _width; }
            
set { _width = value; }
        }


        [NotifyParentProperty(
true)]
        
public int Height
        
{
            
get return _height; }
            
set { _height = value; }
        }

    }

}

内容概要:本文介绍了一个基于冠豪猪优化算法(CPO)的无人机三维路径规划项目,利用Python实现了在复杂三维环境中为无人机规划安全、高效、低能耗飞行路径的完整解决方案。项目涵盖空间环境建模、无人机动力学约束、路径编码、多目标代价函数设计以及CPO算法的核心实现。通过体素网格建模、动态障碍物处理、路径平滑技术和多约束融合机制,系统能够在高维、密集障碍环境下快速搜索出满足飞行可行性、安全性与能效最优的路径,并支持在线重规划以适应动态环境变化。文中还提供了关键模块的代码示例,包括环境建模、路径评估和CPO优化流程。; 适合人群:具备一定Python编程基础和优化算法基础知识,从事无人机、智能机器人、路径规划或智能优化算法研究的相关科研人员与工程技术人员,尤其适合研究生及有一定工作经验的研发工程师。; 使用场景及目标:①应用于复杂三维环境下的无人机自主导航与避障;②研究智能优化算法(如CPO)在路径规划中的实际部署与性能优化;③实现多目标(路径最短、能耗最低、安全性最高)耦合条件下的工程化路径求解;④构建可扩展的智能无人系统决策框架。; 阅读建议:建议结合文中模型架构与代码示例进行实践运行,重点关注目标函数设计、CPO算法改进策略与约束处理机制,宜在仿真环境中测试不同场景以深入理解算法行为与系统鲁棒性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值