asp.net+jQueryRotate开发幸运大转盘

简介: 在线抽奖程序在很多网站上很多,抽奖形式多种多样,Flash抽奖偏多,本文将给大家介绍jQuery转盘抽奖,结合代码实例将使用jQuery和asp.net来实现转盘抽奖程序,为了便于理解,文章贴出实现源代码作为分享。

在线抽奖程序在很多网站上很多,抽奖形式多种多样,Flash抽奖偏多,本文将给大家介绍jQuery转盘抽奖,结合代码实例将使用jQuery和asp.net来实现转盘抽奖程序,为了便于理解,文章贴出实现源代码作为分享。通过转动转盘指针来完成抽奖的一种抽奖形式,根据旋转角度来控制指针停留的位置——幸运大转盘。

1、先来张幸运大抽奖效果图


2、Default.aspx页面代码

<!-- 
更多技术分享请看博客:http://blog.csdn.net/fuyifang 
-->  
<span style="font-family:Microsoft YaHei;font-size:14px;"><%@ Page Language="C#" AutoEventWireup="true"  CodeFile="Default.aspx.cs" Inherits="_Default" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
    <meta content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0" name="viewport">
<meta content="yes" name="apple-mobile-web-app-capable">
    <title>幸运大转盘</title>

    <style type="text/css">
     .demo{ position:relative;}
    #disk{ position:relative; z-index:1;}
    #start{ position:absolute; top:-0; z-index:9;}
    #start img{cursor:pointer; border:none;}
    </style>
    <script src="Scripts/jquery-1.7.1.min.js"  type="text/javascript"></script>
    <script src="Scripts/jQueryRotate.2.1.js" type="text/javascript"></script>
    <script type="text/javascript">
        $(function () {
            $("#startbtn").click(function () {
                lottery();
            });
        });
        function lottery() {
            $.ajax({
                type: 'POST',
                url: 'data.aspx',
                dataType: 'json',
                cache: false,
                error: function () {
                    alert('出错了!');
                    return false;
                },
                success: function (json) {
                    $("#startbtn").unbind('click').css("cursor", "default");
                    var a = json.angle; //角度 
                    var p = json.prize; //奖项 
                    $("#startbtn").rotate({
                        duration: 8000, //转动时间 
                        angle: 0,
                        animateTo: 2880+ a, //转动角度 
                        easing: $.easing.easeOutSine,
                        callback: function () {
                            var con = confirm('恭喜你,中得' + p + '\n还要再来一次吗?');
                            if (con) {
                                lottery();
                            } else {
                                $("#startbtn").click(function () {
                                    lottery();
                                }).css("cursor", "pointer");
                                return false;
                            }
                        }
                    });
                }
            });
        }
    </script>


</head>
<body>
    <form id="form1" runat="server">
   <div>
        <div class="demo">
            <div id="disk"><img src="img/disk.jpg" width="100%" style="max-width:640px;"/></div>
            <div id="start"><a href="###"><img src="img/start.png" id="startbtn" width="100%" style="max-width:640px;"/></a></div>
       </div>

    </div>

    </form>
</body>
</html>
 </span>
<!-- 
更多技术分享请看博客:http://blog.csdn.net/fuyifang 
-->  

我们构建自定义函数lottery(),在lottery()我们向data.php发送一个POST请求,如果成功返回中奖信息后,调用rotate插件开始转动,转动角度由后台返回的角度决定,这里我们用2880+a表示转动的角度,即指针转动8圈+a度后停止,然后我们在单击“开始抽奖”按钮时调用lottery(),于是转盘抽奖就完成。

3、data.aspx中奖逻辑代码

<!-- 
更多技术分享请看博客:http://blog.csdn.net/fuyifang 
-->  
<span style="font-family:Microsoft YaHei;font-size:14px;">using System;
using System.Collections;
using System.Collections.Generic;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;

public partial class data : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        Hashtable ht = new Hashtable();
        Hashtable p1 = new Hashtable();
        p1.Add("id", 1);
        p1.Add("min", 1);
        p1.Add("max", 59);
        p1.Add("prize", "500积分");
        p1.Add("v", 1);
        ht.Add(0, p1);

        Hashtable p2 = new Hashtable();
        p2.Add("id", 2);
        p2.Add("min", 60);
        p2.Add("max", 119);
        p2.Add("prize", "100积分");
        p2.Add("v", 5);
        ht.Add(1, p2);

        Hashtable p3 = new Hashtable();
        p3.Add("id", 3);
        p3.Add("min", 121);
        p3.Add("max", 179);
        p3.Add("prize", "10元商品");
        p3.Add("v", 5);
        ht.Add(2, p3);

        Hashtable p4 = new Hashtable();
        p4.Add("id", 4);
        p4.Add("min", 180);
        p4.Add("max", 240);
        p4.Add("prize", "500积分");
        p4.Add("v", 10);
        ht.Add(3, p4);

        Hashtable p5 = new Hashtable();
        p5.Add("id", 5);
        p5.Add("min", 240);
        p5.Add("max", 300);
        p5.Add("prize", "谢谢参与");
        p5.Add("v", 80);
        ht.Add(4, p5);

        Hashtable p6 = new Hashtable();
        p6.Add("id", 6);
        p6.Add("min", 300);
        p6.Add("max", 360);
        p6.Add("prize", "订单免单");
        p6.Add("v", 1);
        ht.Add(5, p6);

        //Hashtable p7 = new Hashtable();
        //p7.Add("id", 7);
        //p7.Add("min", new int[6] { 32, 92, 152, 212, 272, 332 });
        //p7.Add("max", new int[6] { 58, 118, 178, 238, 298, 358 });
        //p7.Add("prize", "谢谢参与");
        //p7.Add("v", 50);
        //ht.Add(6, p7);

        //Console.WriteLine(ht[0]);
        int htlength = ht.Count;
        int[] proArr = new int[htlength]; 
        foreach(DictionaryEntry single in ht)
        {
            Hashtable subObj = single.Value as Hashtable;
            proArr[(int)single.Key] = (int)subObj["v"];
        }

        int rid = this.getRand(proArr);
        int jiaodu = 0;
        string prize = null;
        Hashtable res = ht[rid] as Hashtable;
        Random ran = new Random();
        
        if ((int)res["id"] == 7)
        {
            int[] mins = (int[])res["min"];
            int[] maxs = (int[])res["max"];
            int i = ran.Next(0, 5);
            jiaodu = ran.Next(mins[i], maxs[i]);
        }
        else
        {
            int mins = (int)res["min"];
            int maxs = (int)res["max"];
            jiaodu = ran.Next(mins, maxs);
        }
        
        prize = res["prize"].ToString();



        string json = "{\"angle\":" + jiaodu.ToString() + ",\"prize\":\"" + prize + "\"}";
        Response.Write(json);
        //Dictionary<string, Dictionary<string,string>> dt = new Dictionary<string, Dictionary<string,string>>();
    }

    public int getRand(int[] proArr) 
    {
        int result = -1;
        int proSum = 0;
        foreach(int val in proArr)
        {
            proSum += val;
        }
        int length = proArr.Length;
        for (int i = 0; i < length; i++)
        { 
            Random ran = new Random();
            int ranNum = ran.Next(1, proSum);
            if (ranNum <= proArr[i])
            {
                result = i;
                break;
            }
            else 
            {
                proSum -= proArr[i];
            }
        }
        return result;
    }


}</span>
<!-- 
更多技术分享请看博客:http://blog.csdn.net/fuyifang 
-->  

V参数代表百分比,默认为100,V月大代表该奖项中奖率越高,越小中奖率越小。


更多关注付义方技术博客:http://blog.csdn.net/fuyifang


目录
相关文章
|
11天前
|
开发框架 算法 Java
.NET 开发:实现高效能的秘诀
【7月更文挑战第4天】探索.NET高效开发涉及理解运行时(如GC、JIT)、代码与算法优化及工具利用。关键点包括适应性垃圾回收、异步编程、明智的并发控制;编写高效代码(避免对象创建,选对数据结构和算法);使用性能分析工具,善用高性能框架如ASP.NET Core,并借助云服务和CI/CD流程持续优化。性能优化是持续学习与实践的过程。
22 1
|
1月前
|
开发框架 前端开发 .NET
LIMS(实验室)信息管理系统源码、有哪些应用领域?采用C# ASP.NET dotnet 3.5 开发的一套实验室信息系统源码
集成于VS 2019,EXT.NET前端和ASP.NET后端,搭配MSSQL 2018数据库。系统覆盖样品管理、数据分析、报表和项目管理等实验室全流程。应用广泛,包括生产质检(如石化、制药)、环保监测、试验研究等领域。随着技术发展,现代LIMS还融合了临床、电子实验室笔记本和SaaS等功能,以满足复杂多样的实验室管理需求。
36 3
LIMS(实验室)信息管理系统源码、有哪些应用领域?采用C# ASP.NET dotnet 3.5 开发的一套实验室信息系统源码
|
11天前
|
人工智能 前端开发 Devops
NET技术在现代开发中的影响力日益增强,本文聚焦其核心价值,如多语言支持、强大的Visual Studio工具、丰富的类库和跨平台能力。
【7月更文挑战第4天】**.NET技术在现代开发中的影响力日益增强,本文聚焦其核心价值,如多语言支持、强大的Visual Studio工具、丰富的类库和跨平台能力。实际应用涵盖企业系统、Web、移动和游戏开发,以及云服务。面对性能挑战、容器化、AI集成及跨平台竞争,.NET持续创新,开发者应关注技术趋势,提升技能,并参与社区,共同推进技术发展。**
12 1
|
11天前
|
机器学习/深度学习 人工智能 开发者
.NET 技术:为开发带来新机遇
【7月更文挑战第4天】**.NET技术开启软件开发新篇章,通过跨平台革命(.NET Core, Xamarin, .NET MAUI)、云服务与微服务(Azure, DevOps, Docker)及AI集成(ML.NET, 认知服务, TensorFlow)为开发者创造新机遇。开源社区的繁荣与性能提升使.NET更具竞争力,推动智能应用的创新与发展。开发者需紧跟潮流,利用这些工具和框架构建高效、创新的解决方案。**
9 1
|
1月前
|
开发框架 JavaScript 前端开发
分享7个.NET开源、功能强大的快速开发框架
分享7个.NET开源、功能强大的快速开发框架
|
2月前
|
开发框架 .NET C#
使用C#进行.NET框架开发:深入探索与实战
【5月更文挑战第28天】本文探讨了C#在.NET框架中的应用,展示了其作为强大编程语言的特性,如类型安全、面向对象编程。C#与.NET框架的结合,提供了一站式的开发环境,支持跨平台应用。文中介绍了C#的基础知识,如数据类型、控制结构和面向对象编程,以及.NET的关键技术,包括LINQ、ASP.NET和WPF。通过一个实战案例,展示了如何使用C#和ASP.NET开发Web应用,包括项目创建、数据库设计、模型和控制器编写,以及视图和路由配置。本文旨在揭示C#在.NET开发中的深度和广度,激发开发者探索更多可能性。
|
2月前
|
人工智能 量子技术 C#
【专栏】.NET 开发:开启数字化新时代
【4月更文挑战第29天】.NET开发在数字化新时代中发挥关键作用,借助跨平台能力、高性能和现代编程语言支持,如C#,助力企业实现数字化转型。通过企业级应用开发、移动应用和云计算集成,.NET加速业务流程和提升用户体验。未来,.NET将涉足AI、ML、MR/AR及量子计算,持续推动技术创新和数字化转型。开发者应提升技能,适应高性能需求,把握发展机遇。
|
2月前
|
缓存 监控 算法
【专栏】.NET 开发:实现卓越性能的途径
【4月更文挑战第29天】本文探讨了.NET开发中的性能优化,强调了理解性能问题根源和使用分析工具的重要性。基础优化包括代码优化(如减少计算、避免内存泄漏)、资源管理及选择合适算法。高级策略涉及并行编程、缓存策略、预编译(AOT)和微服务架构。持续性能测试与监控是关键,包括性能测试、监控分析和建立优化反馈循环。开发者应持续学习和实践性能优化,以构建高性能应用。
|
2月前
|
开发框架 .NET C#
【专栏】理解.NET 技术,提升开发水平
【4月更文挑战第29天】本文介绍了.NET技术的核心概念和应用,包括其跨平台能力、性能优化、现代编程语言支持及Web开发等特性。文章强调了深入学习.NET技术、关注社区动态、实践经验及学习现代编程理念对提升开发水平的重要性。通过这些,开发者能更好地利用.NET构建高效、可维护的多平台应用。
|
2月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
114 0