How to Show the Only Part of the Image

How can I display just a portion of an image in HTML/CSS?

One way to do it is to set the image you want to display as a background in a container (td, div, span etc) and then adjust background-position to get the sprite you want.

How to show the only part of the image

Here is a working example: https://snack.expo.io/@zvona/cropped-image

The idea is to have "cropped" View where Image is positioned inside it with custom dimensions. I use constants in my example to clarify the case.

<View style={styles.cropped}>
<Image
style={styles.image}
source={{uri: 'https://upload.wikimedia.org/wikipedia/en/0/02/Homer_Simpson_2006.png'}} />
</View>

And on styles:

  image: {
marginLeft: -OFFSET_LEFT,
marginTop: -OFFSET_TOP,
width: IMAGE_WIDTH,
height: IMAGE_HEIGHT,
},

cropped: {
width: 150,
height: 150,
overflow: 'hidden',
position: 'absolute',
left: OFFSET_LEFT,
top: OFFSET_TOP,
},

Note that ImageBackground is only for example purposes and it's not needed in the actual implementation.

How to show only a portion of an image just by using the img tag?

Final Update--tested IE8+: This solution uses a refinement of Surreal Dreams' idea of using outline for getting the border. This allows a cross browser simplicity compared to the linear-gradient method I was previously going for. It works in IE7, except the outline (unsupported).

Keeping it as an img tag with a src keeps it semantic.

A margin: 1px is applied to give the outline "space" in the layout, since by nature outline takes up no space. The zero height suppresses the main image, and the padding is used create the desired height for the background image (which is set the same as the main image) to show.

HTML

<img class="photo" src="foo.png" style="background-image: url(foo.png)" />

CSS

.photo {
padding: 64px 0 0 0;
border: 3px solid #fff;
outline: 1px solid #000;
margin: 1px;
width: 64px;
height: 0px;
display: block;
}

How to show only part of an image as the background

Instead of applying the background directly on the label, create a pseudo element, size it to the dimensions of the image in your sprite and apply your background to it instead.

input[type="checkbox"]:not(old)+label{    box-sizing:border-box;    height:25px;}input[type="checkbox"]:not(old)+label::before{    background: url(http://cdn.sstatic.net/Sites/stackoverflow/../../img/share-sprite-new.svg?v=78be252218f3) no-repeat -220px -54px;    content:"";    display:inline-block;    margin-right:10px;    height:25px;    vertical-align:bottom;    width:25px;}
<input type="checkbox"><label>Some random text</label>

Showing only a part of image in div using css

Use position: relative on the parent element and position: absolute on the child images.

#sample {
width: 200px;
height: 200px;
overflow: hidden;
position: relative;
border: 1px solid black;
}

#sample img {
position: absolute;
top: -100px;
left: -100px;
}
<div id="sample">
<img src=""
/>
</div>

Fabricjs: how to display only a part of image?

Have you tried cropX/cropY? Combine them with setting width and height:

const canvas = new fabric.Canvas('c')const url = 'https://i.stack.imgur.com/qVhbV.jpg'const imgEl = document.createElement('img')imgEl.src = urlimgEl.onload = () => {  const img = new fabric.Image(imgEl)  img.set({    cropX: 70,    cropY: 140,    width: 200,    height: 150,  })  canvas.add(img)}
<script src="https://cdnjs.cloudflare.com/ajax/libs/fabric.js/3.6.2/fabric.min.js"></script><canvas id="c" width="300" height="200"></canvas>

How to show only the top portion of an image with CSS?

http://jsfiddle.net/3mRh9/1/

Add display: block to your .limited style.

.limited {
width: 115px;
height: 115px;
overflow: hidden;
border: 1px solid red;
display: block;
}

<a> tags are inline by default, and inline elements cannot have width or height.

Alternatively, you could just wrap with a block-level element, like a div, instead (fiddle):

<div>
<div class="floated">
<div class="limited">
<a href="http://example.com">
<img src="http://change.gov/page/-/officialportrait.jpg"/>
</a>
</div>
</div>
</div>

Css Displaying only center part of image

You can set the image as the bg of an element, and then something like this:

        div {            background: #eee url(http://www.google.co.cr/logos/classicplus.png) center center;            width: 100px;            height:100px;            border: 1px solid red;            text-indent: -9999px;        }
<img src="http://www.google.co.cr/logos/classicplus.png"><div>some text that won't be seen</div>


Related Topics



Leave a reply



Submit