Muestra las diferencias entre dos versiones de la página.
Ambos lados, revisión anterior Revisión previa Próxima revisión | Revisión previa | ||
clase:daw:diw:2eval:tema06 [2021/01/20 17:51] admin [Arquitectura responsiva] |
clase:daw:diw:2eval:tema06 [2024/05/17 18:38] (actual) admin [viewport] |
||
---|---|---|---|
Línea 26: | Línea 26: | ||
Mas información: | Mas información: | ||
* [[https:// | * [[https:// | ||
- | * [[https:// | + | * [[https:// |
* [[https:// | * [[https:// | ||
* [[https:// | * [[https:// | ||
Línea 68: | Línea 68: | ||
| | ||
| | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | * También se pueden usar decimales con '' | ||
+ | |||
+ | <sxh css> | ||
+ | .c-titulo { | ||
+ | font-size: 3.14vw; | ||
} | } | ||
</ | </ | ||
Línea 82: | Línea 90: | ||
==== em ==== | ==== em ==== | ||
- | La unidad '' | + | La unidad '' |
Línea 155: | Línea 163: | ||
<sxh css> | <sxh css> | ||
.c-titulo { | .c-titulo { | ||
- | font-size: | + | font-size: calc( ( 1 / 3 ) * 100vw); |
} | } | ||
</ | </ | ||
+ | <sxh css> | ||
+ | .c-titulo { | ||
+ | font-size: clamp(40px, | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | |||
+ | |||
+ | <note tip> | ||
+ | <note important> | ||
+ | Es obligatorio separar siempre las operaciones de suma y resta con espacios en blanco de sus operandos. | ||
+ | |||
+ | Por ejemplo, la siguiente expresión no es correcta: | ||
+ | |||
+ | '' | ||
+ | |||
+ | debiendose corregir y quedando así: | ||
+ | |||
+ | '' | ||
+ | |||
+ | Aunque los operadores '' | ||
+ | </ | ||
Línea 166: | Línea 196: | ||
+ | ==== Calculo de valores con clamp ==== | ||
+ | La siguiente gráfica muestra como funciona '' | ||
+ | {{ : | ||
+ | |||
+ | Para calcular los tamaños de pantalla donde se producen los cambios (puntos rojos) las variable son las siguientes: | ||
+ | |||
+ | * $w_{lower}$: | ||
+ | * $w_{upper}$: | ||
+ | * $min_{value}$: | ||
+ | * $max_{value}$: | ||
+ | \\ | ||
+ | * $pendiente$: | ||
+ | |||
+ | $$ | ||
+ | pendiente=60 | ||
+ | \\ | ||
+ | min=200 | ||
+ | \\ | ||
+ | max=400 | ||
+ | $$ | ||
+ | \\ | ||
+ | \\ | ||
+ | $$ | ||
+ | |||
+ | w_{lower} * \frac {pendiente}{100}=min_{value} | ||
+ | \\ | ||
+ | w_{lower} = \frac {min_{value}*100}{pendiente}= \frac {200*100}{60}=333px | ||
+ | $$ | ||
+ | |||
+ | \\ | ||
+ | \\ | ||
+ | $$ | ||
+ | w_{upper} * \frac {pendiente}{100}=max_{value} | ||
+ | \\ | ||
+ | w_{upper} = \frac {max_{value}*100}{pendiente}= \frac {400*100}{60}=667px | ||
+ | |||
+ | |||
+ | $$ | ||
+ | |||
+ | |||
+ | De forma genérica podemos establecer los valores de las 4 variables de la siguiente forma: | ||
+ | |||
+ | {{ : | ||
+ | |||
+ | Siendo los valores de $pendiente$ y $coeficiente_{posición}$ los siguientes: | ||
+ | |||
+ | $$ | ||
+ | pendiente=\frac {max_{value} - min_{value}}{w_{upper} - w_{lower}}*100 | ||
+ | \\ | ||
+ | coeficiente_{posición}=min_{value} - \frac{pendiente}{100}*w_{lower} | ||
+ | $$ | ||
+ | |||
+ | Veamos el ejemplo en el que queremos que la propiedad '' | ||
+ | * $w_{lower}$: | ||
+ | * $w_{upper}$: | ||
+ | * $min_{value}$: | ||
+ | * $max_{value}$: | ||
+ | |||
+ | Entonces | ||
+ | |||
+ | $$ | ||
+ | pendiente=\frac {max_{value} - min_{value}}{w_{upper} - w_{lower}}=\frac {20-12}{600-230}*100=2, | ||
+ | \\ | ||
+ | coeficiente_{posición}=min_{value} - \frac{pendiente}{100}*w_{lower}=12-\frac{2, | ||
+ | $$ | ||
+ | |||
+ | Por lo tanto el css será: | ||
+ | |||
+ | <sxh css> | ||
+ | .c-titulo { | ||
+ | font-size: clamp(12px, | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | |||
+ | * El código en python para crear los gráficos es el siguiente: | ||
+ | <sxh python> | ||
+ | import numpy as np | ||
+ | import matplotlib.pyplot as plt | ||
+ | from matplotlib.ticker import AutoLocator | ||
+ | |||
+ | min_value=200 | ||
+ | max_value=400 | ||
+ | pendiente=60 | ||
+ | coeficiente_posición=15 | ||
+ | |||
+ | def decore_axes(axes, | ||
+ | axes.set_title(title, | ||
+ | axes.set_xlabel(xlabel, | ||
+ | axes.set_ylabel(ylabel, | ||
+ | axes.set_xlim(xmin=0) | ||
+ | axes.grid(visible=True, | ||
+ | axes.set_axisbelow(True) | ||
+ | axes.yaxis.set_major_locator(AutoLocator()) | ||
+ | axes.set_facecolor('# | ||
+ | |||
+ | max_w_size=1200 | ||
+ | x=np.linspace(0, | ||
+ | y=[] | ||
+ | |||
+ | for xi in x: | ||
+ | yi=xi*(pendiente/ | ||
+ | if (yi< | ||
+ | yi=min_value | ||
+ | elif (yi> | ||
+ | yi=max_value | ||
+ | |||
+ | y.append(yi) | ||
+ | |||
+ | min_corte_x=((min_value-coeficiente_posición)*100)/ | ||
+ | max_corte_x=((max_value-coeficiente_posición)*100)/ | ||
+ | figure=plt.figure(figsize=(8, | ||
+ | axes = figure.add_subplot(1, | ||
+ | |||
+ | axes.plot(x, | ||
+ | axes.scatter(min_corte_x, | ||
+ | axes.scatter(max_corte_x, | ||
+ | |||
+ | decore_axes(axes, | ||
+ | |||
+ | _=axes.set_xticks( [0, | ||
+ | </ | ||
===== Imágenes ===== | ===== Imágenes ===== | ||
Hay muchas opciones al respecto de las imágenes responsivas. La técnica consiste principalmente en usar una imagen u otra en función de: | Hay muchas opciones al respecto de las imágenes responsivas. La técnica consiste principalmente en usar una imagen u otra en función de: | ||
Línea 387: | Línea 539: | ||
@media (min-width: 576px) { | @media (min-width: 576px) { | ||
- | .g--font-size-1\@movil { | + | .g--font-size-1\@tablet |
font-size: 40px; | font-size: 40px; | ||
} | } | ||
- | .g--font-size-2\@movil { | + | .g--font-size-2\@tablet |
font-size: 50px; | font-size: 50px; | ||
} | } | ||
- | .g--font-size-3\@movil { | + | .g--font-size-3\@tablet |
font-size: 55px; | font-size: 55px; | ||
} | } | ||
- | .g--font-size-4\@movil { | + | .g--font-size-4\@tablet |
font-size: 70px; | font-size: 70px; | ||
} | } | ||
Línea 402: | Línea 554: | ||
@media (min-width: 768px) { | @media (min-width: 768px) { | ||
- | .g--font-size-1\@tablet | + | .g--font-size-1\@desktop |
font-size: 40px; | font-size: 40px; | ||
} | } | ||
- | .g--font-size-2\@tablet | + | .g--font-size-2\@desktop |
font-size: 50px; | font-size: 50px; | ||
} | } | ||
- | .g--font-size-3\@tablet | + | .g--font-size-3\@desktop |
font-size: 55px; | font-size: 55px; | ||
} | } | ||
- | .g--font-size-4\@tablet | + | .g--font-size-4\@desktop |
font-size: 70px; | font-size: 70px; | ||
} | } | ||
Línea 417: | Línea 569: | ||
@media (min-width: 992px) { | @media (min-width: 992px) { | ||
- | .g--font-size-1\@desktop | + | .g--font-size-1\@fulldesktop |
font-size: 40px; | font-size: 40px; | ||
} | } | ||
- | .g--font-size-2\@desktop | + | .g--font-size-2\@fulldesktop |
font-size: 50px; | font-size: 50px; | ||
} | } | ||
- | .g--font-size-3\@desktop | + | .g--font-size-3\@fulldesktop |
font-size: 55px; | font-size: 55px; | ||
} | } | ||
- | .g--font-size-4\@desktop | + | .g--font-size-4\@fulldesktop |
font-size: 70px; | font-size: 70px; | ||
} | } | ||
Línea 433: | Línea 585: | ||
<sxh html> | <sxh html> | ||
- | <p class=" | + | <p class=" |
</ | </ | ||
En el ejemplo por defecto el tamaño de la fuente será de 40px pero en resoluciones mayores de 992px será de 55px. | En el ejemplo por defecto el tamaño de la fuente será de 40px pero en resoluciones mayores de 992px será de 55px. | ||
- | Lo que hacemos es crear todas los modificadores globales o modificadores de bloques para las distintas resoluciones pero añadiendo el sufijo '' | + | Lo que hacemos es crear todas los modificadores globales o modificadores de bloques para las distintas resoluciones pero añadiendo el sufijo |
Otro ejemplo de ello lo podemos ver en [[https:// | Otro ejemplo de ello lo podemos ver en [[https:// | ||
Línea 471: | Línea 623: | ||
===== Menu responsivo ===== | ===== Menu responsivo ===== | ||
- | {{menu.zip|}} | + | {{..:1eval:menu.zip|}} |
<sxh html;title: HTML> | <sxh html;title: HTML> | ||
Línea 569: | Línea 721: | ||
^ ^ Interno | ^ ^ Interno | ||
- | ^ Fluido | + | ^ Fluido |
- | ^ Escalonado | + | ^ Escalonado |
Línea 589: | Línea 741: | ||
- | * Interno/ | + | * Interno/ |
<sxh css> | <sxh css> | ||
Línea 621: | Línea 773: | ||
</ | </ | ||
- | * Externo/ | + | * Externo/ |
<sxh html> | <sxh html> | ||
Línea 636: | Línea 788: | ||
* 1 div cuadrado azul de tamaño 400px | * 1 div cuadrado azul de tamaño 400px | ||
* 1 div cuadrado verde de tamaño 400px | * 1 div cuadrado verde de tamaño 400px | ||
- | * Dentro cada cuadrado azul , añade otro div de color rojo con tamaño | + | * Dentro cada cuadrado azul , añade otro div de color rojo con tamaño |
- | * Dentro cada cuadrado verde , añade otro div de color rojo con tamaño | + | * Dentro cada cuadrado verde , añade otro div de color rojo con tamaño |
Ahora: | Ahora: | ||
- | * Explica la diferencia de tamaños entre los de 10% y 10vw | + | * Explica la diferencia de tamaños entre los de 20% y 20vw |
* Ahora cambia el tamaño de la página y mira como de modifica el tamaño de los cuadrados. Indica cuales han cambiado de tamaño y explica porqué han cambiado de tamaño | * Ahora cambia el tamaño de la página y mira como de modifica el tamaño de los cuadrados. Indica cuales han cambiado de tamaño y explica porqué han cambiado de tamaño | ||
Línea 683: | Línea 835: | ||
==== Ejercicio 5 ==== | ==== Ejercicio 5 ==== | ||
Dado el típico layout de cabecera, menú lateral, cuerpo y pie. Haz una página HTML pero de forma que si el tamaño de la pantalla es menor que 500px no se vea el menú lateral. Deberás hacerlo usando BEM | Dado el típico layout de cabecera, menú lateral, cuerpo y pie. Haz una página HTML pero de forma que si el tamaño de la pantalla es menor que 500px no se vea el menú lateral. Deberás hacerlo usando BEM | ||
- | |||
==== Ejercicio 6 ==== | ==== Ejercicio 6 ==== | ||
+ | Crea una clase css llamada '' | ||
+ | |||
+ | * Menos de 500px sea de color rojo | ||
+ | * Entre 500px y 750px sea de color verde | ||
+ | * Entre 750px y 1000px sea de color azul | ||
+ | * Más de 1000px sea de color naranja | ||
+ | |||
+ | Lo usarán en una página HTML donde estará un cuadrado de 200px x 200px | ||
+ | |||
+ | ==== Ejercicio 7 ==== | ||
+ | Crea las siguientes clases css: | ||
+ | |||
+ | <sxh css> | ||
+ | .g--bg-color-red { | ||
+ | background-color:# | ||
+ | } | ||
+ | .g--bg-color-green { | ||
+ | background-color:# | ||
+ | } | ||
+ | .g--bg-color-blue { | ||
+ | background-color:# | ||
+ | } | ||
+ | .g--bg-color-orange { | ||
+ | background-color:# | ||
+ | } | ||
+ | |||
+ | |||
+ | </ | ||
+ | |||
+ | Y modificalas con el sufijo " | ||
+ | |||
+ | ==== Ejercicio 8 ==== | ||
Crea modificadores globales para las siguientes propiedades CSS: | Crea modificadores globales para las siguientes propiedades CSS: | ||
* '' | * '' | ||
Línea 705: | Línea 888: | ||
* Que si la tabla no cabe, aparezcan las barras de scroll. | * Que si la tabla no cabe, aparezcan las barras de scroll. | ||
- | ==== Ejercicio | + | ==== Ejercicio |
Modifica el ejercicio anterior de forma que ahora los modificadores globales se puedan usar de forma responsiva con | Modifica el ejercicio anterior de forma que ahora los modificadores globales se puedan usar de forma responsiva con | ||
- | * @movil | ||
* @tablet | * @tablet | ||
* @desktop | * @desktop | ||
+ | * @fulldesktop | ||
Modifica el ejemplo de la tabla HTML de forma que las columnas ahora tenga siempre tamaños fijos (es decir no usar min o max), pero que cambien según la resolución de la pantalla. | Modifica el ejemplo de la tabla HTML de forma que las columnas ahora tenga siempre tamaños fijos (es decir no usar min o max), pero que cambien según la resolución de la pantalla. | ||
- | ==== Ejercicio | + | ==== Ejercicio |
Usando las clases de BEM y los modificadores globales que has ido usando durante el curso, añade de forma que ahora se puedan usar de forma responsiva con | Usando las clases de BEM y los modificadores globales que has ido usando durante el curso, añade de forma que ahora se puedan usar de forma responsiva con | ||
- | * @movil | ||
* @tablet | * @tablet | ||
* @desktop | * @desktop | ||
+ | * @fulldesktop | ||
- | ==== Ejercicio | + | ==== Ejercicio |
Modifica la página del tema anterior para hacerla responsiva de forma que según la resolución se cambie el tamaño : | Modifica la página del tema anterior para hacerla responsiva de forma que según la resolución se cambie el tamaño : | ||
* El tamaño de los títulos | * El tamaño de los títulos |