2016-01-16 25 views
13

La mia domanda riguarda il gradiente con dissolvenza: gradiente - dall'alto verso il basso e dissolvenza - da sinistra a destra.Gradiente con dissolvenza in CSS

Esempio:

enter image description here

Il codice è:

background-image: 
    linear-gradient(0deg, rgba(198,83,165,.95) 0%, rgba(198,86,51,.95) 100%), 
    linear-gradient(90deg, transparent 50%, rgba(0,0,0,.95) 100%); 
opacity: 0.949; 

Il mio risultato è al di sotto.

enter image description here

Come si vede, non sbiadisce il gradiente, sembra livello separato, dietro a questo gradiente. C'è qualche altro metodo per implementarlo?

+2

Trasparente mostrerà solo il livello dietro (che è quello con il colore) e quindi questo approccio non funzionerà. Dovrai usare un altro modo – Harry

risposta

11

Come ho menzionato nei commenti, quando si aggiunge un livello trasparente sopra un altro gradiente, verrà visualizzato solo attraverso il livello sfumato colorato che si trova sotto di esso (e non l'immagine che è presente nel contenitore). Quindi, sarebbe molto difficile (quasi impossibile) ottenere questo con gradienti.

Dovresti utilizzare un'immagine maschera per realizzarla. Di seguito è riportato uno snippet che utilizza una maschera SVG .

div { 
 
    position: relative; 
 
    height: 300px; 
 
    width: 500px; 
 
} 
 
div svg { 
 
    position: absolute; 
 
    height: 100%; 
 
    width: 100%; 
 
} 
 
div .grad-fill { 
 
    fill: url(#grad); 
 
    mask: url(#masker); 
 
}
<div> 
 
    <svg viewBox="0 0 500 300" preserveAspectRatio="none"> 
 
    <defs> 
 
     <linearGradient id="grad" gradientUnits="objectBoundingBox" gradientTransform="rotate(270,0.5,0.5)"> 
 
     <stop offset="0%" stop-color="rgba(198,83,165,.95)" /> 
 
     <stop offset="100%" stop-color="rgba(198,86,51,.95)" /> 
 
     </linearGradient> 
 
     <linearGradient id="mask-grad" gradientUnits="objectBoundingBox"> 
 
     <stop offset="40%" stop-color="black" /> 
 
     <stop offset="100%" stop-color="white" /> 
 
     </linearGradient> 
 
     <mask id="masker" x="0" y="0" width="500" height="300"> 
 
     <rect x="0" y="0" width="500" height="300" fill="url(#mask-grad)" /> 
 
     </mask> 
 
    </defs> 
 
    <rect x="0" y="0" width="500" height="300" class="grad-fill" /> 
 
    </svg> 
 
    <img src="http://lorempixel.com/500/300/animals/8" /> 
 
</div>

Potete trovare ulteriori informazioni su maschere SVG nel link qui sotto:


Questo può essere fatto anche con CSS puro ma sfortunatamente mask-image property is currently supported only by WebKit browsers e quindi questo approccio non è raccomandato.

div { 
 
    position: relative; 
 
    height: 300px; 
 
    width: 500px; 
 
    color: white; 
 
} 
 
div:after, 
 
img { 
 
    position: absolute; 
 
    height: 100%; 
 
    width: 100%; 
 
    top: 0px; 
 
    left: 0px; 
 
    z-index: -1; 
 
} 
 
div:after { 
 
    content: ''; 
 
    background-image: linear-gradient(0deg, rgba(198, 83, 165, .95) 0%, rgba(198, 86, 51, .95) 100%); 
 
    -webkit-mask-image: linear-gradient(90deg, transparent 40%, rgb(0, 0, 0) 100%); 
 
}
<div>Some text 
 
    <img src="http://lorempixel.com/500/300/animals/8" /> 
 
</div>

+1

Posso vedere il gradiente nell'ultimo snippet, ma non riesco a vedere 'Abcd'. Dove è andata? –

+1

Mi piace quando dici che qualcosa sarebbe quasi impossibile! – vals

+0

Bel tentativo @vals ma non penso che produca lo stesso effetto. Ma sì, con CSS e gradienti, quello è il più vicino che si possa ottenere. – Harry

1

È ancora possibile utilizzare il gradiente verticale per lo sfondo colorato, ma utilizzare la maschera png per lo sbiadimento.

Guardate questi esempi di utilizzo di maschere PNG: https://css-tricks.com/clipping-masking-css/

Il resto è abbastanza semplice.

5

Un modo per creare questo effetto con CSS puro è quello di giocare con più sfumature radiali, e con la trasparenza di ogni

dietro i gradienti radiali, che sono abbastanza trasparenti per consentire loro di sfumare tra di loro, c'è un gradiente lineare che fornisce opacità (in bianco) sul lato destro.

Se si desidera che questo sia più preciso, è possibile impostare più gradienti radiali, ciascuno dei quali copre una parte dell'immagine.

.test { 
 
    width: 500px; 
 
    height: 400px; 
 
    border: solid 1px green; 
 
    background: 
 
    radial-gradient(ellipse 70% 100% at top right, rgba(255,0,0,0.5), transparent), 
 
       radial-gradient(ellipse 70% 100% at bottom right, rgba(255,0,80,0.5), transparent), 
 
       linear-gradient(to left, white 20%, transparent); 
 
    background-size: 100% 80%, 100% 80%, 100% 100%; 
 
    background-position: top left, left 100%, top left; 
 
    background-repeat: no-repeat; 
 
} 
 

 
body { 
 
    background-image: url(http://lorempixel.com/500/400/nature); 
 
    background-repeat: no-repeat; 
 
    background-position: 8px 8px; 
 
}
<div class="test"></div>

0

Un altro modo potrebbe usare un PNG per il gradiente in uno sfondo con background-size: contain.

Vantaggio:

  • opere su tutti i browser (non < = IE8)

disagi:

  • hanno bisogno editor di immagini per modificare i colori
  • il PNG potrebbe essere pesante (dipende dalle sue dimensioni)
  • non si controlla molto bene il modo in cui il gradiente viene applicato

.test > div { 
 
    background: url(''); 
 
    background-size: contain; 
 
    width: 300px; 
 
    height: 150px; 
 
} 
 

 
.test p { 
 
    color: #fff; 
 
    font-weight: bold; 
 
    text-align: right; 
 
    margin: 10px; 
 
} 
 

 
.test { 
 
    width: 300px; 
 
    height: 150px; 
 
    background: url(http://lorempixel.com/300/150/nature) no-repeat; 
 
}
<div class="test"> 
 
    <div> 
 
    <p>Lorem ipsum</p> 
 
    </div> 
 
</div>

(sto usando un'immagine base64 immagine file PNG invece di non dover cercare un server , ma ovviamente funziona bene con un'immagine di file)