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 [2024/01/08 19:27] admin [Cálculos en CSS] |
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 150: | Línea 158: | ||
.c-titulo { | .c-titulo { | ||
font-size: calc(10vw - 10px); | font-size: calc(10vw - 10px); | ||
+ | } | ||
+ | </ | ||
+ | |||
+ | <sxh css> | ||
+ | .c-titulo { | ||
+ | font-size: calc( ( 1 / 3 ) * 100vw); | ||
} | } | ||
</ | </ | ||
Línea 158: | Línea 172: | ||
} | } | ||
</ | </ | ||
+ | |||
+ | |||
<note tip> | <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 167: | Línea 196: | ||
- | ==== Calculo de valores | + | ==== Calculo de valores |
+ | 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 391: | 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 406: | 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 421: | 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 437: | 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 625: | Línea 773: | ||
</ | </ | ||
- | * Externo/ | + | * Externo/ |
<sxh html> | <sxh html> | ||
Línea 718: | Línea 866: | ||
</ | </ | ||
- | Y modificalas con el sufijo "@movil", "@tabled" y "@desktop" y repite el ejercicio anterior pero en vez de usar la clase '' | + | Y modificalas con el sufijo "@tabled", "@desktop" y "@fulldesktop" y repite el ejercicio anterior pero en vez de usar la clase '' |
==== Ejercicio 8 ==== | ==== Ejercicio 8 ==== | ||
Línea 742: | Línea 890: | ||
==== Ejercicio 9 ==== | ==== Ejercicio 9 ==== | ||
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. | ||
Línea 751: | Línea 899: | ||
==== Ejercicio 10 ==== | ==== Ejercicio 10 ==== | ||
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 | ||