質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

レスポンシブWebデザイン

レスポンシブWebデザイン(RWD)は、スクリーンのサイズ、プラットフォーム、オリエンテーションに基づいて様々なデバイスで最適のサイトを生成するのウェブデザインとその開発のアプローチ方法を呼びます。

Q&A

解決済

1回答

851閲覧

背景斜めの図形に対して配置した画像の位置をレスポンシブで表示した時、WEBサイトで表示した時の位置を比率で維持したいですが上手くできません。

yuyuki

総合スコア6

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

レスポンシブWebデザイン

レスポンシブWebデザイン(RWD)は、スクリーンのサイズ、プラットフォーム、オリエンテーションに基づいて様々なデバイスで最適のサイトを生成するのウェブデザインとその開発のアプローチ方法を呼びます。

0グッド

0クリップ

投稿2020/02/24 13:25

背景斜めの図形に対して画像をブレンドモード:乗算(mix-blend-mode: multiply;)を使用して
図形と重ねて配置しました。
配置した時、図形との重なり具合が、WEBサイト、スマホで表示した時、それぞれで異なってしまします。
理想としては、WEBサイトで表示した時の見え方で、比率を維持して、レスポンシブで表示したいと
考えております。

HTML

1<!DOCTYPE html> 2<html> 3<head> 4 5<title>テスト</title> 6 7 8<link rel="stylesheet" href="./css/style.css"> 9 10</head> 11 12<body> 13 14<!-- partial:index.partial.html --> 15<section> 16 <div class="inner"> 17 <h1>Title</h1> 18 <div class="top-img"><img src="https://uploda4.ysklog.net/c20a6d522fafe57d114e96c58725788c.jpg 19" alt="仮画像"></div> 20 <p>Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. </p> 21 </div> 22</section> 23<section class="slant-section"> 24 <div class="inner"> 25 <h2>Slant Layout</h2> 26 <p>Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. </p> 27 <p>Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. </p> 28 <p>Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. </p> 29 </div> 30</section> 31<section> 32 <div class="inner"> 33 <h2>Title</h2> 34 <p>Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. </p> 35 </div> 36</section> 37 38 <section class="slant-section"> 39 <div class="inner"> 40 <h2>Slant Layout</h2> 41 <p>Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. </p> 42 <p>Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. </p> 43 <p>Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. Sample Text. </p> 44 </div> 45</section> 46<!-- partial --> 47 48 49</body> 50</html>

css

1body { 2 margin: 0; 3 background: #fff; 4} 5 6section { 7 position: relative; 8 box-sizing: border-box; 9} 10section .inner { 11 position: relative; 12 padding: 50px; 13 max-width: 1024px; 14 margin: auto; 15} 16 17.slant-section { 18 margin: 200px auto; /* 白余白 */ 19} 20 21@media screen and (max-width:350px) { 22 .slant-section{ 23 margin: 20px auto; 24 } 25} 26 27.slant-section:before { 28 content: ""; 29 display: block; 30 position: absolute; 31 top: -50px; 32 z-index: -1; 33 width: 100%; 34 height: 150%; 35 background: #c90b0b; 36 transform: skewY(-10deg); 37} 38.slant-section + section:before { 39 content: ""; 40 display: block; 41 position: absolute; 42 top: -50px; 43 z-index: -1; 44 width: 100%; 45 height: 100%; 46 background: #fff; 47 transform: skewY(-10deg); 48} 49 50.top-img { 51 max-width:100%; 52 height: auto; ; 53 border:none; 54 top: 50px; 55 right: 10px; 56 opacity: 0.7; 57 mix-blend-mode: multiply; /* 乗算 */ 58 position: absolute; 59}

試したこと

CSSの
.slant-section {
margin: 200px auto; /* 白余白 */
}
部分に様々な変更を加えてみました。
position: absolute;、position: relative;を加えてみたり、
margin: 200px auto;のpxをvwや%で試してみました。
また.slant-sectionに対して@media screen and〜のコードを
色々調べながら手探りで試してみましたが、上手くいかず、PC、スマホ、ipadで
それぞれで表示が異なってしまいます。

お力をお借りしたいと思いますので、何かいい方法が御座いましたら、
何卒よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hwatarig

2020/02/25 12:46

貼っていただいているコードの表示を広い画面で確認すると、斜めのラインが画像の人物の膝あたりにぶつかっていますが、その位置関係を常に保ちたい、ということでしょうか?
yuyuki

2020/02/25 12:50

ご確認下さり、有難う御座います。 そうです。画像の人物の膝あたりと斜めのラインの位置関係を保ちたいという事です。 思いつく限り調べたり、色々試してみましたが、上手くいかなかったもので、位置関係を保つ方法が何かあればと検討しております。
guest

回答1

0

ベストアンサー

このような形にするのはいかがでしょうか。わかりやすいよう、一部色を変えています。
https://jsfiddle.net/v9ke8ao4/5/

斜めの線と画像の位置関係を保ちたいということだったので、「斜めの線」だけを直角三角形として切り出して、基準となる位置をずれないようにしてみました。
また、「斜めの線」と「画像」のサイズと位置指定をすべてvwで行うことで、画面幅に応じて常に比率を保ったまま等倍でサイズだけが変わるようにしています。

投稿2020/02/25 13:01

hwatarig

総合スコア461

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

yuyuki

2020/02/25 14:20

大変ご丁寧なご回答を下さり、有難う御座います。vwの扱いやレスポンシブに対する 考え方や知識がまだまだ浅いため、大変勉強になります。 作って下さったコードを参考に、勉強させて頂きます。本当にお忙しい中、 有難う御座いました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問