画像の上にテキストを置きたいのですが、以下の条件の場合にどのようにcssを書けばいいのかわからないので教えてください。
1. 画像サイズがウインドウの大きさに合わせて可変する
2. 画像の垂直中央にテキストを配置する
3. 画像の大きさに合わせて相対的にテキストのサイズも同様に可変する
ネットでいろいろ検索したり書籍を見たのですがなかなかこういう場合の手法が探せませんでした。
1.の画像サイズをウインドウの大きさに合わせるのはわかりましたが、2.はテーブルを使わずにできないでしょうか?
また、3.は検討もつきませんでした。やはりjavascriptなどを使わないと実現できないでしょうか?
やりたいことはスマホ用サイトで、スマホを縦にしたり横にしたりした場合に、画像の大きさはウインドウ横幅に合わせて変えられるのですが、文字の大きさまで変えたり、中央に配置するのがわかりませんでした。
html5+css3です。お手数ですがよろしくお願い致します。
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
スマホでしたら、文字サイズも自動調整されるはずです。
<body>
<header>
</header>
<section>
<h2>見出し</h2>
<p>文章</p>
</section>
<footer>
</footer>
</body>
body>section{
width:80%;
min-width:450px;/* スマホはこのサイズまで縮めた後リサイズする */
max-width:960px;
background-image:url();
background-size:cover;
}
この回答への補足
ちなみにサイトの構成ですが、サイトトップ画面で、
<header>サイト名のある画像</header>
があり、その下にサイトの趣旨を示した画像と、その画像の上に文章を書きたいと思っています。
例えば、
<section>
<img src="images/main.jpg" />
<h2>このサイトは○○○です</h2>
</section>
のような感じです。
テーブルを使えば簡単なのでしょうが、どうやら昨今ではテーブルレイアウトは推奨されていないみたいなので質問させて頂きました。
すみませんがよろしくお願い致します。
ありがとうございます。
試して見ましたが文字がリサイズされないし、画像の中央に来ないです。
さらに画像の縦の高さが文字の高さ分しか表示されませんでした。
No.2
- 回答日時:
すみません。
文字のこと忘れてました。文字は、コンテンツの巾が450px以上の場合は、画面に収まるよう縮小されるはずです。
ブラウザが背景画像のサイズを指定するCSS3のbackground-sizeに対応していないと思われます。CSS2.1で書き直します。文字サイズはCSS3でも、変えられません。スマホの独自の機能に頼るしかないかも。
再度のご回答ありがとうございます。
なかなか難しいのですね。文字は質問の画像にあるように画像の幅を超えるほどの文字数ではないのです。
javascriptかPHPで画面の横幅から文字の大きさを割り出しての対応を考えてみたいと思います。
No.3
- 回答日時:
いえ、・・・スマートフォンのブラウザは、ウインドウ巾に合わせて縮小されるので、サイズを決め打ちすると、伸縮するはずです。
<!DOCTYPE html>
<html lang="ja">
<head>
_<meta charset="UTF-8">
_<title>Untitled</title>
_<meta name="author" content="IRUKA">
_<meta http-equiv="Content-Script-Type" content="text/javascript">
_<meta http-equiv="Content-Style-Type" content="text/css">
_<style type="text/css">
<!--
html,body{margin:0;padding:0;background-color:black;}
article{
_width:640px;height:480px;
_margin:0 auto;
_background: black url(./images/sample03.jpg) no-repeat 50% 50%;
_background-size:cover;
_color:white;
_position:relative;
}
article div{
_width:50%;height:50%;
_position:absolute;top:30%;left:20%;
_text-align:center;font-size:200%;
}
-->
_</style>
</head>
<body>
_<article>
__<div>
___<h1>サンプル</h1>
___<p>ここ短い文章</p>
__</div>
_</article>
</body>
</html>
何度もありがとうございます。
記述してくださったコードをそのままスマートフォンで表示してみましたが、ダメでした。
スマートフォンを縦と横にしてもどちらも画像と文字がそのままの大きさ・配置で画面が切り替わる(回る)だけでした。
ちなみにスマートフォンはandroidです。iPhoneだと文字の大きさが画面に合わせるのかもしれないですが、持っていないので確認できません。
それと、記述してくださった方法だと画像がウインドウ幅に合わせてサイズが変わりませんでした…。
いろいろとありがとうございました。他の方法を考えてみようと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
- ・ゆるやかでぃべーと タイムマシンを破壊すべきか。
- ・歩いた自慢大会
- ・許せない心理テスト
- ・字面がカッコいい英単語
- ・これ何て呼びますか Part2
- ・人生で一番思い出に残ってる靴
- ・ゆるやかでぃべーと すべての高校生はアルバイトをするべきだ。
- ・初めて自分の家と他人の家が違う、と意識した時
- ・単二電池
- ・チョコミントアイス
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
IMGタグで画像の繰り返し使用は…
-
背景画像の上に透過GIF背景...
-
<hr>の縦バージョンはありますか?
-
要素の幅をいろんな写真の幅に...
-
WEBサイトの画像の一部に動きを...
-
画像とその下にあるテキストの...
-
コーディング中、右側に謎の余...
-
フルCSSでバナーを作りたい
-
半透明のtable、画像は透過した...
-
【至急お助け!】チェックボッ...
-
WEB上でディレクトリ内の画像を...
-
スマートフォンで荒れない画像
-
画像固定をするタグを教えてく...
-
全くの初心者ですが、どなたか...
-
CSSでローマ数字と○1などを画像...
-
両端に背景画像を入れる
-
LightBoxの矢印の出し方
-
画像を左下と右下に固定したい...
-
jQueryでCSSの背景画像を切り替...
-
画面サイズ変更時のレイアウト...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
<hr>の縦バージョンはありますか?
-
画像の上にテキスト配置で、拡...
-
background-sizeの背景で最小値...
-
【Webサイト】画像が小さく表示...
-
画像とその下にあるテキストの...
-
background-repeat CSS で切れ...
-
【至急お助け!】チェックボッ...
-
iframe内をクリックさせない方...
-
lightbox2で画像を天地左右中央...
-
要素の幅をいろんな写真の幅に...
-
IMGタグで画像の繰り返し使用は…
-
background-sizeでcontainする...
-
同じ画像 複数回使用
-
コーディング中、右側に謎の余...
-
particles.jsの背景の上にテキ...
-
背景画像が半分しか表示されない
-
htmlかcssで背景の白い枠をなく...
-
LightBoxの矢印の出し方
-
画像の上に
-
gif画像でたまに背景がグレーに...
おすすめ情報