2017-11-03 9 views
0

私がやっていることは、イメージボタンの中にオーディオボタンを配置することです。誰かが私を助けることができますか?コード全体がjsfiddleにあります。それはもっと多くの情報を追加することを言っているが、それは私が助けを求めているすべてです。誰かが私を助けてくれますか?それはもっと多くの情報を追加することを言っているが、それは私が助けを求めているすべてです。イメージ内に再生ボタンを配置する

ワーキングコード

https://jsfiddle.net/7h8jsvch/1/

映像/音声ボタン

enter image description here

<style> 
 
#container { 
 
    background-color: black; 
 
    position:relative; 
 
    width:260px; 
 
    height:194px; 
 
    padding:0; 
 
    border: 3px solid #0059dd; 
 
} 
 

 
#img1,#img2 { 
 
    position: absolute; 
 
    top: 50%; 
 
    left: 50%; 
 
    transform: translate(-50%, -50%); 
 

 
} 
 

 
#img1 { 
 
    clip-path: circle(85px at center); 
 
} 
 
    
 
#grad { 
 
    position: absolute; 
 
    top: 0; 
 
    left: 0; 
 
    width: 260px; 
 
    height: 194px; 
 
    cursor: pointer; 
 
    background-color: transparent; ; 
 
    background-image: linear-gradient(to right,transparent 0, transparent 83px,#0059dd 83px, #0059dd 86px, transparent 86px, transparent 174px, #0059dd 174px, #0059dd 177px, transparent 177px,transparent 260px); 
 
    
 
    } 
 

 
    .button div { 
 
    width: 38px; 
 
    height: 38px; 
 
    top: 76px; 
 
    left: 111px; 
 
    background-color: transparent; 
 
    background-size: 14px 18px; 
 
    background-repeat: no-repeat; 
 
    border-radius: 50%; 
 
    position: absolute; 
 
    } 
 

 
</style> 
 

 
<div id="container"> 
 
    <img id="img1" width="170" height="113" src="https://i.imgur.com/BO6KOvw.jpg"> 
 
    <img id="img2" width="180" height="180" src="https://i.imgur.com/4HJbzEq.png"> 
 
    <div id="grad"> 
 

 

 

 
</div> 
 
</div> 
 

 

 
<div id="playButton4" style="position:relative;border: 3px solid #0059dd;background-color:black;width: 260px; height: 194px;cursor: pointer;" onclick=" 
 
var button = document.getElementById('playButton4'); 
 
var player = document.getElementById('player4'); 
 
button.querySelector('.play').style.display='none'; 
 
button.querySelector('.pause').style.display='none'; 
 
player.volume=1.0; if (player.paused) { 
 
button.querySelector('.pause').style.display='inline-block'; 
 
player.play(); 
 
} else { 
 
button.querySelector('.play').style.display='inline-block'; 
 
player.pause(); 
 
}"> 
 

 
    
 

 
    <div class="button"> 
 
    <div class="play" style="background-image: url(''); background-position: 58% 50%;"> 
 
    </div> 
 
    <div class="pause" style="background-image: url('');background-position: 50%;display: none;"> 
 
    </div> 
 

 
    </div> 
 

 

 
</div> 
 

 
<audio id="player4" style="display:none;"> 
 
    <source src='http://hi5.1980s.fm/;' type='audio/mpeg'> 
 
    </source> 
 
</audio>

+1

それがオンいない代わりにjsfiddle – Ibo

答えて

0

ちょうどあなたのplayButton4のdivとコンテナ内buttonのdivを移動します。また、背景色と境界線を削除します。playButton4 div。

#container { 
 
    background-color: black; 
 
    position:relative; 
 
    width:260px; 
 
    height:194px; 
 
    padding:0; 
 
    border: 3px solid #0059dd; 
 
} 
 

 
#img1,#img2 { 
 
    position: absolute; 
 
    top: 50%; 
 
    left: 50%; 
 
    transform: translate(-50%, -50%); 
 

 
} 
 

 
#img1 { 
 
    clip-path: circle(85px at center); 
 
} 
 
    
 
#grad { 
 
    position: absolute; 
 
    top: 0; 
 
    left: 0; 
 
    width: 260px; 
 
    height: 194px; 
 
    cursor: pointer; 
 
    background-color: transparent; ; 
 
    background-image: linear-gradient(to right,transparent 0, transparent 83px,#0059dd 83px, #0059dd 86px, transparent 86px, transparent 174px, #0059dd 174px, #0059dd 177px, transparent 177px,transparent 260px); 
 
    
 
    } 
 

 
    .button div { 
 
    width: 38px; 
 
    height: 38px; 
 
    top: 76px; 
 
    left: 111px; 
 
    background-color: transparent; 
 
    background-size: 14px 18px; 
 
    background-repeat: no-repeat; 
 
    border-radius: 50%; 
 
    position: absolute; 
 
    }
<div id="container"> 
 
    <img id="img1" width="170" height="113" src="https://i.imgur.com/BO6KOvw.jpg"> 
 
    <img id="img2" width="180" height="180" src="https://i.imgur.com/4HJbzEq.png"> 
 
    <div id="grad"> 
 

 

 
<div id="playButton4" style="position:relative;width: 260px; height: 194px;cursor: pointer;" onclick=" 
 
var button = document.getElementById('playButton4'); 
 
var player = document.getElementById('player4'); 
 
button.querySelector('.play').style.display='none'; 
 
button.querySelector('.pause').style.display='none'; 
 
player.volume=1.0; if (player.paused) { 
 
button.querySelector('.pause').style.display='inline-block'; 
 
player.play(); 
 
} else { 
 
button.querySelector('.play').style.display='inline-block'; 
 
player.pause(); 
 
}"> 
 

 
    
 

 
    <div class="button"> 
 
    <div class="play" style="background-image: url(''); background-position: 58% 50%;"> 
 
    </div> 
 
    <div class="pause" style="background-image: url('');background-position: 50%;display: none;"> 
 
    </div> 
 

 
    </div> 
 

 

 
</div> 
 
</div> 
 

 

 

 
</div> 
 

 
<audio id="player4" style="display:none;"> 
 
    <source src='http://hi5.1980s.fm/;' type='audio/mpeg'> 
 
    </source> 
 
</audio>

0

コンテナdivの中に再生ボタンを配置し、再生ボタンから黒い背景も削除することをお勧めします。

https://jsfiddle.net/7h8jsvch/7/

<div id="container"> 
    <img id="img1" width="170" height="113" 
src="https://i.imgur.com/BO6KOvw.jpg"> 
    <img id="img2" width="180" height="180" 
src="https://i.imgur.com/4HJbzEq.png"> 
    <div id="grad"> 
    <div id="playButton4" style="position:relative;border: 3px solid 
#0059dd;width: 260px; height: 194px;cursor: pointer;" onclick=" 
var button = document.getElementById('playButton4'); 
var player = document.getElementById('player4'); 
button.querySelector('.play').style.display='none'; 
button.querySelector('.pause').style.display='none'; 
player.volume=1.0; if (player.paused) { 
button.querySelector('.pause').style.display='inline-block'; 
player.play(); 
} else { 
button.querySelector('.play').style.display='inline-block'; 
player.pause(); 
}"> 
</div> 
</div> 
+0

のスタックオーバーフローのコードスニペット機能を使用してください。 https://jsfiddle.net/7h8jsvch/13/ –

+0

jsfiddleの必要はありません、スタックオーバーフロー 'code snippet'を使うべきです – Ibo

関連する問題