Welcome!

Welcome to the official BlackBerry Support Community Forums.

This is your resource to discuss support topics with your peers, and learn from each other.

inside custom component

Web and WebWorks Development


Thank you for visiting the BlackBerry Support Community Forums.

BlackBerry will be closing the BlackBerry Support Community Forums Device Forums on April 1st (Developers, see below)

BlackBerry remains committed to providing excellent customer support to our customers. We are delighted to direct you to the CrackBerry Forums, a well-established and thorough support channel, for continued BlackBerry support. Please visit http://forums.crackberry.com or http://crackberry.com/ask. You can also continue to visit BlackBerry Support or the BlackBerry Knowledge Base for official support options available for your BlackBerry Smartphone.

"When we launched CrackBerry.com 10 years ago, we set out to make it a fun and useful destination where BlackBerry Smartphone owners could share their excitement and learn to unleash the full potential of their BlackBerry. A decade later, the CrackBerry community is as active and passionate as ever and I know our knowledgeable members and volunteers will be excited to welcome and assist more BlackBerry owners with their questions."

- Kevin Michaluk, Founder, CrackBerry.com

Developers, for more information about the BlackBerry Developer Community please review Join the Conversation on the BlackBerry Developer Community Forums found on Inside BlackBerry.


Reply
Highlighted
Developer
Posts: 116
Registered: ‎03-15-2011
My Device: Blackberry 9800
My Carrier: developer
Accepted Solution

Getting incorrect Base64 string of image from toDataURL() for the first time in blackberry 10 webworks

[ Edited ]

Hi,


I need to get Contact image converted to Base64 string using BB 10 Webworks (blackberry.pim.contacts) as I am only getting the contact.photos[0].smallFilePath which is returning the file path from the phonebook.

 

Now i want to get image from this path and convert it into Base64 string.

Below is the code of javascript:

 

var img = document.createElement('Image');
var canvas = document.createElement('Canvas');

 

function getBase64Image(p){
   img.setAttribute("src", p);

   canvas.width = img.width;

   canvas.height = img.height;

   var ctx = canvas.getContext("2d");
   ctx.drawImage(img, 0, 0);
   return canvas.toDataURL("image/jpg");

}

 

This is returning wrong Base64 string of image for the first time. When i convert this string to image it displays white screen. But returns perfect string at secong time and after conversion, displays correct image.

 

I am using Blackberry Z10(OS 10) for testing .

 

i think canvas is not drawing image properly for the first time.

I searched and tried a lot but didn't get success.What will be the solution.

 

Thanks in Advance.

Retired
Posts: 1,561
Registered: ‎04-12-2010
My Device: BlackBerry Z10
My Carrier: Bell

Re: Getting incorrect Base64 string of image from toDataURL() for the first time in blackberry 10 webworks

My guess is that the image hasn't loaded the source fully yet. Setting the src / loading the image is an asynchronous event, meaning your code will continue to the next line regardless of whether the image has loaded yet or not.

After you call setAttribute, instead of executing the canvas code, you will likely need to set an event listener on img for the load event. Once the image has loaded, you can then use the img variable with canvas to retrieve its data.

Note that getBase64 will return immediately, so you may need to either design some sort of wait mechanism before returning, or embrace the asynchronous approach and integrate callbacks for success to trigger the next piece of code.

Erik Oros | @WaterlooErik | eoros@blackberry.com | Developer Issue Tracker

If a reply has answered your question, please click Accept as Solution to help other visitors in the future.