I tried my hardest to figure this out with pure css. Though the problem with css I could not figure out how to calculate the diameter of the circle based on the content div size; the length from top left corner to bottom right corner of the variable height div.
I’m not sure if can be done using the calc() css function.
But I did manage to do it with a little jquery (which could easily be changed to pure javascript if you are not using jquery).
See working resizable example below (follow my comments in code)
Note: If you are using internet explorer the resizable demo content div will not resize.
// circumscriber for variable size divs
function circumscriber() {
// for each variable size div on page
$(".variable-size").each(function() {
// get the variable size div content width and height
let width = $(this).outerWidth();
let height = $(this).outerHeight();
// get the diameter for our pefect circle based on content size
let diameter = Math.sqrt(width ** 2 + height ** 2);
// extra 15 pixel circle edge around variable size div
let edge = 15;
// add current circle size width css
$('.circle', this).css({
'width': (diameter + (edge * 2)) + 'px'
})
});
}
// run the circumscriber (you might wana do this on ready)
circumscriber();
// if the window is resized responsively
$(window).on('resize', function() {
circumscriber();
});
// for demo purpose to fire circumscriber when resizing content
// not needed for real thing
$('.content').on('input', function() {
this.style.height = "";
this.style.height = ( this.scrollHeight - 30 ) + "px";
circumscriber();
}).on('mouseup', function() {
circumscriber();
});
/* variable size container to be circumscribed by circle */
/* none of these styles are required, this just to center the variable size div in the window for demo purposes */
.variable-size {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
/* resizable text area for demo */
/* again not needed */
.variable-size .content {
padding: 15px;
background: #fff;
resize: both;
overflow: auto;
color: #000;
border: none;
width: 200px;
font-weight: bold;
}
.variable-size .content:focus {
outline: 0;
}
/* child circle div css */
.variable-size .circle {
position: absolute;
background-image: url('https://i.imgur.com/2dxaFs9_d.webp?maxwidth=640&shape=thumb&fidelity=medium');
background-position: center center;
z-index: -1;
border-radius: 50%;
left: 50%;
top: 50%;
transform: translate(-50%, -50%);
transition: all 0.5s ease;
width: 0;
}
/* fast way to make circle height the same as current width */
.variable-size .circle:before {
display: block;
content: '';
width: 100%;
padding-top: 100%;
}
/* demo window css */
HTML,
BODY {
height: 100%;
min-height: 100%;
background: black;
position: relative;
font-family: "Lucida Console", Courier, monospace;
}
<div class="variable-size">
<textarea class="content" rows="1" placeholder="TYPE TEXT OR RESIZE ME ↘"></textarea>
<div class="circle"></div>
</div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="square">
<div class="emptyDiv"></div>
<div class="content">
Hello!<br>
<br><br><br>This has a variable height but fixed width<br><br><br>Hello
</div>
<div class="emptyDiv"></div>
</div>
Problem :
I’ve looked into this a fair bit but can’t seem to find a good, solid answer to find how to make a responsive circle around a div element of variable height.
It’s easy to make a simple responsive circle using vw units.
<div style="height:20vw; width:20vw"></div>
However, I’m looking to use a min-height of an element and have a circle around this div.
Another way to create a responsive circle is using something like the snippet below, but again I can’t adapt this to work for a variable height (again, I can’t use vh units as the div will change in height.
I am trying to create something like the below, where the circle will never cut into the corners of the div (with around a 10px padding). I personally was trying to avoid javascript and would have preferred a css only approach, but it seems it’s unavoidable. Maybe the only solution is to use a jquery to calculate the height of the element in order to apply this to a wrapper element?
<div class="square">
<div class="content">
Hello!<br>
<br><br><br>This has a variable height but fixed width<br><br><br>Hello
</div>
</div>
Comments
Comment posted by stackoverflow.com/questions/41855730/…
Related
Comment posted by this
Hey @Paulie_D I saw that one but doesn’t like the multi-line aspect. Closest I’ve got to is
Comment posted by iguypouf
But I thought you want a solution without javascript ? If you accept javascript this is really not hard to achieve because you can calculate the diagonale of your content box divide by 2, add the padding you want, and this is the radius of your circle. Apply it in both size.
Comment posted by jbutler483
I would prefer to use CSS only but it seems js is the only option here (despite the power of CSS functionality)
Comment posted by jbutler483
Cheers Temani. I’ll check browser support but this looks to be very close to desired effect and could probably work it out from this. Thanks again.
Comment posted by Den Kerny
lets say we need to add border to circle..how to make this works?
Comment posted by Temani Afif
@DenKerny the first or last example?
Comment posted by jsfiddle.net/854u6or9
@DenKerny try this:
Comment posted by jbutler483
Not too sure how canvas can achieve this.
Comment posted by jbutler483
flex-basis
Comment posted by Sean
This creates an ellipse, not a circle.
Comment posted by alchemist95
You could use width instead of flex-basis
Comment posted by alchemist95
But correct, it’s not a circle. Let me try something else