Форум программистов, компьютерный форум, киберфорум
HTML, CSS
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
467 / 431 / 117
Регистрация: 15.02.2012
Сообщений: 1,951

Css масштабирующийся квадрат

17.02.2025, 17:41. Показов 1434. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Как получить масштабирующийся квадрат?

Есть блок и там всегда должен быть квадрат не выходящий за рамки экрана и без прокруток.
Внутри будут круги, которые зависят от размеров квадрата.

верстка предполагает 3 колонки:
колонка 20% и (колонка 80% поделенная на 2 в соотношении 60/40)

вот в колонке 2, 60% которая , нужен квадрат который должен масштабироваться в зависимости от размеров/разрешения экрана
т.е. если я в браузере сделаю размер экрана 1920*300, то квадрат не должен быть больше 100vh - 80px т.е. примерно 220px ? потому что высота маленькая, если я экран начну делать 1000*1000? то тут ширина уже будет ~560 значит и квадрат не больше этого значения

или только это реализуемо через js?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.02.2025, 17:41
Ответы с готовыми решениями:

CSS
Допустим у меня в CSS файле определен класс menu menu{color:white;width:100;heigth:200}Как мне лучше определить такой же класс только что...

CSS Bootstrap шаблон
Есть у кого реализованный шаблон? Вообще без разницы какое наполнение del

Верстка с CSS
Здравствуйте! У меня произошла такая проблема, если просмотреть страничку через IE, то когда щелкаешь на слово Порфолио, то появляется...

4
 Аватар для voraa
1269 / 1233 / 183
Регистрация: 21.01.2024
Сообщений: 5,677
17.02.2025, 18:00
Цитата Сообщение от tgarl Посмотреть сообщение
если я экран начну делать 1000*1000? то тут ширина уже будет ~560
Откуда 560?
480 наверно.
Цитата Сообщение от tgarl Посмотреть сообщение
если я в браузере сделаю размер экрана 1920*300, то квадрат не должен быть больше 100vh - 80px т.е. примерно 220px ? потому что высота маленькая,
А как от высоты зависит? Почему 220 а не 300?
0
929 / 551 / 292
Регистрация: 07.11.2022
Сообщений: 902
17.02.2025, 18:17
Цитата Сообщение от tgarl Посмотреть сообщение
Как получить масштабирующийся квадрат?
Так?
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
<!doctype html>
<html>
<head>
<style>
* {
  margin: 0;
  padding: 0;
}
.wrapper {
  display: flex;
  min-height: 100vh;
}
.wrapper .left {
  width: 20%;
  background: #fcc;
}
.wrapper .center {
  width: 48%; /* 80%*0.6 */
  background: #cfc;
}
.wrapper .right {
  width: 32%; /* 80%*0.4 */
  background: #ccf;
}
 
.square {
  max-width: 100%;
  max-height: 100vh;
  aspect-ratio: 1/1;
  background: #ccc;
}
</style>
</head>
<body>
<div class="wrapper">
  <div class="left">
  </div>
  <div class="center">
    <div class="square"></div>
  </div>
  <div class="right">
  </div>
</div>
</body>
</html>
Откуда в задаче появляется 80px и где оно и по какому случаю должно добавляться/вычитаться, телепаты не смогли понять. )
0
467 / 431 / 117
Регистрация: 15.02.2012
Сообщений: 1,951
18.02.2025, 10:21  [ТС]
80px - это я исхожу что может быть шапка над этим блоком

Если добавить к .wrapper .center центровку через flex, то перестает работать(
CSS
1
2
3
display: flex;
align-items: center;
justify-content: center;
0
929 / 551 / 292
Регистрация: 07.11.2022
Сообщений: 902
18.02.2025, 11:38
Лучший ответ Сообщение было отмечено tgarl как решение

Решение

Цитата Сообщение от tgarl Посмотреть сообщение
Если добавить к .wrapper .center центровку через flex, то перестает работать(
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
<!doctype html>
<html>
<head>
<style>
* {
  margin: 0;
  padding: 0;
}
.wrapper {
  display: flex;
  min-height: 100vh;
}
.wrapper .left {
  width: 20%;
  background: #fcc;
}
.wrapper .center {
  width: 48%; /* 80%*0.6 */
  background: #cfc;
}
.wrapper .right {
  width: 32%; /* 80%*0.4 */
  background: #ccf;
}
 
.square {
  position: relative;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  place-content: center;
  max-width: calc(100% - 80px);
  max-height: calc(100vh - 80px);
  aspect-ratio: 1/1;
  background: #ccc;
}
</style>
</head>
<body>
<div class="wrapper">
  <div class="left">
  </div>
  <div class="center">
    <div class="square">Квадрат</div>
  </div>
  <div class="right">
  </div>
</div>
</body>
</html>
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.02.2025, 11:38
Помогаю со студенческими работами здесь

Не выравнивается TH в CSS
Всем привет! Такая проблема: во внешней таблице стилей написала такой код: th {text-align:left;} td {text-align:center;} p...

Жирная ссылка при нажатии (CSS)
Здравствуйте! у меня такой вопрос! a.cont{ color: #777576; text-decoration: none; font-weight: 200; font-size:11; } ...

Проблема с CSS
Вобщем, тут такое дело. Мне надо слой с картинкой (зеленый) сдвинуть за основной слой (красный). В Опере все замечательно а е#$@%й IE...

Необходимо текст установить в рамки голубого поля (css)
Проблема с CSS. Необходимо текст установить в рамки голубого поля. Голубое поле это картинка вставлена в таблицу, текст идет поверх нее...

Подскажите по видео урокам специалист html и css
Здравствуйте! Подскажите пожалуйста где можно посмотреть видео уроки или скачать Центра специалист &quot;Создание сайтов глубокое...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru