Jquery会议室布局含门入口和投影位置调整,并自动截图

news2025/1/12 0:57:42

一、关于下载

1、文章中罗列了主要代码,如需使用,请前往CSDN下载进行下载,包中包含所有文件素材,开箱即用

2、下载链接:https://download.csdn.net/download/zlxls/88305636

二、有这么一个需求

1、会场进行布局,需要设置布局包含的座位,桌子,设置在指定的位置,按照领导席位进行排布。
2、桌子可能时U型(四个开口方向)、圆形、方形。
3、根据每个座位序号设置水牌。
4、保存为图片,方便直接打印,图片为base64,可在服务端进行转储。
5、功能包括:新增位置、去除/恢复编辑样式、门入口设置、投影设置、显示/隐藏水牌、保存数据(数据保存时进行截图,截图格式为去除编辑样式后的截图)。
6、保存数据时,会将所有数据打包为json进行打印。
7、修改时,传入初始化数据,会进行数据初始化。
8、包中包含所有文件素材,开箱即用。
9、文件包含一个index.html文件,为主文件。
10、index-base.html文件为原始拖动插件。
11、其他js、css等用到的插件已经全部打包,没有文件遗漏。
12、本插件全部使用js+Jquery进行编写,代码没有进行紧密封装,可以根据自己需要进行修改和封装,中间使用到的jquery选择器比较多,但是主要功能操作都进行了注释,方便读者了解编写时的逻辑,方便进行二次开发和修改。
12、如有疑问可联系作者,欢迎指出bug和不足之处,以便完善内容。

三、实现的效果图如下

四、主要逻辑代码

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>会议室布局</title>
    <link rel="stylesheet" type="text/css" href="css/bootstrap.css">
    <link rel="stylesheet" type="text/css" href="css/font-awesome.min.css"/>
    <link rel="stylesheet" type="text/css" href="css/default.css">
    <link rel="stylesheet" type="text/css" href="css/gridstack.css"/>
    <!--[if IE]>
    <script src="js/html5.min.js"></script>
    <![endif]-->
</head>
<body class="bgcolor-3">
<div class="jq22-container">
    <div class="jq22-content">
        <div class="container-top">
            <div class="btns">
                <div data-bind="click: add_new_widget" class="btn btn-primary">+ 新增一个位置(上限 <span class="add-span">0</span> 当前 <span class="add-span">0</span>)</div>
                <div onclick="clear_style(this);" class="btn btn-warning clear_style">去除编辑样式</div>
                <div class="btn btn-default">门入口设置:</div>
                <div class="btn btn-success door-op" data-type="0" data-index="0">上边</div>
                <div class="btn btn-success door-op" data-type="1" data-index="0">右边</div>
                <div class="btn btn-success door-op" data-type="2" data-index="0">下边</div>
                <div class="btn btn-success door-op" data-type="3" data-index="0">左边</div>
                <div class="btn btn-danger door-op" data-type="4" data-index="0">左移</div>
                <div class="btn btn-danger door-op" data-type="5" data-index="0">右移</div>
                <div class="btn btn-default">投影设置:</div>
                <div class="btn btn-success door-op" data-type="0" data-index="1">上边</div>
                <div class="btn btn-success door-op" data-type="1" data-index="1">右边</div>
                <div class="btn btn-success door-op" data-type="2" data-index="1">下边</div>
                <div class="btn btn-success door-op" data-type="3" data-index="1">左边</div>
                <div class="btn btn-danger door-op" data-type="4" data-index="1">左移</div>
                <div class="btn btn-danger door-op" data-type="5" data-index="1">右移</div>
				<div onclick="submitHandler();" class="btn btn-success" style="float: right;">保存数据</div>
                <div onclick="names_style(this);" class="btn btn-primary" style="float: right;">隐藏水牌</div>
            </div>
            <p class="tips" style="">请根据会场进行布局,位置按钮可以拖拽放大缩小,上下位置,不能有空位,可使用隐藏功能占位</p>
        </div>
        <div id="container-data">
            <div class="names"></div>
            <div class="container-fluid" style="padding: 15px;">
                <div data-bind="component: {name: 'dashboard-grid', params: $data}" class="template-base"></div>
                <div class="door-ty door"><img src="img/door.png"></div>
                <div class="door-ty ty"><img src="img/ty.png"></div>
            </div>
        </div>
    </div>
</div>
<input name="id" type="hidden" value="">
<input name="type" type="hidden" value="">
<script src="js/jquery.min.js"></script>
<script src="js/jquery-ui.min.js"></script>
<script src="js/bootstrap.min.js"></script>
<script src="js/lodash.min.js"></script>
<script src="js/knockout-min.js"></script>
<script src="js/gridstack.js"></script>
<script src="js/html2canvas.min.js"></script>
<script src="layer/layer.min.js"></script>
<script type="text/javascript">
    //数据
    //格式:[{x: 0, y: 0, width: 1, height: 1, input: '姓名1', hide: '隐藏', class: '',rate:0}];
    var json = "";
    //数量
    var roomIdNum = "60";
    roomIdNum = parseInt(roomIdNum);
	$(".add-span").html(roomIdNum);
    //虚拟对齐显示数量,用来美化页面
    var roomIdNumYushu = roomIdNum % 10;
    var roomIdNumShow = roomIdNum+(roomIdNumYushu>0?(10-roomIdNumYushu):0);
    //操作类型
    var type = "0";
    //门、投影的位置
    //格式:[{"t":"bottom","t1":"0","l":"left","l1":"50"},{"t":"top","t1":"0","l":"left","l1":"50"}]
    //下标0为门位置1为投影位置
    var doors = "";
    //水牌
    //格式:['张三','李四']
    var names = "";
    //初始化组件相关参数
    ko.components.register('dashboard-grid', {
        viewModel: {
            createViewModel: function (controller, componentInfo) {
                var ViewModel = function (controller, componentInfo) {
                    var grid = null;
                    this.widgets = controller.widgets;
                    this.afterAddWidget = function (items) {
                        if (grid == null) {
                            grid = $(componentInfo.element).find('.grid-stack').gridstack({
                                auto: false
                            }).data('gridstack');
                        }
                        var item = _.find(items, function (i) { return i.nodeType == 1 });
                        grid.add_widget(item);
                        ko.utils.domNodeDisposal.addDisposeCallback(item, function () {
                            grid.remove_widget(item);
                        });
                    };
                };
                return new ViewModel(controller, componentInfo);
            }
        },
        template:
            [
                '<div class="grid-stack" data-bind="foreach: {data: widgets, afterRender: afterAddWidget}">',
                '   <div class="grid-stack-item" data-bind="attr: {\'data-input\': $data.input,\'data-class\': $data.class,\'data-hide\': $data.hide,\'data-rate\': $data.rate,\'data-gs-x\': $data.x, \'data-gs-y\': $data.y, \'data-gs-width\': $data.width, \'data-gs-height\': $data.height, \'data-gs-auto-position\': $data.auto_position}">',
                '       <div class="grid-stack-item-content">' +
                '           <input placeholder="未填写序号或名称">' +
                '           <span class="grid-style-span">' +
                '               <span data-type="0">☐型</span>' +
                '               <span data-type="1">u型</span>' +
                '               <span data-type="2">⊂型</span>' +
                '               <span data-type="3">∩型</span>' +
                '               <span data-type="4">⊃型</span>' +
                '               <span data-type="5">○型</span>' +
                '           </span>' +
                '           <span class="opacity-span"></span>' +
                '       </div>' +
                '       <button class="grid-stack-item-close" data-bind="click: $root.delete_widget"></button>',
                '   </div>',
                '</div> '
            ].join('')
    });
    $(function () {
        //模块形状点击事件
        $(".template-base").on('click','.grid-style-span span',function(){
            $(this).parent().parent().removeClass("grid-style-0").removeClass("grid-style-1").removeClass("grid-style-2").removeClass("grid-style-3").removeClass("grid-style-4").removeClass("grid-style-5").addClass("grid-style-"+$(this).data("type"));
        });
        //显示或隐藏组件
        $(".template-base").on('click','.opacity-span',function(){
            if($(this).parent().hasClass("active")){
                $(this).parent().find(".grid-style-span").show();
                $(this).parent().find("input").removeClass("input-show");
                $(this).parent().removeClass("active");
                $(this).html("隐藏");
            }else{
                $(this).parent().find(".grid-style-span").hide();
                $(this).parent().find("input").addClass("input-show");
                $(this).parent().addClass("active");
                $(this).html("显示");
            }
            getCount();
        });
        //初始化组件相关事件
        var Controller = function (widgets) {
            var self = this;
            this.widgets = ko.observableArray(widgets);
            //新增一个组件
            this.add_new_widget = function () {
                this.widgets.push({x: 0, y: 0, width: 1, height: 1, input:'', hide:'隐藏', rate:0, class:'', auto_position: true});
                getCount();
            };
            //删除一个组件
            this.delete_widget = function (item) {
                self.widgets.remove(item);
                getCount();
            };
        };
        //初始数据初始化
        var widgets = [];
        if(json) {
            widgets = JSON.parse(json);
            //计算个数
            $(".add-span").eq(1).html(json.match(new RegExp(/\隐藏/g)).length);
        }
        var controller = new Controller(widgets);
        ko.applyBindings(controller);
        //门、投影的位置点击事件
        setDoorOpClick();
        //门、投影的位置 初始化
        //延时加载,不然获取的宽度不是数据初始化的宽度
        setTimeout(function () {
            initDoorOp();
        },500);
        //水牌 初始化
        initNames();
    });

    /**
     * 数据提交
     */
    function submitHandler() {
        var serialized_data = _.map($('.grid-stack > .grid-stack-item:visible'), function (el) {
            el = $(el);
            var node = el.data('_gridstack_node');
            return {x : node.x, y : node.y, width : node.width, height : node.height, input : el.find("input").val(), hide : el.find(".opacity-span").html(), rate : getRateFlag(el), class : el.find(".grid-stack-item-content").hasClass("active")?'active':'',};
        }, this);
        if(serialized_data.length<1){
            layer.alert("请完善布局再提交");
            return false;
        }
        var count = serialized_data.length - $('.grid-stack > .grid-stack-item:visible > .active').length;
        if(count>roomIdNum){
            layer.alert("该会场容纳人数最多为"+roomIdNum+",当前布局"+count);
            return false;
        }
        names = [];
        $("[name='names[]']").each(function () {
            names.push($(this).val());
        });
        var _data = {
            json : JSON.stringify(serialized_data),
            doors : JSON.stringify(doors),
            names : JSON.stringify(names),
            type : $("[name='type']").val(),
            id : $("[name='id']").val()
        };
        //begin截图时要处理的问题
        //1、如果是编辑样式,则去除
        var clear_style_flag = 0;
        if(!$(".template-base").hasClass("template-base-style")){
            clear_style(".clear_style");
            clear_style_flag = 1;
        }
        //2、输入框的背景颜色去除
        $(".input-show").css("background","unset");
        //3、输入框截图存在错位,需要动态替换为div标签显示
        $(".names-name").each(function () {
            $(this).find("div").html($(this).find("input").val());
            $(this).find("input").hide();
            $(this).find("div").show();
        });
        //end
        html2canvas(document.getElementById("container-data")).then(function(canvas) {
            //begin截图后进行数据恢复
            //1、如果去除了编辑样式,则恢复
            if(clear_style_flag == 1){
                clear_style(".clear_style");
            }
            //2、输入框的背景颜色恢复
            $(".input-show").css("background","#18bc9c");
            //3、动态恢复为input标签显示
            $(".names-name").each(function () {
                $(this).find("input").show();
                $(this).find("div").hide();
            });
            //end
            _data.img = canvas.toDataURL("image/png");
			console.info(_data);
			return false;
            $.ajax({
                url: "http://localhost:8183/layout/editData",
                type: "post",
                dataType: "json",
                data:_data,
                success: function(result) {
                    layer.alert(result.msg);
                }
            });
        });
    }

    /**
     * 计算组件个数
     */
    function getCount() {
        var _count = $('.grid-stack > .grid-stack-item:visible').length - $('.grid-stack > .grid-stack-item:visible > .active').length;
        $(".add-span").eq(1).html(_count);
    }

    /**
     * 清楚组件编辑样式
     */
    function clear_style(_this) {
        if($(".template-base").hasClass("template-base-style")){
            $(".template-base").removeClass("template-base-style");
            $(_this).html("去除编辑样式");
            $(".grid-stack-item-content input").attr("placeholder","未填写序号或名称");
            $(".names-name input").attr("placeholder","请输入姓名");
        }else{
            $(".template-base").addClass("template-base-style");
            $(_this).html("恢复编辑样式");
            $("input").removeAttr("placeholder");
        }
    }

    /**
     * 水牌名称编辑样式
     */
    function names_style(_this) {
        if($(_this).html()=='隐藏水牌'){
            $(".names").hide();
            $(_this).html("显示水牌");
        }else{
            $(".names").show();
            $(_this).html("隐藏水牌");
        }
    }

    /**
     * 获取形状编号
     * @param el
     * @returns {number}
     */
    function getRateFlag(el) {
        if(el.find(".grid-stack-item-content").hasClass("grid-style-1")){return 1;
        }else if(el.find(".grid-stack-item-content").hasClass("grid-style-2")){return 2;
        }else if(el.find(".grid-stack-item-content").hasClass("grid-style-3")){return 3;
        }else if(el.find(".grid-stack-item-content").hasClass("grid-style-4")){return 4;
        }else if(el.find(".grid-stack-item-content").hasClass("grid-style-5")){return 5;
        }else{return 0;}
    }

    /**
     * 门和投影点击事件
     */
    function setDoorOpClick() {
        $(".door-op").on('click',function(){
            var numOne = 5;
            var type = parseInt($(this).data("type"));
            var index = parseInt($(this).data("index"));
            var indexBegin = getDoorOpIndexBegin(index);
            switch (type) {
                case 0:doors[index].t = "top";     doors[index].t1 = "0"; doors[index].l = "left";   doors[index].l1 = "50";break;//上
                case 1:doors[index].t = "right";   doors[index].t1 = "0"; doors[index].l = "top";    doors[index].l1 = "50";break;//右
                case 2:doors[index].t = "bottom";  doors[index].t1 = "0"; doors[index].l = "left";   doors[index].l1 = "50";break;//下
                case 3:doors[index].t = "left";    doors[index].t1 = "0"; doors[index].l = "top";    doors[index].l1 = "50";break;//左
                case 4://左移 上移
                    var _val = parseInt(doors[index].l1)-numOne;
                    doors[index].l1 = _val<=0?0:_val;
                    break;
                default://右移 下移
                    var _val = parseInt(doors[index].l1)+numOne;
                    doors[index].l1 = _val>=100?100:_val;
                    break;
            }
            setDoorOpStyle();
        });
    }

    /**
     * 门和投影移动方向
     */
    function setDoorOpStyle() {
        setDoorOp(0);
        setDoorOp(1);
        //获取当前方向标签的长度或者高度
        var max0 = getDoorOpStyleMax(0);
        var max1 = getDoorOpStyleMax(1);
        //计算当前比例下的实际定位长度或者高度
        var aspect0 = (max0/100)*parseInt(doors[0].l1);
        var aspect1 = (max1/100)*parseInt(doors[1].l1);
        //当前定位方向
        var position0 = doors[0].l;
        var position1 = doors[1].l;
        //如果为左侧定位&&定位数值为100%时,换为右侧定位&&数值为0%
        if(doors[0].l=='left' && parseFloat(doors[0].l1)==100){
            aspect0 = 0;
            position0 = 'right';
        }
        if(doors[1].l=='left' && parseFloat(doors[1].l1)==100){
            aspect1 = 0;
            position1 = 'right';
        }
        $(".door").css("top","unset").css("left","unset").css("right","unset").css("bottom","unset").css(doors[0].t,doors[0].t1+"px").css(position0,aspect0+"px");
        $(".ty"  ).css("top","unset").css("left","unset").css("right","unset").css("bottom","unset").css(doors[1].t,doors[1].t1+"px").css(position1,aspect1+"px");
    }

    /**
     * 门和投影选择器
     * @param _index
     * @returns {number}
     */
    function getDoorOpIndexBegin(_index){
        return 6*(_index+1);
    }

    /**
     * 门和投影写入操作
     * @param _index
     */
    function setDoorOp(_index){
        if(doors[_index].t == "top"||doors[_index].t == "bottom"){
            $(".door-op").eq(getDoorOpIndexBegin(_index)-2).html("左移");$(".door-op").eq(getDoorOpIndexBegin(_index)-1).html("右移");
        }else{
            $(".door-op").eq(getDoorOpIndexBegin(_index)-2).html("上移");$(".door-op").eq(getDoorOpIndexBegin(_index)-1).html("下移");
        }
    }

    /**
     * 门和投影获取实际长了宽
     * @param _index
     * @returns {jQuery}
     */
    function getDoorOpStyleMax(_index) {
        if(doors[_index].t == "top"||doors[_index].t == "bottom"){
            return $(".container-fluid").width();
        }else{
            return $(".container-fluid").height();
        }
    }

    /**
     * 门、投影的位置 初始化
     */
    function initDoorOp(){
        if(doors && $.isArray(JSON.parse(doors))) {
            doors = JSON.parse(doors);
        }else{
            doors = [{"t":"bottom","t1":"0","l":"left","l1":"50"},{"t":"top","t1":"0","l":"left","l1":"50"}];
        }
        setDoorOpStyle();
    }

    /**
     * 水牌 初始化
     * 由于容纳人数roomIdNum是动态的,
     * 这里需要动态处理已有的水牌数据,
     * 例如原本容纳人数为20人,修改时可能变成15人或者25人,
     * 要以实际能容纳的人数为基准。
     */
    function initNames(){
        var _names = names?JSON.parse(names):[];
        names = [];
        for (var i=0;i<roomIdNumShow;i++){
            names.push(_names.length>i?_names[i]:"");
        }
        setNames();
    }

    /**
     * 水牌名称设置
     */
    function setNames() {
        var html = "";
        for (var i=0;i<names.length;i++){
            if(i<roomIdNum){
                html+='<div class="names-row"><div class="names-index">'+(i+1)+'</div><div class="names-name"><div style="display: none;"></div><input name="names[]" value="'+names[i]+'" placeholder="请输入姓名"></div></div>';
            }else{
                //补齐一排的样式,必然比较难看
                html+='<div class="names-row"><div class="names-index"></div><div class="names-name"></div></div>';
            }
        }
        $(".names").html(html);
    }
</script>
</body>
</html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/984385.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

行业追踪,2023-09-07

自动复盘 2023-09-07 凡所有相&#xff0c;皆是虚妄。若见诸相非相&#xff0c;即见如来。 k 线图是最好的老师&#xff0c;每天持续发布板块的rps排名&#xff0c;追踪板块&#xff0c;板块来开仓&#xff0c;板块去清仓&#xff0c;丢弃自以为是的想法&#xff0c;板块去留让…

Android手机防沉迷软件的基本原理

(现在手机游戏、短视频等不仅对小孩子负面影响巨大&#xff0c;连很多成年人都沉迷其中难以自拔&#xff0c;影响工作、生活、学习。这已经造成全社会性的巨大影响&#xff0c;长此以往&#xff0c;国将不国。本人仅在此以自己掌握的些许技术略尽绵薄之力&#xff0c;希望能抛砖…

基于SpringBoot的社团管理系统

基于SpringBootVue的社团管理系统&#xff0c;前后端分离 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringBoot、Vue、Mybaits Plus、ELementUI工具&#xff1a;IDEA/Ecilpse、Navicat、Maven 角色&#xff1a;普通用户、管理员 管理员&#xff1a;…

有哪些开源通用流程引擎

有哪些开源通用流程引擎 Activiti&#xff1a;Camunda&#xff1a;Flowable&#xff1a;jBPM&#xff1a;Bonita&#xff1a; 以下是一些常见的开源通用流程引擎&#xff1a; Activiti&#xff1a; Activiti 是一个轻量级的、基于 Java 的 BPM&#xff08;Business Process M…

Git 常用

1.工作区、暂存区、版本库&#xff1a; 工作区&#xff1a;就是电脑上可以看到的目录&#xff1b; 暂存区&#xff1a;英文叫 stage 或 index。一般存放在 .git 目录下的 index 文件&#xff08;.git/index&#xff09;中&#xff0c;所以我们把暂存区有时也叫作索引&#xf…

华为OD机试 - 最多颜色的车辆 - 数据结构map(Java 2022Q4 100分)

目录 专栏导读一、题目描述二、输入描述三、输出描述四、解题思路1、核心思想2、题做多了&#xff0c;你就会发现&#xff0c;这道题属于送分题&#xff0c;为什么这样说&#xff1f;3、具体解题思路&#xff1a; 五、Java算法源码六、效果展示1、输入2、输出 华为OD机试 2023B…

一文读懂骨传导耳机和入耳式耳机哪个对人体伤害小?

先说结论&#xff0c;骨传导耳机和入耳式耳机哪个对人体伤害最小&#xff0c;答案是骨传导耳机对人体的伤害要小一些。 普通的耳机传声原理是直接将声音通过空气振动传递给耳膜&#xff0c;从而听到声音而骨传导的传声原理有所不同&#xff0c;骨传导传递声音是通过振动&#…

功率信号源可以应用在哪些方面

功率信号源是一种能够产生一定功率的信号源&#xff0c;广泛应用于各个领域。下面将介绍功率信号源在电子、通信、工业和科研等方面的应用。 在电子行业中&#xff0c;功率信号源是一种重要的测试工具。它可以产生各种波形的信号&#xff0c;如正弦波、方波、脉冲波等&#xff…

MySQL 8.0安装及配置教程

一、下载mysql 进入官网https://www.mysql.com/&#xff0c;下载最新的的mysql8.0版本&#xff0c;该版本新增了许多特性。 进入下载页面&#xff0c;可以选择企业版本和社区版本&#xff0c;一般选择社区免费下载。 二、安装mysql&#xff08;此方法默认安装至C盘&#xff0c…

echarts环图配置

echarts环图配置 1、安装echarts npm install echarts4.9.02、页面引入echarts import echarts from echarts;3、应用 template片段 <div class"chart-wrap"><div id "treeChart" style "width: 180px; height:180px;" ><…

实现Map批量赋值,我只需24秒搞定!

函数的功能是将一组键值对批量赋值给Map中的键。在Java中&#xff0c;通常使用Map的put方法逐个将键值对赋值给Map&#xff0c;但在某些场景下&#xff0c;可能需要一次性将多个键值对赋值给Map。 函数功能&#xff1a;Map批量赋值 参数1&#xff1a;参数名称&#xff1a;targ…

VR全景广告——实体商家的营销新选择

前几年&#xff0c;大家出行不便&#xff0c;那个时候实体商家整天苦恼于没有客户&#xff0c;没有销量&#xff0c;一直到引入VR全景广告才算是有所好转。随着VR全景技术不断完善&#xff0c;许多行业、领域开始结合VR全景&#xff0c;例如景区、房地产、车企等都会利用VR全景…

如何防止僵尸 API...

人们越来越依赖Web API。2023 年 Postman API 状况报告发现&#xff0c;整整 92% 的组织计划在明年增加对 API 的投资。API 正在为从内部微服务策略到合作伙伴策略和成熟产品的一切提供动力。 然而&#xff0c;这种新发现的API 蔓延带来了后果&#xff1b;迫在眉睫的威胁可能会…

CSS:屏幕正中间有个元素A,元素A中有文字A,随着屏幕宽度的增加

始终需要满足以下条件&#xff1a; A元素垂直居中于屏幕***&#xff1b;A元素距离屏幕左右边距各10px&#xff1b;A元素里面的文字”A”的font-size:20px&#xff1b;水平垂直居中;A元素的高度始终是A元素宽度的50%; (如果搞不定可以实现为A元素的高度固定为200px;)请用 html及…

【产线故障】线上接口请求过慢如何排查?

文章目录 前言一、内存使用过高导致CPU满载案例代码分析思路 二、出现了类似死循环导致cpu负载案例代码分析思路 三、死锁案例代码分析思路 前言 首先线上接口变慢&#xff0c;原因可能有很多&#xff0c;有可能是网络&#xff0c;有可能是慢 SQL&#xff0c;有可能是服务本身…

3种轻量化框架总结

一般的卷积神经网络的参数量和计算量都很大&#xff0c;很难应用在资源有限的场景中。为了解决这个问题&#xff0c;通常是在训练好的模型上进行优化&#xff0c;如通过对模型压缩减少计算量和存储成本&#xff0c;也可以通过剪枝连接方法去掉了不重要的神经元连接或者通道修剪…

SecureCRT9.1高亮配色设置

参考:http://zh-cjh.com/qita/1623.html https://download.csdn.net/download/qq_45698138/88310255?spm1001.2014.3001.5503 1.创建文件colorful-network.ini,添加如下内容 D:"Match Case"00000000 D:"Regex Line Mode"00000000 Z:"Keyword Lis…

C语言学习:6、C语言程序的循环结构

生活中&#xff0c;有很多循环的东西&#xff0c;比如钟表就是在1到12循环&#xff0c;太阳东升西落也是循环&#xff0c;春夏秋冬也是循环&#xff0c;人生可能也是一个循环。 while C语言中的循环可以这么描述&#xff1a;当某个条件成立&#xff0c;就一直做某件事或某些事…

微信小程序开发---基本组件的使用

目录 一、scroll-view &#xff08;1&#xff09;作用 &#xff08;2&#xff09;用法 二、swiper和swiper-item &#xff08;1&#xff09;作用 &#xff08;2&#xff09;用法 三、text &#xff08;1&#xff09;作用 &#xff08;2&#xff09;使用 四、rich-tex…

煤矿虚拟仿真 | 采煤工人VR虚拟现实培训系统

随着科技的发展&#xff0c;虚拟现实(VR)技术已经逐渐渗透到各个行业&#xff0c;其中包括煤矿行业。VR技术可以为煤矿工人提供一个安全、真实的环境&#xff0c;让他们在虚拟环境中进行实际操作和培训&#xff0c;从而提高他们的技能水平和安全意识。 由广州华锐互动开发的采煤…