`
huangyongxing310
  • 浏览: 506498 次
  • 性别: Icon_minigender_1
  • 来自: 广州
文章分类
社区版块
存档分类
最新评论

weuiJsLayer.js

 
阅读更多
var weuiJsAlterMap = {};


function addWeuiJsAlter(htmlString,alterId) {
	AddElement('body', htmlString);



	addWeuiJsAlterOtherDeal(alterId);
	// commonJs.commonConsole(weuiJsAlterMap, "addWeuiJsAlter weuiJsAlterMap");
}

function closeWeuiJsAlter(alterId) {
	removeElement("#" + alterId);

	closeWeuiJsAlterOtherDeal(alterId);

	//==========
	delete weuiJsAlterMap[alterId]; //true



	// commonJs.commonConsole(weuiJsAlterMap, "weuiJsAlterMap");
}

function addWeuiJsAlterOtherDeal(alterId) {
	var scrollTopValue = weuiJsAlterGetscrollTopValue(alterId);
	weuiJsAlterMap[alterId].scrollTopValue = scrollTopValue;

	window.document.body.style.overflow='hidden';
	window.document.body.style.top=-1*scrollTopValue+"px";
}


function weuiJsAlterGetscrollTopValue(alterId) {
	var scrollTopValue = window.pageYOffset;
	return scrollTopValue;
}


function closeWeuiJsAlterOtherDeal(alterId) {
	var scrollTopValue = weuiJsAlterMap[alterId].scrollTopValue;

	window.document.body.style.overflow='auto';
	window.document.body.style.position=null;
	window.document.body.style.top=null;
	window.scrollTo(0,scrollTopValue);
}


function getAlterId() {
	var alterId = 'alterId_' + new Date().getTime();


	var alterIdTemp = alterId;

	var count = 0;
	while(1){
		if(weuiJsAlterMap[alterIdTemp]){
			count = count +1;
			alterIdTemp=  alterId + "_" +  count;
		}else{
			return alterIdTemp;
		}
	}
}


//=============================================Alert
var weuiJsAlertTemplate = `
        <div id="{{alterId}}">
            <div class="weui-mask"></div>
            <div class="weui-dialog" :style="{ width:width }">
                <div class="weui-dialog__hd">
                    <div class="weui-dialog__title">{{title}}</div>
                </div>
                <div class="weui-dialog__bd">
                    {{content}}
                </div>
                <div class="weui-dialog__ft">
                    <a onclick="okClickWeuiJsAlterFun('{{alterId}}')" class="weui-dialog__btn weui-dialog__btn_primary">{{confirmButtonText}}</a>
                </div>
            </div>
        </div>
    `;


function openWeuiJsAlter(content, title, fun, confirmButtonText) {
	var temp = weuiJsAlertTemplate;
	var alterId = getAlterId();
	temp = replaceAll(temp, "{{title}}", title);
	temp = replaceAll(temp, "{{content}}", content);
	temp = replaceAll(temp, "{{alterId}}", alterId);
	temp = replaceAll(temp, "{{confirmButtonText}}", confirmButtonText);

	var obj = {
		callBackFun: fun
	};

	weuiJsAlterMap[alterId] = obj;
	// weuiJsAlterMap[alterId].callBackFun=fun;

	addWeuiJsAlter(temp,alterId);

	return alterId;
}

function okClickWeuiJsAlterFun(alterId) {
	commonJs.commonConsole(alterId, "okClickFun alterId");

	var callBackFun = weuiJsAlterMap[alterId]['callBackFun'];
	if (callBackFun) {
		callBackFun('ok');
	}

	closeWeuiJsAlter(alterId);
}



//=============================================confirm
var weuiJsConfirmTemplate = `
        <div id="{{alterId}}">
            <div class="weui-mask"></div>
            <div class="weui-dialog" :style="{ width:width }">
                <div class="weui-dialog__hd">
                    <div class="weui-dialog__title">{{title}}</div>
                </div>
                <div class="weui-dialog__bd">
                    {{content}}
                </div>
                <div class="weui-dialog__ft">
                    <a onclick="cancelClickWeuiJsAlterFun('{{alterId}}')" class="weui-dialog__btn weui-dialog__btn_default">{{cancelButtonText}}</a>
            		<a onclick="okClickWeuiJsAlterFun('{{alterId}}')" class="weui-dialog__btn weui-dialog__btn_primary">{{confirmButtonText}}</a>
                </div>
            </div>
        </div>
    `;


function openWeuiJsConfirm(content, title, fun, confirmButtonText,cancelButtonText) {
	var temp = weuiJsConfirmTemplate;
	var alterId =  getAlterId();
	temp = replaceAll(temp, "{{title}}", title);
	temp = replaceAll(temp, "{{content}}", content);
	temp = replaceAll(temp, "{{alterId}}", alterId);
	temp = replaceAll(temp, "{{confirmButtonText}}", confirmButtonText);
	temp = replaceAll(temp, "{{cancelButtonText}}", cancelButtonText);

	var obj = {
		callBackFun: fun
	};

	weuiJsAlterMap[alterId] = obj;
	// weuiJsAlterMap[alterId].callBackFun=fun;

	addWeuiJsAlter(temp,alterId);

	return alterId;
}

function cancelClickWeuiJsAlterFun(alterId) {
	commonJs.commonConsole(alterId, "okClickFun alterId");

	var callBackFun = weuiJsAlterMap[alterId]['callBackFun'];
	if (callBackFun) {
		callBackFun('no');
	}

	closeWeuiJsAlter(alterId);
}


//=============================================Loading
var weuiJsLoadingTemplate = `
        <div id="{{alterId}}">
			<div class="weui-mask"></div>
			<div class="weui-toast">
				<i class="weui-loading weui-icon_toast"></i>
				<p class="weui-toast__content">{{content}}</p>
			</div>
		</div>
    `;


function openWeuiJsLoading(content) {
	var temp = weuiJsLoadingTemplate;
	var alterId =  getAlterId();
	// temp = replaceAll(temp, "{{title}}", title);
	temp = replaceAll(temp, "{{content}}", content);
	temp = replaceAll(temp, "{{alterId}}", alterId);
	// temp = replaceAll(temp, "{{confirmButtonText}}", confirmButtonText);
	// temp = replaceAll(temp, "{{cancelButtonText}}", cancelButtonText);

	var obj = {
		// callBackFun: fun
	};

	weuiJsAlterMap[alterId] = obj;
	// weuiJsAlterMap[alterId].callBackFun=fun;

	addWeuiJsAlter(temp,alterId);

	return alterId;
}


function closeWeuiJsLoading(index) {
	closeWeuiJsAlter(index)
}


//=============================================Toast
var weuiJsToastTemplate = `
        <div id="{{alterId}}">
			<div class="weui-mask_transparent"></div>
   			<div class="weui-toast">
				<p class="weui-toast__content weui-toast__text">{{content}}</p>
			</div>
		</div>
    `;

function openWeuiJsToast(content, msTime) {
	var temp = weuiJsToastTemplate;
	var alterId = getAlterId();
	// temp = replaceAll(temp, "{{title}}", title);
	temp = replaceAll(temp, "{{content}}", content);
	temp = replaceAll(temp, "{{alterId}}", alterId);
	// temp = replaceAll(temp, "{{confirmButtonText}}", confirmButtonText);
	// temp = replaceAll(temp, "{{cancelButtonText}}", cancelButtonText);

	var obj = {
		// callBackFun: fun
	};

	weuiJsAlterMap[alterId] = obj;
	// weuiJsAlterMap[alterId].callBackFun=fun;

	addWeuiJsAlter(temp,alterId);


	window.setTimeout(function () {
		closeWeuiJsAlter(alterId)
	}, msTime);


	return alterId;

}







分享到:
评论

相关推荐

    毕业设计物联网实战项目基于Eclipse Theia开源框架开发的物联网在线编程IDE.zip

    【项目资源】: 物联网项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    工具变量-全国分省低空经济高质量发展数据(2012-2023年)

    因文件较多,数据存放网盘,txt文件内包含下载链接及提取码,永久有效。失效会第一时间进行补充。样例数据及详细介绍参见文章:https://blog.csdn.net/T0620514/article/details/146960240

    【ThingsBoard初体验】本地编译踩坑记录.html

    【ThingsBoard初体验】本地编译踩坑记录.html

    社团管理系统的设计与实现(代码+数据库+LW)

    摘  要 互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对信息管理混乱,出错率高,信息安全性差,劳动强度大,费时费力等问题,采用社团管理系统可以有效管理,使信息管理能够更加科学和规范。 社团管理系统在Eclipse环境中,使用Java语言进行编码,使用Mysql创建数据表保存本系统产生的数据。系统可以提供信息显示和相应服务,其管理员增删改查社团信息和社团信息资料,审核社团预订信息。总之,社团管理系统集中管理信息,有着保密性强,效率高,存储空间大,成本低等诸多优点。它可以降低信息管理成本,实现信息管理计算机化。 关键词:社团管理系统;Java语言;Mysql

    【传感器技术】HPS700A压力传感器数据手册:特性、应用与接口设计

    内容概要:HPS700A是一款高精度气压传感器,具有1.8V到3.6V的工作电压范围,测量压力范围为0到1600KPa,温度范围为-40℃到85℃。它采用MEMS技术并通过I²C接口提供温度和压力数据,内部集成24位ADC进行数字化处理,并内置补偿算法确保数据准确性。传感器具备低功耗特性,待机电流小于0.1μA。该器件广泛应用于便携式气泵、移动气压计、工业压力温度监测等领域。文档详细描述了HPS700A的功能特性、电气参数、命令集、I²C通信协议及其典型应用。 适合人群:电子工程师、硬件开发者以及对高精度气压传感器感兴趣的科研人员。 使用场景及目标:①用于需要精确测量环境压力和温度的应用场合;②帮助工程师理解并掌握I²C接口的使用方法;③适用于开发小型化、低功耗的产品设计。 其他说明:HPS700A出厂时已进行校准,用户通常无需再做额外校正。此外,该传感器支持多种OSR(过采样率)设置,允许用户根据精度需求选择不同的转换时间和功耗水平。同时,提供了详细的引脚定义、封装信息及批量生产规格,方便产品集成与大规模制造。

    Android毕设实战项目基于Android的新闻推荐系统,本科毕业设计项目。.zip

    【项目资源】: 适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    【车载电源技术】基于TI C2000的车载DC/DC转换器解决方案:硬件设计、智能控制算法及便捷调试工具介绍

    内容概要:本文介绍了一款国内首家推出的车载DC/DC转换器解决方案,旨在解决传统电源方案的诸多痛点并助力车载电源智能化升级。硬件设计方面,采用TI C2000系列主控芯片,搭配进口功率器件和高精度采样电路,提供了高可靠性的电源方案,甚至将输入级EMI滤波部分进行了模块化设计,并给出了不同功率等级下的元器件选型表。软件部分实现了电压环、电流环双闭环控制,采用了动态调整算法,创新地使用DMA搬运PWM占空比参数,降低CPU占用率,同时在输入电压异常时自动切换硬件保护模式。上位机工具提供实时数据显示、参数设置、波形分析等功能,开放了协议栈源码,内置自动标定功能。; 适合人群:从事车载电源开发的工程师,尤其是希望提升产品开发效率和技术水平的专业人士。; 使用场景及目标:①硬件工程师可以借鉴模块化设计思路和详细的元器件选型表,优化电路设计;②软件工程师可以从双闭环控制算法、DMA传输机制等方面学习先进的编程技巧;③调试人员利用上位机工具进行便捷高效的参数调整和故障排查。; 其他说明:该方案不仅提供了完整的技术文档支持,而且开放的软件架构和配套调试工具极大地方便了二次开发,提高了开发效率。建议对车载电源开发感兴趣的工程师获取相关资料深入学习。

    【C语言编程】华为C语言面试试卷:涵盖基础语法、指针、内存管理与数据结构的综合考核题库设计

    内容概要:本文档是为华为C语言面试设计的试卷,旨在评估应聘者的C语言掌握程度。试卷分为三个主要部分:选择题、填空题和代码题。选择题涵盖了基础语法、指针、内存管理、数据结构等核心知识点,例如动态内存分配、指针操作、结构体大小、位运算等。填空题进一步考察了指针、函数声明、宏定义、内存管理等实际编程技能。代码题则侧重于算法实现,包括单链表反转、字符串逆序、二分查找、内存拷贝、统计二进制中1的个数、删除链表节点、快速排序、判断回文链表、大端小端检测以及线程安全单例模式的实现。所有题目难度适中且贴近实际开发场景,有助于全面评估应聘者的编程能力和问题解决能力。; 适合人群:具备一定C语言基础,有志于应聘华为或其他相关企业的软件开发岗位的求职者。; 使用场景及目标:①帮助求职者复习C语言基础知识,熟悉常见的面试考点;②通过实际编程题目的练习,提高解决问题的能力;③模拟真实面试环境,提升面试自信心。; 其他说明:此试卷不仅测试应聘者的理论知识,还注重实际编程能力的考察。建议考生在准备过程中,不仅要掌握语法和概念,还要多动手实践,理解每个知识点的具体应用。同时,注意代码的规范性和鲁棒性,确保在面试中能够写出高质量的代码。

    汛期安全知识教育课件教案资料.pptx

    汛期安全知识教育课件教案资料

    《人工智能在智能客服领域的应用方案》

    《人工智能在智能客服领域的应用方案》:在当今数字化时代,企业与客户之间的互动日益频繁,客户服务的质量和效率成为企业竞争的关键因素之一。传统的客服模式面临着诸多挑战,如人工客服成本高昂、工作时间受限、服务质量参差不齐、难以应对大量并发的客户咨询等问题。随着人工智能技术的飞速发展,智能客服应运而生,它能够为企业提供高效、便捷、低成本的客户服务解决方案,极大地提升客户体验和企业运营效率。无论是电商、金融、电信、教育等行业,都可以通过对客服数据的分析,优化自身的业务流程和服务质量,提升企业的竞争力。

    毕业设计物联网实战项目基于ThinkAdmin开发对接中国移动物联网开放平台OneNET的终端管理后台.zip

    【项目资源】: 物联网项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    scipy-0.10.1-cp27-cp27mu-manylinux1_x86_64.whl

    该资源为scipy-0.10.1-cp27-cp27mu-manylinux1_x86_64.whl,欢迎下载使用哦!

    Android毕设实战项目所有Android系统上使用Android12的SplashScreen API.zip

    【项目资源】: 适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    毕业设计物联网实战项目基于Zigbee和NB-Iot作为主要通信方式的物联网平台设计,其中还涉及到了AndroidAPP和物联网云平台的使用.zip

    【项目资源】: 物联网项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    毕设单片机实战项目基于mqtt协议进行信息的交互,并通过UART传至51单片机上,进而对继电器和oled显示屏做出操作.zip

    【项目资源】: 单片机项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    hive电商案例分析30.zip

    hive电商案例分析30.zip

    (源码)基于蓝牙技术的多通道键盘.zip

    # 基于蓝牙技术的多通道键盘 ## 项目简介 在多设备工作环境中,用户常常需要在家庭电脑、工作笔记本或平板电脑之间频繁切换键盘输入,这不仅占用了大量桌面空间,而且操作不便。本项目旨在通过蓝牙技术,设计一款能够同时连接多个设备并实现一键切换的多通道键盘,从而简化用户的操作流程,提高工作效率。 ## 项目的主要特性和功能 1. 多设备连接键盘可以同时连接多达三个不同的设备。 2. 一键切换通过按键即可快速切换输入目标设备。 3. 高性能微控制器采用ATMega32u4微控制器,提供足够的GPIO引脚,支持Arduino编程环境,便于固件开发和升级。 4. 蓝牙模块使用RN42蓝牙模块,确保稳定的设备连接和数据传输。 5. 电压调节器使用MIC4680电压调节器,确保系统稳定供电。 ## 安装使用步骤 1. 硬件准备 获取ATMega32u4微控制器、RN42蓝牙模块、MIC4680电压调节器等硬件组件。 2. 电路设计

    毕设单片机实战项目基于esp8266的高考倒计时.zip

    【项目资源】: 单片机项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

    车辆控制Simulink电动车转弯制动ABS与DYC联合控制系统设计:7自由度模型及滑模控制优化使用Simulink

    内容概要:本文详细解析了一个用于电动汽车转弯制动时ABS(防抱死系统)与DYC(横摆力矩控制)协同工作的Simulink模型。模型采用7自由度设计,涵盖纵向、横向、横摆运动及四轮旋转自由度,并引入轮胎魔术公式来精确模拟轮胎力特性。文章重点介绍了ABS系统中的滑移率观测与PID控制策略,以及DYC系统的滑模控制设计,特别是两者之间的协同控制逻辑。通过双移线工况测试验证,该模型能够显著提高车辆稳定性,将横摆角控制在3度以内,并缩短制动距离1.2米。文中还提供了关于模型优化、参数调试的具体建议,以及针对特定工况的仿真技巧。 适合人群:从事车辆控制系统开发的工程师、研究生及对汽车主动安全技术感兴趣的科研人员。 使用场景及目标:①研究ABS与DYC在电动汽车中的协同控制机制;②探索不同路面条件下车辆动态性能优化;③为ESP或TCS系统开发提供参考模型;④比较滑模控制与LQR控制在车辆控制中的应用效果。 阅读建议:建议读者重点关注7自由度模型的设计思路、轮胎魔术公式的实现方式、滑模控制参数调试过程以及ABS和DYC协同控制策略。由于模型涉及较多数学公式和Simulink实现细节,建议结合相关文献深入理解,并通过实际仿真加深认识。

    毕设单片机实战项目基于ESP8266开发.zip

    【项目资源】: 单片机项目适用于从基础到高级的各种项目,特别是在性能要求较高的场景中,比如操作系统开发、嵌入式编程和底层系统编程。如果您是初学者,可以从简单的控制台程序开始练习;如果是进阶开发者,可以尝试涉及硬件或网络的项目。 【项目质量】: 所有源码都经过严格测试,可以直接运行。 功能在确认正常工作后才上传。 【适用人群】: 适用于希望学习不同技术领域的小白或进阶学习者。 可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】: 项目具有较高的学习借鉴价值,也可直接拿来修改复刻。 对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】: 有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 鼓励下载和使用,并欢迎大家互相学习,共同进步。 # 注意 1. 本资源仅用于开源学习和技术交流。不可商用等,一切后果由使用者承担。 2. 部分字体以及插图等来自网络,若是侵权请联系删除。

Global site tag (gtag.js) - Google Analytics