data:image/s3,"s3://crabby-images/7285a/7285abadf0af2dca25dc570244587012c79d8db2" alt="Preview"
Sometimes we face the requirement like how to show the image before image upload. There are some easy steps to preview images before upload.
- Create a blank page with two region. One for file browse option and second is sub-region for showing images.
data:image/s3,"s3://crabby-images/07522/0752275e2505d7a25d5872c800f50711cd80170f" alt=""
- Create a Page Item on change event dynamic action:
Event=>Change.
selection type=>button
Action=> Execute JavaScript Code
data:image/s3,"s3://crabby-images/8a09f/8a09fc6ffcf7a6f07bf1e197a9626c2131b64bbe" alt=""
- Copy and paste the following code on Execute JavaScript code and also define affected elements in this solution as per screenshot.
try {
var canvas = $x('image-preview');
var ctx = canvas.getContext('2d');
var img = new Image;
img.src = window.URL.createObjectURL(this.triggeringElement.files[0]);
img.onload = function() {
if (img.width > 200) {
canvas.style.width = "250px";
} else {
canvas.style.width = img.width + "px";
}
canvas.width = img.width;
canvas.height = img.height;
ctx.drawImage(img, 0, 0);
$("#container-img-preview").show();
}
} catch (e) {
console.log(e);
}
data:image/s3,"s3://crabby-images/29d6e/29d6efc2401170b582c5c92116e8af032546f94d" alt=""
- Copy and Paste below HTML code inside the second sub-region:
<canvas id="image-preview"
style="text-align: center;
margin-left: 100px;
margin-top: 30px;
border: 1px solid black;">
</canvas>
data:image/s3,"s3://crabby-images/a23d4/a23d49e632ef5eeee5744f8cd9df84fe6f628b77" alt=""
- Use below CSS for adjusting the height and width:
canvas#image-preview{
text-align: center;
margin-left: 100px;
margin-top: 30px;
border: 1px solid black;
width: 240px !important;
}
data:image/s3,"s3://crabby-images/10c06/10c0619275a531619a9cde5cdf1c3984d482f4fe" alt=""