开发大型的MIS系统,肯定是离不开第三方控件的,同时也要根据项目需要自己写几个。

MicroERP共用了以下几个控件:

第三方商业控件:

vsFlexGrid:大名鼎鼎的表格控件,不用多说,配合vsPrinter使用

开源的基础上修改和自己写的:

button按钮

cash会计凭证用的金额线

MDITabs MDI窗体

LeftMenu手风琴导航菜单

这里着重说一下vsFlexGrid、scriptControl的使用,以工资模块来说明表格运算及脚本编程示例。

这个控件也不是万能的,比如单元格没有change事件,很淡疼

在工资发放中,最难的就是工资表的自定义字段,某些成熟的软件用了内置上百个字段,然后由用户修改字段属性方式来完成,这里我用了“行转列”的方式,具体实现效果请参见MicroERP中的工资管理模块。

实现原理就是把预设的工资结构在填制工资表时,将表中的行转为工资表中的发放字段,某工资表数据行如下:

基本工资

岗位工资

养老保险

应发工资

应发工资=基本工资+岗位工资-养老保险

实发工资表时,显示为:

员工姓名|基本工资|岗位工资|养老保险|应发工资

员工一.......................

员工二.......................

以VB为例,实现代码如下,其它语言类似

'行转列
Public Sub SetFrame(frameID As Long)

Dim cn As New ADODB.Connection, rs As New ADODB.Recordset, sql As String
    Dim i As Long
    btnSelectEmployee.Enabled = True
   
    sql = "SELECT tbGZItem.ItemName "
    sql = sql & "FROM (tbGZFrame INNER JOIN tbGZFrameDetail ON
tbGZFrame.ID = tbGZFrameDetail.FrameID) INNER JOIN tbGZItem ON
tbGZFrameDetail.ItemID = tbGZItem.ID "
    sql = sql & "where tbGZFrameDetail.FrameID=" & frameID & " order by tbGZFrameDetail.FOrder"
    On Error GoTo err
    Set cn = GetConnection
    rs.CursorLocation = adUseClient
    rs.Open sql, cn, adOpenStatic, adLockReadOnly

With fg
        .Clear
        .Rows = 1
        .Cols = rs.RecordCount + 3
        For i = 3 To .Cols - 1
            .ColWidth(i) = 1300
            .ColAlignment(i) = flexAlignRightCenter
        Next i
        
        .TextMatrix(0, 1) = "EmpID"
        .TextMatrix(0, 2) = "员工姓名"

.Cell(flexcpAlignment, 0, 1, 0, .Cols - 1) = flexAlignCenterCenter
        .ColWidth(0) = 300
        .ColHidden(1) = True

For i = 0 To rs.RecordCount - 1
            .TextMatrix(0, i + 3) = rs.Fields("ItemName").Value
            .ColKey(i + 3) = rs.Fields("ItemName").Value
            rs.MoveNext
        Next i
    End With
    
    Exit Sub
err:
    If rs.State <> adStateClosed Then rs.Close
    Set rs = Nothing
    If cn.State <> adStateClosed Then cn.Close
    Set cn = Nothing

MsgBox err.Description, vbCritical, "SetFrame"
End Sub

注意,.ColKey(i + 3) = rs.Fields("ItemName").Value,这句是重点。

下在是在工资表编辑时,根据字段定义,来自动计算公式列和所得税列的值

Private Sub fg_BeforeEdit(ByVal Row As Long, ByVal Col As Long, Cancel As Boolean)
    Dim formula As String '公式
    Dim funCol As String '需要计算的列
    Dim i As Integer
    Dim s As Single
    Dim q As Single
    
    If Col = 2 Then Cancel = True
    On Error GoTo err
    If Row <> 0 Then

If GetEditMode(fg.ColKey(Col)) = "公式计算" Then
            funCol = "fg.TextMatrix(" & Row & "," & Col & ")="
            
            formula = GetFormula(mFrameID, GetItemID(fg.ColKey(Col)))
            
            '例:基本工资+补贴-保险
            '将公式替换成行列索引
            For i = 3 To fg.Cols - 1
                formula = Replace(formula, fg.ColKey(i),
"fg.ValueMatrix(" & Row & ", " & fg.colIndex(fg.ColKey(i))
& ")")
            Next i
            formula = funCol & formula
    
            ScriptControl1.Reset
            ScriptControl1.AddObject "fg", fg
            ScriptControl1.ExecuteStatement formula
            
        ElseIf GetEditMode(fg.ColKey(Col)) = "所得税" Then
            txtYF.Text = Trim(GetINIstr(gAppPath & "option.ini", "system", "yffield"))
            '应发工资
            s = Val(fg.TextMatrix(Row, fg.colIndex(txtYF.Text)))
            '起征点
            q = Val(GetINIstr(gAppPath & "option.ini", "system", "gztax"))
            If s <= q Then
                fg.TextMatrix(Row, Col) = "0"
            Else
            '全月应纳税所得额
                fg.TextMatrix(Row, Col) = GetTax(s - q)
            End If
            
            
        End If
    End If
    
    Exit Sub
err:
    MsgBox err.Description, vbExclamation, "fg_BeforeEdit"
End Sub

注意:formula = Replace(formula, fg.ColKey(i), "fg.ValueMatrix(" &
Row & ", " & fg.colIndex(fg.ColKey(i)) & ")"),这句是重点。

工资表结构预定义:

工资数据录入,下图的各列除基本工资和岗位工资外,其它列为自动计算出的数值:

有看不懂的或需要代码的可能联系我

http://www.tshuake.com/microerp

MicroERP开发技术分享:vsFlexGrid、scriptControl实现工资表自定义列与表间关系计算的更多相关文章

  1. MicroERP开发技术分享:技术选型

    为什么要想起开发一个近似一套完整的ERP软件呢,原因有二:一是想在空闲时间把以前的进销存软件丰富一下,结果越搞越大了:二是这些年光搞C#了,不想把VB6忘光了 非微软的东西还真没时间去学,也有主要原因 ...

  2. iOS开发技术分享(1)— iOS本地数据存储

    iOS开发技术分享(1)— iOS本地数据存储 前言: 我本是一名asp.net程序员,后来加入了iOS游戏开发队伍,到现在也有一年多的时间了.这一年来,每天都干到2.3点钟才睡觉,不为别的,只为了学 ...

  3. Docker原理(开发技术分享转发)

    Docker原理Docker是啥Docker是一个程序运行.测试.交付的开放平台,Docker被设计为能够使你快速地交付应用.在Docker中,你可以将你的程序分为不同的 基础部分,对于每一个基础部分 ...

  4. javac选项以递归方式编译给定目录下的所有Java文件 - IT屋-程序员软件开发技术分享社区

    http://www.it1352.com/539276.html #Linux $ find -name“* .java”> sources.txt $ javac @ sources.txt ...

  5. SDNLAB技术分享(四):利用ODL下发流表创建VxLAN网络

    邓晓涛,当前就职于江苏省未来网络创新研究院,是CDN团队的一名研发人员,主要从事SDN相关的研发相关工作.曾就职于三星电子于先行解决方案研发组任高级工程师.思科系统于云协作应用技术部(CCATG)任工 ...

  6. fir.im Weekly - 2016 移动开发技术大回顾

    2016 年是移动技术发展迅速的一年,认认真真回顾这一年必不可少.@移动开发前线 的 这篇 2016移动开发技术巡礼 ,精心盘点了 2016 年 移动开发技术大事件,分为 iOS/Android平台篇 ...

  7. 爱奇艺技术分享:爱奇艺Android客户端启动速度优化实践总结

    本文由爱奇艺技术团队原创分享,原题<爱奇艺Android客户端启动优化与分析>. 1.引言 互联网领域里有个八秒定律,如果网页打开时间超过8秒,便会有超过70%的用户放弃等待,对Andro ...

  8. fir.im Weekly - 新开发时代,需要什么样的技术分享

    "2016年,当我们迎来了如Xcode 8.Swift 3.SiriKit.Android N.Android Instant Apps.React Native等诸多移动开发技术.开发工具 ...

  9. Excel阅读模式/单元格行列指示/聚光灯开发 技术要点再分享

    1. 引言 文题中所谓技术要点再分享,本意是想在大神Charltsing Liu的博文“简单介绍Excel单元格行列指示的实现原理(俗称聚光灯功能)”的基础上写一点个人开发体会.写本文的初衷有三点,一 ...

随机推荐

  1. 剑指offer六:反转链表

    输入一个链表,反转链表后,输出链表的所有元素 public class ListNode { int val; ListNode next = null; ListNode(int val) { th ...

  2. Javascript中的栈

    栈 是一种遵从 后进先出(LIFO)原则的有序集合.就像一摞盘子. push 添加一个元素到栈顶 pop 移除并返回栈顶的元素 peek 返回栈顶元素 isEmpty 如果栈里没有任何元素,返回tru ...

  3. RealSense开发-Session和SenseManager的几种创建方法

    从Intel RealSense 的SDK文档对其架构(如图1所示)的始描述可知,Session是SDK应用的主控模块,必须在所有模块操作之前创建,并且在所有模块注销后最后注销.SenseManage ...

  4. ssm+redis 如何更简洁的利用自定义注解+AOP实现redis缓存

    基于 ssm + maven + redis 使用自定义注解 利用aop基于AspectJ方式 实现redis缓存 如何能更简洁的利用aop实现redis缓存,话不多说,上demo 需求: 数据查询时 ...

  5. ROS学习笔记(八)——ROSTOPIC

    NEW 1 $ roscore NEW 2 $ rosrun turtlesim turtlesim_node NEW 3 $ rosrun turtlesim turtle_teleop_key N ...

  6. 微信微信JS-SDK 6.0.2 填坑笔记

    0.为什么以前不需要配置这么麻烦就可以修改分享description 等信息,但是现在不行了. 因为6.0.2版本之前没有做权限验证,所以config都是ok,但这并不意味着你config中的签名是O ...

  7. laravel 5.2 引入第三方类

    composer 安装类依赖包 很受用 也很方便 但是要是一个有一定规模的公司技术团队 因为要照顾大局 还是引入类好些 下面是引入类的方法 1.首先在app目录下创建一个新的文件夹,命名Tools(可 ...

  8. jquery阻止元素冒泡的两种方法

    通常情况下,如果给父元素添加事件之后,子元素也会继承同样的事件,这个时候就要阻止子元素的这种行为,成为阻止冒泡,总结两种解决方法: html代码: <div id="parent&qu ...

  9. display:inline、block、inline-block的区别

    display:block就是将元素显示为块级元素. block元素的特点是: 总是在新行上开始: 高度,行高以及顶和底边距都可控制: 宽度不设是它的容器的100%,除非设定一个宽度 <div& ...

  10. SPSS数据分析—广义估计方程

    广义线性模型虽然很大程度上拓展了线性模型的应用范围,但是其还是有一些限制条件的,比如因变量要求独立,如果碰到重复测 量数据这种因变量不独立的情况,广义线性模型就不再适用了,此时我们需要使用的是广义估计 ...