I have an image of a bottle and try to fill this bottle with a certain color
I found the fill coordinates but the background inside the bottle is not filled
.item { width: 150px; height: 150px; } #tubeLiquid { background-color: #74ccf4; clip-path: polygon(45% 19%, 41% 22%, 41% 29%, 41% 36%, 41% 43%, 41% 50%, 41% 57%, 41% 63%, 41% 70%, 41% 77%, 41% 83%, 41% 90%, 43% 93%, 50% 92%, 56% 93%, 60% 88%, 59% 81%, 60% 75%, 60% 68%, 60% 61%, 59% 55%, 59% 48%, 59% 42%, 59% 35%, 59% 29%, 58% 23%, 54% 19%); } #bottleMask{ background-color: #FFFFFF; clip-path: polygon(45% 19%, 41% 22%, 41% 29%, 41% 36%, 41% 43%, 41% 50%, 41% 57%, 41% 63%, 41% 70%, 41% 77%, 41% 83%, 41% 90%, 43% 93%, 50% 92%, 56% 93%, 60% 88%, 59% 81%, 60% 75%, 60% 68%, 60% 61%, 59% 55%, 59% 48%, 59% 42%, 59% 35%, 59% 29%, 58% 23%, 54% 19%); }
<div class="item"> <svg viewBox="0 0 300 300"> <image width="300" clip-path="url(#bottleMask)" xlink:href="https://i.ibb.co/Mhfwtxp/image-removebg-preview-1.png" ></image> <defs> <mask id="bottleMask"></mask> </defs> <g id="maskedLiquid" mask="url(#bottleMask)"> <path id="tubeLiquid" fill="#74ccf4"></path> </g> </svg> </div>
You don't need the extra
.Due to the shape of the bottle, you can use the circle
as the clipping path:First draw the clipping path and fill scale/progress bar shape - without clipping anything - to find the correct coordinates and dimensions.
You can then apply a clipping path.
I used the
element for the "tubeLiquid" element because it allows us to set thepathLength
property to 100.We can easily change the current padding value by updating the
lines-dasharray
property:You will find many examples of using this method to implement various dynamic gauges/progress bars or animated pie charts , such as "Set svg progress bar percentage in JavaScript"
The closest solution I found was I didn't fill the whole bottle, but you just had to change some coordinates in the polygon, I don't know much about shapes and polygons.