首页 上一页 1 2 3 下一页 尾页

用1500plc及hmi制作随机抽奖程序 点击:5757 | 回复:58



小古gg

    
  • 精华:1帖
  • 求助:0帖
  • 帖子:4帖 | 9回
  • 年度积分:385
  • 历史总积分:2078
  • 注册:2018年6月08日
发表于:2021-12-25 01:10:08
楼主

    今年马上结束了,单位又要举行年会,抽奖活动必不可少,制作一个抽奖软件一般都是IT人员的工作,身为一个工控人,怎么能谦让呢,今年用西门子1500plc+HMI制作一个抽奖程序,年会现场没有硬件,于是使用西门子的plcsim仿真加电脑屏幕投影。

使用软件版本TIA15.1

功能:随机抽取人名,随机抽奖,被抽取的人和奖品不在出现,最后可将结果保存在电子表格内,抽奖人数最大99人,

画面一,欢迎界面

1.JPG

画面2-设置人名和奖品画面

画面三-抽奖画面

触摸屏和plc程序代码:(详细可下载附件查看)

//Check_Fild

Dim FSO ,Myfile  'FSO:访问系统文件的一个对象,Myfile:访问文件

Set FSO=CreateObject("scripting.filesystemobject")   '创建访问系统文件

If FSO.FileExists("C:\Storage Card SD\Logs\2021NewYearParty.csv")=True Then     '如果存在文件

Call Write_Date'调用write_date函数

Else

Set Myfile=FSO.CreateTextFile("C:\Storage Card SD\Logs\2021NewYearParty.csv")'利用creat方法创建文件,并将对象返回到Myfile中

Myfile.WriteLine "编号,时间,人名,奖品"'利用writeline函数对新建的文件写入表头

Myfile.Close'关闭文件

Call Write_Date'调用write_date函数

Set Myfile=Nothing'释放对象

End If

Set FSO=Nothing


End Sub


//Delete_File

Dim FSO

Set FSO=CreateObject("scripting.filesystemobject")

If FSO.FileExists("C:\Storage Card SD\Logs\2021NewYearParty.csv")=True Then    '检查如果文件存在,然后

FSO.DeleteFile ("C:\Storage Card SD\Logs\2021NewYearParty.csv") '删除文件

End If

Set FSO=Nothing

End Sub



//Write_Date

Dim FSO,MyFile   'FSO:访问系统文件的一个对象,Myfile:访问的文件

Set FSO=CreateObject("scripting.filesystemobject")   'set语句创建访问系统的对象并用set进行对象引用

Set MyFile=FSO.OpenTextFile("C:\Storage Card SD\Logs\2021NewYearParty.csv",8)'利用OpenTextFile函数打开指定文件,并用Myfile进行对象引用

                                                 'OpenTextFile参数说明:(“文件路径”,打开模式【1:只读 2:写 8:在最后一行写入】)

MyFile.WriteLine MyFile.Line-1&","&Time()&","&SmartTags("HMI_随机人名显示")&","&SmartTags("HMI_随机奖品名显示")

                                                                '将编号、时间、人名、奖品名变量写入到Excel文件中

MyFile.Close'关闭文件

Set FSO=Nothing'释放对象

Set MyFile=Nothing



End Sub

//开机时初始化

IF "FirstScan" THEN

    #抽奖次数 := 99;

    #中奖人 := 101;

    "确认" := 1;

    "复位提示" := 1;

END_IF;


//复位中奖人单和奖品名背景色

IF "抽奖重新开始" THEN

    FOR #i := 0 TO 99 DO

        "HMI".中奖人名变色[#i] := 0;

        "HMI".中奖奖品变色[#i] := 0;

    END_FOR;

IF #人数 > 99 THEN    //抽奖人数不能大于99人

    #人数 := 0;

    #中奖人 := 103;   //103表示人数超上限

    

END_IF;


#R_TRIG_Instance_2(CLK:=#RESET OR "FirstScan" , //数列复位

                   Q=>#R_TRIG_Instance_2.Q);

IF #R_TRIG_Instance_2.Q THEN                    

    FOR #j := 0 TO 109 DO

        #站队[#j] := #j + 1;

    END_FOR;

    #n := 20;

    #中奖人 := 102;       //102代码表示请抽奖

    #抽奖次数 := 0;

    "抽奖" := 0;

END_IF;



FOR #i := 0 TO 99 DO                     //序列重新排队

    IF #站队[#i] > #站队[#i + 1] THEN

        #战队temp := #站队[#i];

        #站队[#i] := #站队[#i + 1];

        #站队[#i + 1] := #战队temp;

    END_IF;

END_FOR;



#R_TRIG_Instance(CLK:=#抽奖,               //点击抽奖

                 Q=>#R_TRIG_Instance.Q);

IF #R_TRIG_Instance.Q THEN

    #中奖人 := #站队[#n];

    #n_timp := #n;

END_IF;


#中奖人名 := "抽奖人名单".中奖人名单[#中奖人 - 1];


#随机人 := #站队[#n];


#R_TRIG_Instance_1(CLK := #确认,               //对抽奖结果确认

                   Q => #R_TRIG_Instance_1.Q);

IF #R_TRIG_Instance_1.Q THEN

    #站队[#n_timp] := 100;

    #中奖人 := 102;           //等待抽奖

    #抽奖次数 := #抽奖次数 + 1;

END_IF;


#n := #n + 1;//随机数,因博图中无随机数,所以采取让n快速自增的方法。

IF #n >= #人数 - #抽奖次数 THEN

  #n := 0;

END_IF;



IF #抽奖次数 >= #人数 THEN     //抽奖次数大于人数时,提示抽奖结束

    #中奖人 := 101;            //101表示抽奖结束

END_IF;



END_IF;

//中奖人单背景变色

IF "中奖人" < 100 THEN

    IF "抽奖" = 1 THEN

        #j := "中奖人";

        "HMI".中奖人名变色[#j] := 1;

    END_IF;

    #n:= "中奖人";

    IF "再给次机会"=1 THEN

      

        "HMI".中奖人名变色[#n] := 0;

    END_IF;

END_IF;


//中奖奖品名背景变色

IF "中奖名" < 100 THEN

    IF "抽奖_JP" = 1 THEN

        #j := "中奖名";

        "HMI".中奖奖品变色[#j] := 1;

    END_IF;

    #n := "中奖名";

    IF "再给次机会_JP" = 1 THEN

        

        "HMI".中奖奖品变色[#n] := 0;

    END_IF;

END_IF;


//HMI显示块

//"随机显示人名"

IF "抽奖" = 0 THEN

    "HMI".随机人名显示 := "抽奖人名单".中奖人名单["随机人" - 1];

ELSE

    "HMI".随机人名显示 := "抽奖人名单".中奖人名单[ "中奖人"- 1];

END_IF;


//"随机显示奖品名"

IF "抽奖_JP" = 0 THEN

    "HMI".随机奖品名显示 := "奖品名单".中奖人名单["随机奖品" - 1];

ELSE

    "HMI".随机奖品名显示 := "奖品名单".中奖人名单["中奖名"- 1];

END_IF;


//检查人名单是否有重名

FOR #a := 0 TO 98 DO

    FOR #b := #a+1 TO 99 DO

        IF "抽奖人名单".中奖人名单[#a] = "抽奖人名单".中奖人名单[#b]

            AND "抽奖人名单".中奖人名单[#a] <> #no_name THEN

            "抽奖人名单".中奖人名 := "抽奖人名单".中奖人名单[104];

            "HMI".相同人名报警 := 1;

      //  ELSE

         

        END_IF;

    END_FOR;

END_FOR;

IF "抽奖人名单".中奖人名 <> "抽奖人名单".中奖人名单[104] THEN

    "HMI".相同人名报警 := 0;

END_IF;


//统计人名单人数

#c := 0;

FOR #d := 0 TO 99 DO

    IF "抽奖人名单".中奖人名单[#d] <> #no_name THEN

        #c := #c + 1;

    END_IF;

END_FOR;

"人数" := #c;


//统计奖品数量

#e := 0;

FOR #d := 0 TO 99 DO

    IF "奖品名单".中奖人名单[#d] <> #no_name THEN

        #e := #e + 1;

    END_IF;

END_FOR;

"奖品数" := #e;


//如果奖品数量低于人数,则报警

IF "奖品数" < "人数" THEN

    "HMI".奖品少报警 := 1;

ELSE

    "HMI".奖品少报警 := 0;

END_IF;


IF #奖品数 > 99 THEN    //奖品数不能大于99人

    #奖品数 := 0;

    #中奖名 := 103;   //103表示数量超上限

    

END_IF;


#R_TRIG_Instance_2(CLK:=#RESET OR "FirstScan" , //数列复位

                   Q=>#R_TRIG_Instance_2.Q);

IF #R_TRIG_Instance_2.Q THEN                    

    FOR #j := 0 TO 109 DO

        #站队[#j] := #j + 1;

    END_FOR;

    #n := 20;

    #中奖名 := 102;       //102代码表示请抽奖

    #抽奖次数 := 0;

    "抽奖_JP" := 0;

END_IF;



FOR #i := 0 TO 99 DO                     //序列重新排队

    IF #站队[#i] > #站队[#i + 1] THEN

        #战队temp := #站队[#i];

        #站队[#i] := #站队[#i + 1];

        #站队[#i + 1] := #战队temp;

    END_IF;

END_FOR;



#R_TRIG_Instance(CLK:=#抽奖,               //点击抽奖

                 Q=>#R_TRIG_Instance.Q);

IF #R_TRIG_Instance.Q THEN

    #中奖名 := #站队[#n];

    #n_timp := #n;

END_IF;


#中奖人名 := "奖品名单".中奖人名单[#中奖名 - 1];


#随机奖品 := #站队[#n];


#R_TRIG_Instance_1(CLK := #确认,               //对抽奖结果确认

                   Q => #R_TRIG_Instance_1.Q);

IF #R_TRIG_Instance_1.Q THEN

    #站队[#n_timp] := 100;

    #中奖名 := 102;           //等待抽奖

    #抽奖次数 := #抽奖次数 + 1;

END_IF;


#n := #n + 1;//随机数,因博图中无随机数,所以采取让n快速自增的方法(大约1s自增一千次)。

IF #n >= #奖品数 - #抽奖次数 THEN

  #n := 0;

END_IF;



IF #抽奖次数 >= #奖品数 THEN     //抽奖次数大于人数时,提示抽奖结束

    #中奖名 := 101;            //101表示抽奖结束

END_IF;


//开机时初始化

IF "FirstScan" THEN

    #抽奖次数 := 99;

    #中奖名 := 101;

    "确认_JP" := 1;

    "复位提示" := 1;

END_IF;



正在下载,请等待……
下载附件需5积分!



楼主最近还看过



silky_56

  • 精华:0帖
  • 求助:0帖
  • 帖子:2帖 | 1828回
  • 年度积分:0
  • 历史总积分:66
  • 注册:2003年8月15日
发表于:2022-10-20 13:06:43
41楼

感谢楼主的分享

Q458751110

  • 精华:0帖
  • 求助:1帖
  • 帖子:53帖 | 865回
  • 年度积分:402
  • 历史总积分:4088
  • 注册:2006年4月04日
发表于:2023-01-02 22:02:57
42楼

不错哦。感谢分享

JUSTIN@

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 316回
  • 年度积分:82
  • 历史总积分:343
  • 注册:2022年11月19日
发表于:2023-01-04 22:22:19
43楼

好资料,感谢楼主分享了。

mark123321

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 5回
  • 年度积分:824
  • 历史总积分:1194
  • 注册:2022年5月27日
发表于:2023-02-08 15:58:29
44楼
太牛了

haihuan23

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 47回
  • 年度积分:63
  • 历史总积分:65
  • 注册:2022年12月26日
发表于:2023-03-26 22:15:51
45楼

多谢楼主分享!!112

张歌

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 44回
  • 年度积分:122
  • 历史总积分:127
  • 注册:2014年12月19日
发表于:2023-04-16 21:46:53
46楼

太牛了大神!

wangoo1

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 558回
  • 年度积分:0
  • 历史总积分:49
  • 注册:2009年2月25日
发表于:2023-05-03 20:02:23
47楼

学习了,感谢大神!

xiangyahg

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 2回
  • 年度积分:0
  • 历史总积分:60
  • 注册:2020年11月16日
发表于:2023-06-19 07:00:21
48楼

抽奖人数上限,可修改成999吗,1000人的

xiangyahg

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 2回
  • 年度积分:0
  • 历史总积分:60
  • 注册:2020年11月16日
发表于:2023-06-19 07:02:44
49楼

上限99不太够,可修改多一点吗?

tongok

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 93回
  • 年度积分:56
  • 历史总积分:114
  • 注册:2022年2月10日
发表于:2023-06-29 10:34:46
50楼

厉害。。。。

puxianqiang

  • 精华:0帖
  • 求助:0帖
  • 帖子:4帖 | 71回
  • 年度积分:239
  • 历史总积分:301
  • 注册:2022年8月11日
发表于:2023-06-29 18:30:16
51楼

1、2013最新整理eplan部件库


介绍:每个品牌系列都是可以单独导入的,需要用时才导入以免太大被卡死现象


https://item.taobao.com/item.htm?ft=t&id=714364562044


2、西门子博途 博图plc案例程序s7 200smart 300 1200 1500编程实例工程 最全


https://item.taobao.com/item.htm?spm=a213gs.success.result.1.18407a86KyfmZJ&id=717575723845


只是学电的

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 23回
  • 年度积分:1
  • 历史总积分:39
  • 注册:2015年5月18日
发表于:2023-12-03 19:10:53
52楼

感谢大神分享

puxianqiang

  • 精华:0帖
  • 求助:0帖
  • 帖子:2帖 | 116回
  • 年度积分:278
  • 历史总积分:340
  • 注册:2022年8月11日
发表于:2024-01-01 21:45:17
53楼

eplan部件库,全网最全最新整理(型号全部都分类很清晰,全部都是由本来精心整理)


介绍:每个品牌系列都是可以单独导入的,需要用时才导入以免太大被卡死现象


https://item.taobao.com/item.htm?ft=t&id=714364562044




西门子博途标准模板程序,都是干货懂的来

1、S7-1200/1500工程常用FB块与FC块学习程序整理封装好的块,功能块合集版,让你快速调用实现功能,节约时间,少走弯路

2、单台块内可设间歇时间,一用一备块内有故障自动切换、时间比较最短先启、设定时间自动互切等

https://item.taobao.com/item.htm?spm=a1z10.3-c.w4002-24706589253.21.13c164e5B4gJ6R&id=759671960606


lihua45637

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 7回
  • 年度积分:0
  • 历史总积分:0
  • 注册:1900年1月01日
发表于:2024-03-08 14:21:00
54楼

谢谢分享,努力学习中

桁灏

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 22回
  • 年度积分:125
  • 历史总积分:136
  • 注册:2008年7月09日
发表于:2024-03-12 15:19:18
55楼

大神厉害啊

Cheart

  • 精华:0帖
  • 求助:1帖
  • 帖子:1帖 | 306回
  • 年度积分:42
  • 历史总积分:781
  • 注册:2020年9月02日
发表于:2024-04-26 08:41:03
56楼

感谢楼主分享经验

Cheart

  • 精华:0帖
  • 求助:1帖
  • 帖子:1帖 | 515回
  • 年度积分:190
  • 历史总积分:1029
  • 注册:2020年9月02日
发表于:2024-04-27 08:42:19
57楼

这个挺齐全的,谢谢分享学习

狗鱼

  • 精华:0帖
  • 求助:0帖
  • 帖子:0帖 | 6回
  • 年度积分:86
  • 历史总积分:86
  • 注册:2024年5月11日
发表于:2024-05-11 09:55:49
58楼

感谢大神分享


热门招聘
相关主题

官方公众号

智造工程师
    首页 上一页 1 2 3 下一页 尾页