gpt4 book ai didi

javascript - 使用 JS、HTML、CSS 叠加图像

转载 作者:行者123 更新时间:2023-11-27 23:56:51 25 4
gpt4 key购买 nike

我正在尝试为我的网站创建一个非常类似于典型的装扮游戏的装扮功能。我已经目瞪口呆,但找到的最接近的答案是这个:Overlaying image in HTML

我已经尝试在我的本地服务器上使用我自己的定制来实现它并且成功了!但是,我尝试添加一些东西(如淡入淡出过渡)但它似乎不起作用(主要功能仍然有效)。更糟糕的是,当我将它上传到 JSFiddle 时,原来的功能甚至都不起作用(更不用说淡入淡出过渡了)。

可以找到我的代码 here 。我已经尝试过解决它的方法,但我的 JS/HTML 编码技能有限。基本上我正在尝试为变化添加淡入过渡(而不是突然变化)。至于为什么相同的代码在我的本地计算机上运行,​​但在 JSFiddle 上运行,我不知道。

最后,有没有办法设置默认选择,而不是加载“基础”?目前,正在加载“基础”图像,只有在选择后,才会出现附加图像层。我可以在用户不选择任何内容的情况下预加载列表中的第一个选择吗?

感谢并非常感谢任何帮助:)

代码:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>Funny Dress-up Games</title>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<script type="text/javascript"><!--
function createCharac(userChoice) {
var links = [
"http://dancer2dancer.sg/test/ppl-red.jpg",
"http://dancer2dancer.sg/test/ppl-orange.jpg",
"http://dancer2dancer.sg/test/ppl-pink.jpg"
];

document.getElementById('charac').src = links[userChoice];
}

function createPants(userChoice) {
var links = [
"http://dancer2dancer.sg/test/pants-blue.png",
"http://dancer2dancer.sg/test/pants-green.png",
"http://dancer2dancer.sg/test/pants-yellow.png"
];

document.getElementById('pants').src = links[userChoice];
}

function createShoe(userChoice) {
var links = [
"http://dancer2dancer.sg/test/shoe-blue.png",
"http://dancer2dancer.sg/test/shoe-red.png",
"http://dancer2dancer.sg/test/shoe-yellow.png"
];

document.getElementById('shoe').src = links[userChoice];
}
//--></script>
<style type="text/css">
<!--
.overlay {
position: absolute;
}
.overlay-container {
position: relative;
}
#char {
z-index: 10;
padding:0px 0px 0px 0px;
opacity: 1;
transition: opacity .25s ease-in-out;
-moz-transition: opacity .25s ease-in-out;
-webkit-transition: opacity .25s ease-in-out;
}
#pants {
z-index: 20;
padding:0px 0px 0px 0px;
opacity: 1;
transition: opacity .25s ease-in-out;
-moz-transition: opacity .25s ease-in-out;
-webkit-transition: opacity .25s ease-in-out;
}
#shoe {
z-index: 15;
opacity: 1;
transition: opacity .25s ease-in-out;
-moz-transition: opacity .25s ease-in-out;
-webkit-transition: opacity .25s ease-in-out;
}
-->
</style>
</head>
<body style="margin:0;padding:8px;" onload="initImages();">
<p>What character?
<select name="choice1" id="choice1" onchange="createCharac(this.value)">
<option value="0">Red</option>
<option value="1">Orange</option>
<option value="2">Pink</option>
</select>
</p>
<p>What pants?
<select name="choice2" id="choice2" onchange="createPants(this.value)">
<option value="0">Blue</option>
<option value="1">Green</option>
<option value="2">Yellow</option>
</select>
</p>
<p>What shoe?
<select name="choice3" id="choice3" onchange="createShoe(this.value)">
<option value="0">Blue</option>
<option value="1">Red</option>
<option value="2">Yellow</option>
</select>
</p>
<div class="overlay-container">
<img class="overlay" src="http://dancer2dancer.sg/test/ppl-red.jpg" />
<img class="overlay" id="charac" />
<img class="overlay" id="pants" />
<img class="overlay" id="shoe" />
</div>
</body>
</html>

最佳答案

function initImages(params) {
if(!params) {
var params = {"character":0, "pants":0, "shoe":0}; // Default set
}
createCharac(params.character);
document.getElementById("choice1").value = params.character.toString();

createPants(params.pants);
document.getElementById("choice2").value = params.pants.toString();

createShoe(params.shoe);
document.getElementById("choice3").value = params.shoe.toString();
}

然后你可以像这样使用你的函数:

initImages({"character":0, "pants":2, "shoe":1});

或简单地:initImages() 加载默认集。

关于javascript - 使用 JS、HTML、CSS 叠加图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23448519/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com