I am working with angular on the web, and I have a component called 'sketch' where the editor is configured and working fine. I am comfortable getting converted text through the standard editor. I have the following set up:
this.editorElement.addEventListener("exported", (evt) => {
const exports = evt.detail.exports;
try {
// FIRE IF THERE IS CONTENT
if (exports["application/vnd.myscript.jiix"]) {
console.log(JSON.stringify(exports));
}
} catch {
console.log("nothing");
}
});
This fires when a change occurs. What I am looking to do is treat this as a file - I want to 'save' the sketch that is generated as a 'page,' and have a user come back and load the page later. For example, if I sketch something I am working on, this would save the sketch to a database, and I would be able to open it again later. I want the literal sketch, not the text.
1) How would I 'save' the sketch output so that I may re-open it later?
2) How do I configure the editor so that, on init, it has a sketch present that I had previously saved?
Thank you for any help on this!
Best Answer
G
Gwenaelle @MyScript
said
about 4 years ago
Hi Mason,
If you add the set the strokes configuration with following block within recognition parameter:
iink: {
export: {
jiix: {
strokes: true
}
}
you should be able to get the strokes information in the jiix exported result.
One first remark, please make sure to use our latest javascript library iinkJS.
There is currentley no API to save then re-open the page, so in order to achieve what you want, you have to write the corresponding code.
Here is the outline of what you could try:
export the JIIX file including the strokes information by setting the export.jiix.strokes configuration property to true.
save the JJIIX file
then use this file to parse the strokes information present into the JIIX file and transform them to pointer events to "feed" the editor. You can refer to following demo that shows how to feed the editor with pointer events. The corresponding code is here
Regards,
Gwenaëlle
M
Mason Secky-Koebel
said
about 4 years ago
Hi Gwenaëlle,
Thank you for your reply!
In the documentation, I do not see how to 'save' the jiix file for iinkJS (I see it covered for non-JS platforms). I have the configuration set up (your step 1).
How would I export/save the jiix information? Can I do this inside of the exported event?
Thanks again!
O
Olivier @MyScript
said
about 4 years ago
Dear Mason,
thank you for the update.
Currently, we do not have a save function. What Gwenaelle meant is that you shall first export as JIIX. When you have the JIIX, you can then store it by yourself (just create a small function to save it).
With the JIIX, you can then process it by yourself to get the stroke information.
In order to export as JIIX, you can refer to the following sample with source code:
How it is set up for me at the moment, I am getting the same result as the code you posted, but not the stroke information, or some array of pointer events. I am getting the text prediction object, but not this:
Maybe I am not supposed to get data in the form above? I do not see how to get the stroke information from the editor using iinkJS - just the prediction object. Saving would be perfect if I could somehow get this.
Thanks again for the help!
O
Olivier @MyScript
said
about 4 years ago
Dear Mason,
currently, the X and Y arrays correspond to the strokes. The following is a stroke, or pointer event:
Basically, the strokes you have are converted in milimeters, while you are providing coordinates in milimiters.
You can then use the above coordinates to redarw your ink.
Best regards,
Olivier
M
Mason Secky-Koebel
said
about 4 years ago
Hi Olivier,
I am sorry, I worded my response awkwardly. I am not getting that response, and am not sure how to. That is coming from the example that was provided. I am only able to get the converted text, not the stroke information.
How do I get that stroke information? Gwenaelle told me to export the JIIX file including the strokes information by setting the export.jiix.strokes configuration property to true, which I did, but how to get the stroke information is still a mystery.
Thanks!
G
Gwenaelle @MyScript
said
about 4 years ago
Answer
Hi Mason,
If you add the set the strokes configuration with following block within recognition parameter:
iink: {
export: {
jiix: {
strokes: true
}
}
you should be able to get the strokes information in the jiix exported result.
Oddly enough, as well as not exporting the jiix strokes information, in my editor, the smartGuide is also still enabled, meaning there must be a problem with the way the editor is being configured. Here is the export I get, for example:
Mason Secky-Koebel
Hello!
Brand new to the forum and myScript.js.
I am working with angular on the web, and I have a component called 'sketch' where the editor is configured and working fine. I am comfortable getting converted text through the standard editor. I have the following set up:
This fires when a change occurs. What I am looking to do is treat this as a file - I want to 'save' the sketch that is generated as a 'page,' and have a user come back and load the page later. For example, if I sketch something I am working on, this would save the sketch to a database, and I would be able to open it again later. I want the literal sketch, not the text.
1) How would I 'save' the sketch output so that I may re-open it later?
2) How do I configure the editor so that, on init, it has a sketch present that I had previously saved?
Thank you for any help on this!
Hi Mason,
If you add the set the strokes configuration with following block within recognition parameter:
you should be able to get the strokes information in the jiix exported result.
For instance, your exported JIIX could look like:
The strokes information are stored in the stroke items. For further details, please check this page: https://developer.myscript.com/docs/interactive-ink/1.4/reference/web/jiix/#stroke-item
Regards,
Gwenaëlle
- Oldest First
- Popular
- Newest First
Sorted by Oldest FirstGwenaelle @MyScript
Hello Mason,
Thank you for contacting us.
One first remark, please make sure to use our latest javascript library iinkJS.
There is currentley no API to save then re-open the page, so in order to achieve what you want, you have to write the corresponding code.
Here is the outline of what you could try:
export.jiix.strokes
configuration property to true.Regards,
Gwenaëlle
Mason Secky-Koebel
Hi Gwenaëlle,
Thank you for your reply!
In the documentation, I do not see how to 'save' the jiix file for iinkJS (I see it covered for non-JS platforms). I have the configuration set up (your step 1).
How would I export/save the jiix information? Can I do this inside of the exported event?
Thanks again!
Olivier @MyScript
Dear Mason,
thank you for the update.
Currently, we do not have a save function. What Gwenaelle meant is that you shall first export as JIIX. When you have the JIIX, you can then store it by yourself (just create a small function to save it).
With the JIIX, you can then process it by yourself to get the stroke information.
In order to export as JIIX, you can refer to the following sample with source code:
https://myscript.github.io/iinkJS/examples/non-version-specific/on_demand_exports.html
https://github.com/MyScript/iinkJS/blob/master/examples/non-version-specific/on_demand_exports.html
Best regards,
Olivier
Mason Secky-Koebel
Olivier,
How it is set up for me at the moment, I am getting the same result as the code you posted, but not the stroke information, or some array of pointer events. I am getting the text prediction object, but not this:
Maybe I am not supposed to get data in the form above? I do not see how to get the stroke information from the editor using iinkJS - just the prediction object. Saving would be perfect if I could somehow get this.
Thanks again for the help!
Olivier @MyScript
Dear Mason,
currently, the X and Y arrays correspond to the strokes. The following is a stroke, or pointer event:
Basically, the strokes you have are converted in milimeters, while you are providing coordinates in milimiters.
You can then use the above coordinates to redarw your ink.
Best regards,
Olivier
Mason Secky-Koebel
Hi Olivier,
I am sorry, I worded my response awkwardly. I am not getting that response, and am not sure how to. That is coming from the example that was provided. I am only able to get the converted text, not the stroke information.
How do I get that stroke information? Gwenaelle told me to export the JIIX file including the strokes information by setting the export.jiix.strokes configuration property to true, which I did, but how to get the stroke information is still a mystery.
Thanks!
Gwenaelle @MyScript
Hi Mason,
If you add the set the strokes configuration with following block within recognition parameter:
you should be able to get the strokes information in the jiix exported result.
For instance, your exported JIIX could look like:
The strokes information are stored in the stroke items. For further details, please check this page: https://developer.myscript.com/docs/interactive-ink/1.4/reference/web/jiix/#stroke-item
Regards,
Gwenaëlle
Mason Secky-Koebel
Gwenaëlle,
Here is my configuration:
Oddly enough, as well as not exporting the jiix strokes information, in my editor, the smartGuide is also still enabled, meaning there must be a problem with the way the editor is being configured. Here is the export I get, for example:
Do you see any issue with my configuration?
Thanks again!
Gwenaelle @MyScript
Mason,
Yes the iink block should be within the recognitionParams block. For instance:
Gwenaëlle
1 person likes this
Mason Secky-Koebel
Yes! That did it, so sorry this issue was so basic, but thank you for the help!
Gwenaelle @MyScript
Thanks for your update. We are glad you've fixed your issue.
Gwenaëlle