I need to crop the following image to the image after that.
Should be available on a website. (So no psd etc).
I tried with the clip-path tool but it doesn't seem to work properly.
So Maybe i need to use a tool, or there is a way with clip-path, Please let me know.
Here is the original image:
And here's the image it should be (there should on be 1 edge. so it's not quite this picture:
Thanks in advance.
Since I don't see any complex shape involved, this can be easily achieved through tweaking border-radius property of the image.
.image{
transform: rotate(-135deg);
height: 250px;
width: 250px;
margin-top: -5px;
margin-left: -35px;
}
.container{
height: 200px;
width: 200px;
border-radius: 50% 50% 50% 0;
overflow: hidden;
}
<div>
<img src="">
</div>
<p>Initial Image</p>
<div class="container">
<img src="" class="image">
</div>
<p>Final Image</p>
You can refer the snippet. However, if you wish to use clip-mask it would be easier to use it with an SVG-defined . Refer this for further reading.
EDIT: As pointed out by #fepegar With rotations other than multiples of 90 degree it does become a little trickier. If the image is to be cropped, then with certain changes in the margins of the image we can achieve the required output.
However, this is not highly effective in responsive environment.
Related
I am trying to achieve the following design:
https://imgur.com/a/iXhOTfR
My problem is that I don't want to use a png image as it is too large. Is there another way of achieving the cut image effect?
I am using a SVG file for the left blue part. This is what I achieved so far: https://imgur.com/a/bZSjOUH
Here is my HTML:
<section class="section">
<div class="section-mask">
SVG FILE
</div>
<div class="container-full">
<div class="row">
<div class="col-lg-6 column-text">
<h2 class="title">
Section Title
</h2>
<div class="paragraph">
Section Content
</div>
</div>
<div class="col-lg-6 column">
Section Widget
</div>
</div>
</div>
</section>
If I understand you correctly, you want to achieve something like multiple angled cuts with varying images and background colors. You can do this with something like the following, tailoring it to your needs, and through experimentation swap in different solutions but using the same basic tools.
These tools largely comprise:
clip-path, &
linear-gradient
This solution will provide a close match to the effect, but adapt to the users viewport. But in adapting, be aware that angles will necessarily change (but it should feel natural and fluid, unlike a fixed image that scales and feels unnatural as the viewport changes).
Clip path can be used to give shape to an element, and while the logic for "drawing" the desired shape can be tricky, Bennett Feely has a great tool called Clippy to work out the code.
Here's the 'cut design' demo on CodePen, and I'll include the working code here, as well, with a brief explanation.
The HTML is written assuming that this is part of a visual treatment for a page header, but adapt as needed. The CSS is a quick and dirty mock-up with clip-path arranged in a way to make the number pairs easy to scan and adjust at a glance:
header {
background-image: url(//unsplash.it/1600x900);
background-size: cover;
}
.cut-container {
background-image: linear-gradient(80deg, hsla(180, 100%, 40%, .5) 44.9%, white 45.1%);
}
.cut {
background: url(//unsplash.it/1600x600) center center;
background-size: cover;
clip-path: polygon(
0 0,
100% 0,
100% 70%,
0 100%
);
height: 20em;
}
.cut2 {
background: hsl(220,50%,30%);
clip-path: polygon(
50% 95%,
100% 25%,
100% 100%,
0 100%,
0 25%);
height: 15em;
}
<header>
<div class="cut-container">
<div class="cut"></div>
<div class="cut2"></div>
</div>
</header>
Clip-path is here used to make a polygon, and the number pairs indicate where to position the corners. Each pair corresponds to the number of angles in the shape, so one is a trapezoid, and the other is essentially an odd pentagon in a sort of M shape.
The middle bit is achieved with a hard linear-gradient over a background image. This is all done with random images drawn from the Unsplash API, but you could do something with background position, for example, and use whatever images you're working with in appropriate sizes and eliminate the large bandwidth issues in this rough demo.
Finally, note that for an angled linear-gradient with a sharp cut, most monitors will produce a jagged edge. To effect anti-aliasing and the appearance of a smooth edge, use values that are close but not exact. Here, .cut-containeruses 44.9% and 45.1%, which looks smooth.
With a little more work and appropriately sized images, you can use some of these techniques to build the kind of design you're after with pure CSS and without complex transforms or images that don't adapt to viewport. The support isn't bad on this for modern browser, and those that lack support will ignore the clip-path and fall back to solid blocks, which I really believe is better than fighting through a complex solution for a cosmetic effect, or making high rendering demands of older browsers.
How about making a rotated css block that overlays the image while staying below the svg?
body {
overflow-x: hidden;
}
.image {
background: grey;
width: 100%;
height: 100px;
}
.cut {
border: 1px solid red;
width: 200%;
height: 150px;
transform: rotate(-5deg);
background: white;
padding: 50px;
transform-origin: 0% 50%;
position: absolute;
}
.svg {
border: 1px solid green;
position: relative;
z-index: 1;
}
<div class="image">This would be the image</div>
<div class="cut">This is the CSS block</div>
<div class="svg">This would be the SVG</div>
I've been given a design to develop and the design uses numerous circular layout items and I'm a little unsure how to go about this, I've tried using SVGs, PNGs etc but it's not playing ball.
For example, this section of the design looks like this
But when I try using an SVG, I end up with this
That ^ show a section with a grey background and above is an SVG which has a grey bottom and green line through it, I've tried using an SVG which is white on the top, grey on the bottom and has that green line through the middle, but when I try to replicate the design I run into the problem that SVG doesn't have the image so it cuts off as you can see. Here is an example of my code:
HTML:
<img src="img/line-05.svg" class="svg" />
<section class="bgYellowGrey">
<div class="column two">
<div class="numWrapper"><p class="number">2</p></div>
<h2>Title</h2>
<h3>Subtitle</h3>
<p>Paragraph text</p>
</div>
<div class="column two">
<img id="image-03" src="img/third-image.png" />
</div>
</section>
CSS (of which is relevant):
section{
position: relative;
float: left;
}
.column{
float: left;
}
.two{
padding: 10px 2%;
width: 46%;
}
#image-03{
margin-top: -150px;
}
.svg{
position: relative;
width: 100%;
z-index: 99999;
}
The SVG in question is this (screenshot from illustrator):
The design is totally based around this layout unfortunately. Is there any other convention or simple method of doing replicating the design? I guess I just need to find a way to clip into a div/svg? Any help would be appreciated.
This may be hard to explain but do tell me to explain further on bits and I shall.
Okay, this seems to be an issue with so many potential solutions but none that will work for what I want to do. I always want to display perfect circles, even if the underlying image is not a perfect circle. But, I don't want to specify an image dimension by px because I want it to be responsive. It seems that no matter which solution I try, the circles always either become warped into ovals or the picture dimensions completely take over and make it gigantic.
HTML:
<div class='item-image'>
<img class='img-circle img-responsive img-center' src='#' />
</div>
Goal:
Regardless of the image size (rectangles), I want the part of the image beneath the red circle to show through.
The best way to do this is per overlay. And make the circle with CSS!
<div class="wrapper">
<img src="#" class="img-responsive">
<div class="circle"></div>
</div>
.wrapper has position: relative and .circle has position: absolute and border-radius: 100%.
The wrapper has to be positioned with inline-block. Center the wrapper with text-align: center.
Center an absolute positioned element as follows:
.el {
position: absolute;
top: 50%;
margin-top: -(height / 2)%;
left: 50%;
margin-left: -(width / 2)%;
}
If you want the image inside the circle, make the circle bigger.
Example
HTML:
<div class="circle">
</div>
and use css for image in background:
.circle{
border: 2px solid red;
width: 200px;
height: 200px;
border-radius:100%;
background-image: url('')
}
check the fiddle
I am currently trying to use svg files instead of images for modern browsers on a new fluid site. The idea is to use an SVG as a background image on a fluid div which can then be changed on hover and we can use modernizer (or similar) to fallback to the use of img backgrounds for unsupported browsers.
In theory this is all fine however on certain browsers (particularly Firefox) the right and bottom edges of the svgs have some strange pixelation at certain sizes which doesn't happen for imgs.
So if you view http://jsfiddle.net/deshg/xuq6812g/ you can see a grid of 4 x 25% columns each with a div or img (that is 100% width). Each one has either a div with svg or img background or an img element with the svg/img as the src. If you view this in FF and make it bigger/smaller you'll see at certain sizes the degradation i'm talking about. You can also see this in the image below (the areas circled in blue are the degraded bits which you can see occurs on the svg but not the img).
Can anyone shed some light on why this is happening and how to prevent it as it makes SVGs largely unusable in this way if it can't be fixed
CSS
body, html {
height: 100%;
}
body {
margin: 0;
padding: 0;
}
.container {
float: left;
width: 25%;
height: 100%;
}
.container img {
width: 100%;
}
.container div {
background-size: cover;
width: 100%;
padding-top: 100%;
}
HTML
<div class="container">
BACKGROUND SVG:<br>
<div style="background-image: url('https://dl.dropboxusercontent.com/s/rga8anccnpyublh/svg.svg');">
</div>
</div>
<div class="container">
BACKGROUND IMG:<br>
<div style="background-image: url('https://dl.dropboxusercontent.com/s/rb1u7l90q9ny8bh/img.png');">
</div>
</div>
<div class="container">
SVG IN IMG TAG:<br>
<img src="https://dl.dropboxusercontent.com/s/rga8anccnpyublh/svg.svg" alt="">
</div>
<div class="container">
IMG IN IMG TAG:<br>
<img src="https://dl.dropboxusercontent.com/s/rb1u7l90q9ny8bh/img.png" alt="">
</div>
From working with vector images for years and years, when you crop them accurately, yet they need aliasing, then the crop looks odd -- flattened at the curves. So circles, text, logos, and so forth need some extra edge in the view box. Here I've add a lot more, but you get the idea.
DEMO with before and after: http://jsbin.com/buquw/1/edit
ORIGINAL -- cropped accurately, but too close, because this image needs aliasing.
NEW VERSION -- you don't need this much, used to exaggerate the situation:
I am trying to resize an image with a percentage of itself. For example, I just want to shrink the image by half by resizing it to 50%. But applying width: 50%; will resize the image to be 50% of the container element (the parent element which maybe the <body> for example).
Question is, can I resize the image with a percentage of itself without using JavaScript or server side? (I have no direct information of the image size)
I am pretty sure you cannot do this, but I just want to see whether there are intelligent CSS only solution. Thanks!
I have 2 methods for you.
Method 1.
This method resize image only visual not it actual dimensions in DOM, and visual state after resize centered in middle of original size.
img {
transform: scale(0.5);
}
<img src="https://via.placeholder.com/300x200" />
Browser support note: browsers statistics showed inline in css.
Method 2.
#wrap {
overflow: hidden;
position: relative;
float: left;
}
#wrap img.fake {
float: left;
visibility: hidden;
width: auto;
}
#img_wrap {
position: absolute;
top: 0;
right: 0;
bottom: 0;
left: 0;
}
#img_wrap img.normal {
width: 50%;
}
<div id="wrap">
<img class="fake" src="https://via.placeholder.com/300x200" />
<div id="img_wrap">
<img class="normal" src="https://via.placeholder.com/300x200/cccccc" />
</div>
</div>
Note: img.normal and img.fake is the same image.
Browser support note: This method will work in all browsers, because all browsers support css properties used in method.
The method works in this way:
#wrap and #wrap img.fake have flow
#wrap has overflow: hidden so that its dimensions are identical to inner image (img.fake)
img.fake is the only element inside #wrap without absolute positioning so that it doesn't break the second step
#img_wrap has absolute positioning inside #wrap and extends in size to the entire element (#wrap)
The result of the fourth step is that #img_wrap has the same dimensions as the image.
By setting width: 50% on img.normal, its size is 50% of #img_wrap, and therefore 50% of the original image size.
This has got to be one of the simplest solutions using the container element approach.
When using the container element approach, this question is a variation of this question. The trick is to let the container element shrinkwrap the child image, so it will have a size equal to that of the unsized image. Thus, when setting width property of the image as a percentage value, the image is scaled relative to its original scale.
Some of the other shrinkwrapping-enabling properties and property values are: float: left/right, position: fixed and min/max-width, as mentioned in the linked question. Each has its own side-effects, but display: inline-block would be a safer choice. Matt has mentioned float: left/right in his answer, but he wrongly attributed it to overflow: hidden.
span {
display: inline-block;
}
img {
width: 50%;
}
<span>
<img src="https://via.placeholder.com/300x200"/>
</span>
Edit: As mentioned by trojan, you can also take advantage of the newly introduced CSS3 intrinsic & extrinsic sizing module:
figure {
width: intrinsic;
}
img {
width: 50%;
}
<figure>
<img src="https://via.placeholder.com/300x200" />
</figure>
However, not all popular browser versions support it at the time of writing.
Scale the image:
img {
transform: scale(0.5);
}
<img src="https://via.placeholder.com/300x200" />
Another solution is to use:
<img srcset="example.png 2x">
It won't validate because the src attribute is required, but it works (except on any version of IE because srcset is not supported).
This is a very old thread but I found it while searching for a simple solution to display retina (high res) screen capture on standard resolution display.
So there is an HTML only solution for modern browsers :
<img srcset="image.jpg 100w" sizes="50px" src="image.jpg"/>
This is telling the browser that the image is twice the dimension of it intended display size. The value are proportional and do not need to reflect the actual size of the image. One can use 2w 1px as well to achieve the same effect. The src attribute is only used by legacy browsers.
The nice effect of it is that it display the same size on retina or standard display, shrinking on the latter.
This actually is possible, and I discovered how quite by accident while designing my first large-scale responsive design site.
The overflow:hidden gives the wrapper height and width, despite the floating contents, without using the clearfix hack. You can then position your content using margins. You can even make the wrapper div an inline-block.
.wrapper {
position: relative;
overflow: hidden;
}
.box {
float: left; /* Note: 'float:right' would work too */
}
.box>img {
width: 50%;
}
<div class="wrapper">
<div class="box">
<img src="https://via.placeholder.com/300x200" alt="">
</div>
</div>
function shrinkImage(idOrClass, className, percentShrinkage){
'use strict';
$(idOrClass+className).each(function(){
var shrunkenWidth=this.naturalWidth;
var shrunkenHeight=this.naturalHeight;
$(this).height(shrunkenWidth*percentShrinkage);
$(this).height(shrunkenHeight*percentShrinkage);
});
};
$(document).ready(function(){
'use strict';
shrinkImage(".","anyClass",.5); //CHANGE THE VALUES HERE ONLY.
});
This solution uses js and jquery and resizes based only on the image properties and not on the parent. It can resize a single image or a group based using class and id parameters.
for more, go here: https://gist.github.com/jennyvallon/eca68dc78c3f257c5df5
I think you are right, it's just not possible with pure CSS as far as I know (not cross-browser I mean).
Ok I didn't like my answer very much so I puzzled a little. I might have found an interesting idea which could help out.. maybe it IS possible after all (although not the prettiest thing ever):
Tested and working in Chrome, FF and IE 8&9. It doesn't work in IE7.
#img_wrap {
display: inline-block;
position: relative;
}
#rescaled_img_wrap {
width: 50%;
}
#original_img {
display: none;
}
#rescaled_img {
width: 100%;
height: 100%;
}
<div id="img_wrap">
<img id="original_img" src="https://via.placeholder.com/300x200" />
<div id="rescaled_img_wrap">
<img id="rescaled_img" src="https://via.placeholder.com/300x200/dddddd" />
</div>
</div>
This is a not-hard approach:
div {
position: absolute;
}
img,
div {
width: ##%;
height: ##%;
}
<div>
<img src="https://via.placeholder.com/300x200" />
</div>
Although it does not answer the question directly, one way to scale images is relative to the size (especially width) of the viewport, which is mostly the use case for responsive design. No wrapper elements needed.
img {
width: 50vw;
}
<img src="https://via.placeholder.com/300x200" />