关于VB中的MDI子窗体不能以模式窗体显示

waterzouzou 2009-10-10 03:46:35
Private Sub cmdModify_Click()
Dim iRet As Integer
If dltUser.Text = "" Then
MsgBox "请选择要修改的用户!", vbOKOnly + vbCritical, "警告"
Exit Sub
End If

Select Case CurUser.iUserClass
Case 1
If UCase(MyUser.strName) = "ADMIN" And UCase(CurUser.strName) <> "ADMIN" Then
MsgBox "您没有修改此用户的权限!", vbOKOnly + vbCritical, "警告"
Exit Sub
End If
If UCase(MyUser.strName) = "ADMIN" Then
iRet = MsgBox("不能修改用户admin的权限和用户名,只能" + vbCrLf & _
"修改该用户的密码!是否要修改密码?", vbYesNo + vbCritical, "警告")
If iRet = vbYes Then
CurUser.strName = MyUser.strName
With frmUserEdit
.Caption = "修改密码"
.strOldUser = CurUser.strName
.txtUserName.Text = Trim(CurUser.strName)
.txtUserName.Enabled = False '不允许修改用户名
Select Case CurUser.iUserClass
Case 1
.cmbUserClass.AddItem "管理员"
Case 2
.cmbUserClass.AddItem "操作员"
End Select
.cmbUserClass.ListIndex = 0
.cmbUserClass.Enabled = False
.bModify = True '设置修改状态
.Show 1
End With
End If
Exit Sub
End If

With frmUserEdit
.strOldUser = MyUser.strName
.txtUserName.Text = MyUser.strName
.txtPWD = MyUser.strPWD
.txtPWD2 = MyUser.strPWD
.Caption = "修改用户信息"
.cmbUserClass.AddItem "管理员"
.cmbUserClass.AddItem "操作员"
.cmbUserClass.ListIndex = MyUser.iUserClass - 1
.bModify = True
.Show 1
End With
Case 2 ' 当前用户权限为2
If MyUser.iUserClass = 1 Then '设置不能修改权限为"1"的用户
MsgBox "您没有修改此用户的权限!", vbOKOnly + vbCritical, "警告"
Else
With frmUserEdit
.strOldUser = MyUser.strName
.txtUserName.Text = MyUser.strName
.txtPWD.Text = MyUser.strPWD
.txtPWD2.Text = MyUser.strPWD
.Caption = "修改用户信息"
.cmbUserClass.AddItem "操作员"
.cmbUserClass.ListIndex = 0
.bModify = True
.Show 1
End With
End If
End Select
AdoUserList.Refresh
DataRefresh
dltUser_Click
End Sub

Private Sub cmdAdd_click()
With frmUserEdit
.txtUserName = ""
.txtPWD = ""
.txtPWD2 = ""
.Caption = "添加用户"
'Admin用户可以添加管理员和操作员,其他管理员只能添加操作员
Select Case CurUser.iUserClass
Case 1
.cmbUserClass.AddItem "管理员"
.cmbUserClass.AddItem "操作员"
.cmbUserClass.ListIndex = 0
.bModify = False
.Show 1
Case 2
.cmbUserClass.AddItem "操作员"
.cmbUserClass.ListIndex = 0
.bModify = False
.Show 1
Case Else
MsgBox "没有添加用户的权限!"
End Select
End With
AdoUserList.Refresh
DataRefresh
dltUser_Click
End Sub
Private Sub cmdDel_Click()
If dltUser.Text = "" Then
MsgBox "请选择要删除的用户", vbOKOnly + vbCritical, "警告"
Exit Sub
End If

If UCase(MyUser.strName) = "ADMIN" Then
MsgBox "不能删除用户admin", vbOKOnly + vbCritical, "警告"
Exit Sub
End If

If CurUser.iUserClass = 2 Then
If MyUser.iUserClass = 1 Then
MsgBox "没有删除此用户的权限!"
Exit Sub
End If
End If

If MsgBox("是否删除用户 " + dltUser.Text + " ?", vbYesNo, "删除") = vbYes Then
MyUser.DeleteUser (dltUser.Text)
AdoUserList.Refresh
DataRefresh
dltUser_Click
End If
End Sub

Private Sub cmdCancel_Click()
Unload Me
End Sub
Public Sub DataRefresh()
AdoUserList.Refresh
Set dltUser.RowSource = AdoUserList '设置数据源
dltUser.ListField = "name" '显示字段
dltUser.BoundColumn = "name" '设置绑定字段
End Sub

Private Sub dltUser_Click()
If dltUser.Text = "" Then
lblUserType = ""
lblUserName = ""
Exit Sub
End If
'读取用户数据
MyUser.GetInfo (dltUser.Text)
If MyUser.iUserClass = 1 Then
lblUserType = "管理员"
Else
lblUserType = "操作员"
End If
lblUserName = MyUser.strName
End Sub

Private Sub Form_Load()
lblUserType.Caption = ""
lblUserName.Caption = ""
AdoUserList.ConnectionString = Conn '数据库连接字符串
AdoUserList.RecordSource = "SELECT * FROM [User]"
DataRefresh
End Sub


我使用了VB应用程序向导建立了窗体,上面这些只是用户管理模块的代码,然后一运行点击:添加用户或删除用户的话就会出现错误404 MDI子窗体不能按模式窗体显示.我是初学VB,这个问题希望有高手帮我解决一下,谢谢
...全文
827 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
waterzouzou 2009-10-11
  • 打赏
  • 举报
回复
谢谢各位高手们的热情回答,我昨天发完帖后就解决了,就是将.show 1后面的1去掉就OK了的!不过还是要谢谢各位朋友解答.
贝隆 2009-10-10
  • 打赏
  • 举报
回复
的确不能模式,我试了一下。
Flyingdragon168 2009-10-10
  • 打赏
  • 举报
回复
[Quote=引用 4 楼 getemail 的回复:]
用此方法还是多文档么?

引用 2 楼 flyingdragon168 的回复:
MDI上窗體打開是不能模式化的。只能form1.show打開。

[/Quote]
form1是指MDI的子窗体。举个例子而已。
zdingyun 2009-10-10
  • 打赏
  • 举报
回复
[Quote=引用 6 楼 getemail 的回复:]
莫非朱总对MDIForm也有研究?
[/Quote]
LS:不敢不敢,与您比差远了!
getemail 2009-10-10
  • 打赏
  • 举报
回复
莫非朱总对MDIForm也有研究?

[Quote=引用 5 楼 zdingyun 的回复:]
LZ:
MDI子窗体是不能显示为有模式的.但如果不是子窗体可以显示为有模式的.
解决方法
1)按1楼建议MDI子窗体 本来就是这样的吧,把.show 后面的1去掉
2)将想设置模式显示的窗体,则设置窗体属性MDIChild为False
[/Quote]
zdingyun 2009-10-10
  • 打赏
  • 举报
回复
LZ:
MDI子窗体是不能显示为有模式的.但如果不是子窗体可以显示为有模式的.
解决方法
1)按1楼建议MDI子窗体 本来就是这样的吧,把.show 后面的1去掉
2)将想设置模式显示的窗体,则设置窗体属性MDIChild为False
getemail 2009-10-10
  • 打赏
  • 举报
回复
用此方法还是多文档么?

[Quote=引用 2 楼 flyingdragon168 的回复:]
MDI上窗體打開是不能模式化的。只能form1.show打開。
[/Quote]
孤独剑_LPZ 2009-10-10
  • 打赏
  • 举报
回复
新手常犯的错误
Flyingdragon168 2009-10-10
  • 打赏
  • 举报
回复
MDI上窗體打開是不能模式化的。只能form1.show打開。
king06 2009-10-10
  • 打赏
  • 举报
回复
MDI子窗体 本来就是这样的吧,把.show 后面的1去掉
内容概要:本文围绕“非线性流量的数据驱动Koopman模型预测控制研究”展开,提出一种基于数据驱动的Koopman算理论方法,用于构建非线性系统的线性化状态空间模型,并结合模型预测控制(MPC)实现对复杂非线性系统的高效控制。研究通过引入扩展动态模态分解(EDMD)等观测函数,将非线性动力学映射至高维特征空间,在该空间实现近似线性化表征,进而融合线性MPC框架进行优化求解。全文系统阐述了Koopman算的数学基础、隐式线性化机制及在非线性流量控制的建模流程,并通过Matlab代码完成了算法实现与仿真实验,验证了该方法在处理无精确物理模型、强非线性、时变动态系统的有效性与鲁棒性,尤其适用于工业流程控制、能源系统调度等实际工程场景。; 适合人群:具备自动控制理论、非线性系统分析基础,熟悉Matlab编程,从事控制工程、系统辨识、智能优化、能源系统建模等方向的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于难以建立精确数学模型的复杂非线性系统(如流体动力系统、电力电系统、机器人动力学等)的建模与实时控制;②实现数据驱动下的模型预测控制,提升系统响应速度与控制精度;③为先进控制策略(如MPC)提供一种可行的线性化建模范式,推动现代控制理论与数据科学、机器学习的深度融合。; 阅读建议:建议读者结合提供的Matlab代码深入理解Koopman方法的具体实现过程,重点关注观测函数构造、核函数选择、矩阵逼近、降维处理及MPC控制器设计等关键技术环节,并尝试将其迁移至其他非线性系统进行复现实验与性能对比,以全面掌握其适用范围与局限性。
内容概要:本文详细介绍了一种基于Simulink的光伏储能单相逆变器并网仿真模型,系统涵盖了光伏阵列、储能单元、DC-AC单相逆变器及并网接口的完整结构,重点实现了储能环节的能量管理与逆变器并网控制策略的建模仿真。通过Simulink平台构建系统模型,验证了逆变器输出电能质量、并网稳定性以及控制系统的动态响应性能,采用SPWM调制、PI闭环控制等关键技术,确保并网电流与电网电压同频同相,满足并网电能质量要求。该模型不仅可用于分布式能源系统的仿真研究,还可作为新能源并网技术的教学与工程实践工具。; 适合人群:电气工程、自动化、新能源科学与工程等相关专业的高校本科生、研究生、科研人员,以及从事光伏发电系统设计、储能控制与并网技术研发的工程技术人员。; 使用场景及目标:①深入理解光伏储能系统能量转换、存储与并网控制的整体工作原理;②支持课程设计、毕业设计或科研项目对单相逆变器控制策略(如SPWM、PI调节、锁相技术等)的仿真验证与参数优化;③为后续研究更复杂的控制算法(如MPPT、低电压穿越、谐波抑制等)提供可扩展的仿真基础平台。; 阅读建议:建议结合MATLAB/Simulink环境动手搭建与调试模型,逐步理解各模块(如光伏建模、储能充放电控制、逆变器驱动、锁相环、PI调节器等)的功能与交互关系,重点关注控制系统的设计逻辑与参数整定过程,并可通过修改负载条件或电网参数测试系统鲁棒性,为进一步拓展至三相系统或多机并网场景奠定基础。

7,789

社区成员

发帖
与我相关
我的任务
社区描述
VB 基础类
社区管理员
  • VB基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧