Editable Image Region

Editable Image Region - Messages

#61 Posted: 2/3/2016 1:25:05 PM
Davide Carpi

Davide Carpi

1,434 likes in 2,910 posts.

Group: Moderator

Wrote

Davide, do you think there is a conceptual way to change the name of the imbedded image during copy / paste? I cannot think of one.



Hello Alex,

the simplest thing that I can think is to use a random temporary directory for each region or a random file name for each region; in both the cases the name can be randomly generated the first time you need to edit the file, and kept until the SMath session ends. In both the cases copy/paste and clone are not involved since the values can be generated on the fly at the first use in the class.

if (String.IsNullOrEmpty(tempPath))
{
   tempPath = ...;
}
// launch the image editor for the image stored in the tempPath

Using a random filename you can keep in memory only the extension of the file; using a random directory you can keep the original filename.


Wrote

Will try :-) update / resize functions are used throughout the code and it will take some effort to seprate the two (i.e. resize without re-rendering of svg, unless certain condition). It should be possible, the question is whether I will be succesful at it.


Use RequestEvaluation() only if you need to get data from the canvas or push data into the canvas; to update the drawings in your methods you can use PrePainter() and Invalidate() (prepainter if change in the sizes is involved). When the resize marks are used, you can deal with Resize().
If you like my plugins please consider to support the program buying a license; for personal contributions to me: paypal.me/dcprojects
#62 Posted: 2/3/2016 2:48:09 PM
vldmrrr

vldmrrr

0 likes in 2 posts.

Group: User

Wrote

Also I am getting close to the point where I wanted to be for the Image Region development (once I take care of the above, if it proves to be possible / necessary). Do you guys have any major griefs with it, or suggestions? Otherwise I wil wrap it up and publish to the extensions manager.



I am not sure if this counts as major grief, but here is screenshot where displayed stroke style is different from what was intended in inksape.

Capture.PNG
#63 Posted: 2/4/2016 12:54:57 AM
Jean Giraud

Jean Giraud

983 likes in 6,866 posts.

Group: User

Wrote

I am not sure if this counts as major grief, but here is screenshot where displayed stroke style is different from what was intended in inksape.

.

____________________ certainly very annoying:

... missing closure in Inkscape ? ... problem saving from Inkscape ?
... Smath not reading correct ? [doubtful]

Read more: once the object is imported in the image region,
"Reset to original size" ... stretch the right handle to create space.
At this point, if you want to zomm ± : move the bottom handle up/down,
that procedure will respect the "Aspect ratio". I have checked the Smath
image zoom with IrfanView: for photos they are ~ equal quality.

The last brick in the wall about editable region(s) is the "Formatted Label".
Possibly useful for collecting functions of same family, vg: PDF, CDF ...

Jean

Formatted Label Styles.bmp
#64 Posted: 2/4/2016 4:43:33 AM
Alexander O. Melnik

Alexander O. Melnik

127 likes in 498 posts.

Group: Moderator

This release addresses all the issues below.
Not resolved:
1. Rendering of inkscape arrows. Even though I am using new SVG renderer, the arrow is still off - now it is reversed. On a plus side - arrow on the left end of line points correctly - use that one.
2. image border on init - proved to be much trouble for the amount of benefit.


Otherwise it is smooth sailing so far. All that is left from what I would like to implement is two new formats: .psd (work with layers) and .dxf (hugely beneficial from engineering perspective).

Cheers all!

ImageRegion.007.zip (188.58 KiB) downloaded 207 time(s).

Wrote

Hi All, I probably wont get to work on the image region till weekend, however it is a good idea to think of a roadmap. Martin, to discuss your comments:



I have done this - found no file found error annoying as well after some use (new .dll is not included yet).

<1. Insert Image
2. try to switch off the image border in the context menu.
this does not work for me, the border is still displayed.>

Unless I am wrong, this is how original image region behaved (I just redownloaded it), do we want to change that?



I am at the stand still here. The plugin only zooms SVG files if no height/width is present inside the file, or if it is set to % (as I did for blank svg). For either of those cases, when inkscape re-opens the svg, the "3D Box" objects were minimized to the bottom left corner (you still can scale them up if desired). If someone can come up with .svg file that both scales in SMath, and is saved/opened correctly by inkscpe I can use it as a blank document in the plugin. It is not a big deal for me though - how often will you sketch those 3D boxes in SMath?



This one is tricky. While there is no intent, per say, I am not sure how to change it either. You see, I can define Clone () though the code, while copy/paste just takes the region and creates the exact duplicate (just like Davide mentioned). And while you can edit the formula you copy/pasted, you cannot redefine the filename of the image in the region from SMath. Davide, do you think there is a conceptual way to change the name of the imbedded image during copy / paste? I cannot think of one..



Will try :-) update / resize functions are used throughout the code and it will take some effort to seprate the two (i.e. resize without re-rendering of svg, unless certain condition). It should be possible, the question is whether I will be succesful at it.



#65 Posted: 2/4/2016 6:40:31 AM
Martin Kraska

Martin Kraska

1,285 likes in 2,205 posts.

Group: Moderator

Wrote

This release addresses all the issues below.
Not resolved:
1. Rendering of inkscape arrows. Even though I am using new SVG renderer, the arrow is still off - now it is reversed. On a plus side - arrow on the left end of line points correctly - use that one.
2. image border on init - proved to be much trouble for the amount of benefit.


Otherwise it is smooth sailing so far. All that is left from what I would like to implement is two new formats: .psd (work with layers) and .dxf (hugely beneficial from engineering perspective).

Cheers all!



Great work, Alex. Even the 3D-shape problem has been resolved.

I've got a question related to SVG page size and image size.

In order to keep line thickness, arrow sizes, symbols and the like consistent in a document, I would like to be able to reset the zoom level of an svg image to that one which is used upon init of a new region.

For png, this is done by "reset to original size", for svg this does not work.
So far, the only option to keep the scale consistent, is to always use new image regions (not copies or clones) for new images and to never resize them.

I guess that the svg images somehow maintain a record of their page size, otherwise it would not be known to inkscape. Could that be used to resize the image region to the original scale?

How do you handle this issue?


Martin KraskaPre-configured portable distribution of SMath Studio: https://en.smath.info/wiki/SMath%20with%20Plugins.ashx
#66 Posted: 2/4/2016 12:12:49 PM
Alexander O. Melnik

Alexander O. Melnik

127 likes in 498 posts.

Group: Moderator

Wrote

Wrote

This release addresses all the issues below.
Not resolved:
1. Rendering of inkscape arrows. Even though I am using new SVG renderer, the arrow is still off - now it is reversed. On a plus side - arrow on the left end of line points correctly - use that one.
2. image border on init - proved to be much trouble for the amount of benefit.


Otherwise it is smooth sailing so far. All that is left from what I would like to implement is two new formats: .psd (work with layers) and .dxf (hugely beneficial from engineering perspective).

Cheers all!




I guess that the svg images somehow maintain a record of their page size, otherwise it would not be known to inkscape. Could that be used to resize the image region to the original scale?





This was fixed in the attached. Keep in mind that re-rendering of SVG only on click or evaluation is not a bug - it speeds up resizing


Davide, thank you for the pointers - really helped. Few more questions for you:

1. In SMath release manager, how do I build / publish a project that was not created by me?

2. I have added another dependency to the project (better SVG render engine), how do I add it in the SVN repo, which file do I modify?

3. Adding better svg rendering engine required me to build for .NET 3.5; how to I change it by hand in the SVN repo?

Also no go on DXF - no engine that can render that in .NET; a pity. So I will add .psd support and publish the plugin. I need .psd to simplify stetching on top of existing blueprints / drawings - one layer - existing drawing, another - my freehand stuff.


ImageRegion.008.zip (188.7 KiB) downloaded 205 time(s).
1 users liked this post
Martin Kraska 2/4/2016 12:34:00 PM
#67 Posted: 2/4/2016 12:33:39 PM
Martin Kraska

Martin Kraska

1,285 likes in 2,205 posts.

Group: Moderator

Wrote

Wrote




I guess that the svg images somehow maintain a record of their page size, otherwise it would not be known to inkscape. Could that be used to resize the image region to the original scale?





This was fixed in the attached. Keep in mind that re-rendering of SVG only on click or evaluation is not a bug - it speeds up resizing



Thanks again for the update. Now it is possible to restore the region size of svg images after changing it in SMath.

But if the paper size is changed in Inkscape, the region doesn't recognize this. At least you can't reset it to a size reflecting the changed values.

Maybe, it is an option, to change the paper size in inkscape to the actual region size whenever inkscape is called? Don't know what side effects this might have but changing the papersize in inkscape seems to be cumbersome and the proposed procedure would be very easy to handle. You would always see in inkscape, what the original size of your region would be.

Martin KraskaPre-configured portable distribution of SMath Studio: https://en.smath.info/wiki/SMath%20with%20Plugins.ashx
#68 Posted: 2/4/2016 1:09:14 PM
Davide Carpi

Davide Carpi

1,434 likes in 2,910 posts.

Group: Moderator

Wrote

Davide, thank you for the pointers - really helped.


You're welcome

Wrote

Few more questions for you:

1. In SMath release manager, how do I build / publish a project that was not created by me?


If has the same GUID, you have to ask Andrey; the GUID is linked to the first publisher.

Wrote

2. I have added another dependency to the project (better SVG render engine), how do I add it in the SVN repo, which file do I modify?
I've seen. Good job, this fork of the "SVG Rendering Library" is active, thus bugs in that library may be fixed.
3. Adding better svg rendering engine required me to build for .NET 3.5; how to I change it by hand in the SVN repo?


It's all in the ImageRegion.csproj file; you have to edit it following this scheme.

Wrote

Also no go on DXF - no engine that can render that in .NET; a pity


netDxf (the one embedded in the modeller region) doesn't works? (not tested, but seems it is possible)

Wrote

I need .psd to simplify stetching on top of existing blueprints / drawings - one layer - existing drawing, another - my freehand stuff.


Not sure if this is easier but I think a good approach may be to replicate what is possible to do with the image editor of greenshot. Any sketch may be treated as an object of the region (like a layer) drawn over the background. Part of the code may be taken from the modeller region. Just an idea.

2016-02-04 17_06_41-Greenshot image editor.png

EDIT

Wrote

Keep in mind that re-rendering of SVG only on click or evaluation is not a bug - it speeds up resizing


You can define a private bool Resizing -> OnMouseDown: set it true if you are over the resize markers -> OnMouseUp: if is true trigger the re-rendering and set it to false;
If you like my plugins please consider to support the program buying a license; for personal contributions to me: paypal.me/dcprojects
#69 Posted: 2/4/2016 1:54:29 PM
Jean Giraud

Jean Giraud

983 likes in 6,866 posts.

Group: User

IMHO, I don't understand why sticking with Inkscape that is just a gadget.
Doing something with CorelDraw, AutoCad ... would make more sense to me.
Most [if not all] Inkscape is doing, is done in Mathcad "Creating Amazing Images"
This Handbook is huge, 10MB. My point here is an "SmathDraw" version as another
product ... in competition with Industry established standard.

PTC, "ProEngineer, Winchill" is great stuff.

Smath does not manage large size matrix, consequently the image region,
Proof: The first Inkscape that Martin posted, the image region does
replot in parts only, not entirely. That's why I posted a scaled down
version that reproduces completely. And, Martin orignal Inkscape is
a peanut size graphic for whoever would want doing some project.

Assume all the Inkscape dedication is successful, fine. But Smath does
not have a 3D graphic to render. It does not plot/rotate 3D matrix,
it only renders as image of limited size.

I understand [I think] what you are after from the Edu. point of view.
But, like Charlie Brown said: "Lola, please get out of your childhood".

Earth is flat on Inkscape.

I'm not negative, just objective in my Cartesian mind wrt Smath.

Jean





#70 Posted: 2/4/2016 2:29:48 PM
Alexander O. Melnik

Alexander O. Melnik

127 likes in 498 posts.

Group: Moderator

Wrote

IMHO, I don't understand why sticking with Inkscape that is just a gadget.
Doing something with CorelDraw, AutoCad ... would make more sense to me.



Suggest "real" file format that:
1. does not require paid editing software
2. Is good for sketching (The closer to CAD the better)
3. Can be rendered to image in C# for free (we would like to display this stuff somehow, wont we?)

I would be very interested in what you find

#71 Posted: 2/4/2016 4:14:22 PM
Alexander O. Melnik

Alexander O. Melnik

127 likes in 498 posts.

Group: Moderator

Wrote



Wrote

Also no go on DXF - no engine that can render that in .NET; a pity


netDxf (the one embedded in the modeller region) doesn't works? (not tested, but seems it is possible)



After some digging around
"The library only has read and write functionality. If you want to display the dxf geometry on a canvas, you will have to code it yourself using your preferred graphics engine. "

So no render function unfortunately
#72 Posted: 2/5/2016 4:01:58 AM
Jean Giraud

Jean Giraud

983 likes in 6,866 posts.

Group: User

Wrote

Suggest "real" file format that:
1. does not require paid editing software
2. Is good for sketching (The closer to CAD the better)
3. Can be rendered to image in C# for free (we would like to display this stuff somehow, wont we?)

I would be very interested in what you find


__________________________

I understand $ 0,00 but like they say "There is no free lunch".
There is no way the small Inkscape team can compete with well
established Autodesk, Adobe ... Can you give an example of what you
want to do: Mechanical Drawing, Industrial Process, College level
Geometry, Advanced Maths [Astronomy ...]

As it looks: save your Inkscape creation *.png => read in Smath.
If Smath does not read, Inkscape *.png => problem is with Inkscape,
no need to alter Smath. Alternately to this case: capture your
Inkscape creation, transit and save to be readable by Smath.
Print Screen => Paint => IrfanView keeps 24 bpp required by Smath "READ".
On large images, I prefer transiting via WinGrab.

Jean

#73 Posted: 2/6/2016 1:47:14 AM
Jean Giraud

Jean Giraud

983 likes in 6,866 posts.

Group: User

... In my own discipline I need graphic in Smath work sheet.
Easy to figure, done in Paint. Even LabView specialised in
Modeling in my discipline won't do, Why ? Because like any
graphic package, it is limited to the graphic competence, in
otherwords: depends upon the mental capability of putting
the mind into graphic package.
Paint has no competence but reads my mind.

The *.BMP is 780 KB Disk size in my PC
The *.gif is 32 KB Disk size in my PC.

For my own curiosity, I attach these two to check the
load in the Forum attachment. The *.gif is 4 BPP,
Smath imports from my file folder plots as nice as
the *.BMP 24 BPP. The gain in size is immense, by
wisely graphing and wisely saving, job done ...
No need for Inksacpe, CorelDraw, ... else invention.

Jean

RegulGIF.gif
RegulBMP.bmp
#74 Posted: 2/6/2016 1:57:26 AM
Jean Giraud

Jean Giraud

983 likes in 6,866 posts.

Group: User

... more than interesting: can download the *.BMP or
copy from forum, paste in Smath work sheet.
*.BMP [678 KB] ... during the transit *.GIF [~ 7 KB]

Thanks to: Microsoft, IrfanView, Smath & Smath Forum.

Jean
#75 Posted: 2/7/2016 10:23:19 PM
Alexander O. Melnik

Alexander O. Melnik

127 likes in 498 posts.

Group: Moderator

Hi all,

Work on image region is complete, as far as I am concerned.

All reported bugs were fixed. File types supported: png, svg, psd, pdf, dxf (partial), dwg (partial).

Known issues:

- it is not possible to set .psd file size. In the code, the blank file types psd, dxf and dwg are inserted as a static base64 string, that is written to a file.
- Pdf support requires large ghostscript .dll files (read further)

Known features:

- Dwg and Dxf support features a clever workaround. Since there is no open source library that will render dwg / dxf, in order to display the CAD drawing you have to export/print it to pdf or png with same filename as original dxf / dwg file. Prints must be placed to either parent folder of .sm workbook, or temporary folder that contains dxf / dwg files "AppData\Roaming\SMath\extensions\plugins\63ddaef8-9a56-4ff6-938e-d590b638bf99" which is default folder when you export from DraftSight.


Lets hunt some bugs before I publish the plugin to extension manager.

On that note, the plugin published to extension manager will feature only .png, .svg, and .psd file types, since .pdf support requires large ghost script library, and dwg/dxf support is marginal and potentially unstable. I will, however, create a new thread which will serve as a repository for complete release of image region plugin.

On a side note, Martin, when you get to release new portable version of SMath plus Maxima, please include full ImageRegion plugin (5 file types) and my excel_io plugin (many thanks).

Note the large archive size due to PDF rendering support.
ImageRegion008.zip.001 (3 MiB) downloaded 598 time(s).
ImageRegion008.zip.002 (3 MiB) downloaded 613 time(s).
ImageRegion008.zip.003 (3 MiB) downloaded 635 time(s).
ImageRegion008.zip.004 (3 MiB) downloaded 616 time(s).
ImageRegion008.zip.005 (3 MiB) downloaded 646 time(s).
ImageRegion008.zip.006 (1.26 MiB) downloaded 626 time(s).

Also download updated ImageRegion.dll ver. 008.5; 008 version contains a bug. (You will still need all other .dll files, except imageregion.dll, from 008 archives above)

ImageRegion.008.5.zip (75.84 KiB) downloaded 217 time(s).
#76 Posted: 2/7/2016 10:36:43 PM
Alexander O. Melnik

Alexander O. Melnik

127 likes in 498 posts.

Group: Moderator

Davide, could you help me out with a piece of code?

I am trying to place a checkmark in from of a context menu item for the region. This code does not work:


MenuButton FileType = new MenuButton("File Type";

            int chckd = 0;
            string[] extension = new string[] { "*.png", "*.svg", "*.psd", "*.pdf", "*.dxf", "*.dwg" };

                FileType.AppendChild(extension[0], delegate(MenuButtonArgs args)
                {
                    ((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext = extension[0];
                    chckd = 0;
                });
                FileType.AppendChild(extension[1], delegate(MenuButtonArgs args)
                {
                    ((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext = extension[1];
                    chckd = 1;
                });
                FileType.AppendChild(extension[2], delegate(MenuButtonArgs args)
                {
                    ((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext = extension[2];
                    chckd = 2;
                });
                FileType.AppendChild(extension[3], delegate(MenuButtonArgs args)
                {
                    ((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext = extension[3];
                    chckd = 3;
                });
                FileType.AppendChild(extension[4], delegate(MenuButtonArgs args)
                {
                    ((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext = extension[4];
                     chckd = 4;
                });
                FileType.AppendChild(extension[5], delegate(MenuButtonArgs args)
                {
                    ((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext = extension[5];
                     chckd = 5;
                });

                FileType.Children[chckd].Checked = true; 
  
#77 Posted: 2/8/2016 1:12:03 PM
Davide Carpi

Davide Carpi

1,434 likes in 2,910 posts.

Group: Moderator

Hello Alex! What's the purpose of those buttons?
If you like my plugins please consider to support the program buying a license; for personal contributions to me: paypal.me/dcprojects
#78 Posted: 2/8/2016 1:24:43 PM
Alexander O. Melnik

Alexander O. Melnik

127 likes in 498 posts.

Group: Moderator

Wrote

Hello Alex! What's the purpose of those buttons?



Davide, the purpose is to set variable "select_ext" to one of the five values in the string [] "extension". Depending on the current value of "select_ext", a check mark should be displayed next to a button.

I tried to follow your code in writer region but failed.
#79 Posted: 2/8/2016 1:33:13 PM
Davide Carpi

Davide Carpi

1,434 likes in 2,910 posts.

Group: Moderator

Wrote

Davide, the purpose is to set variable "select_ext" to one of the five values in the string [] "extension". Depending on the current value of "select_ext", a check mark should be displayed next to a button.



lol, I imagined that

I mean from user side... If I have a dxf and I click on png what should happens?


BTW, I found this that may be interesting: "open with" file dialog


EDIT not tested, but should works:
           MenuButton FileType = new MenuButton("File Type";

           string[] extension = new string[] { "*.png", "*.svg", "*.psd", "*.pdf", "*.dxf", "*.dwg" };

           for (int i = 0; i < extension.Length; i++)
           {
               FileType.AppendChild(extension[0], delegate(MenuButtonArgs args)
                                    {
                                        ((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext = extension[i];
                                    });

               if (((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext == extension[i])
                   FileType.Children[i].Checked = true;
           }
If you like my plugins please consider to support the program buying a license; for personal contributions to me: paypal.me/dcprojects
#80 Posted: 2/8/2016 9:41:09 PM
Alexander O. Melnik

Alexander O. Melnik

127 likes in 498 posts.

Group: Moderator

Wrote

Wrote

Davide, the purpose is to set variable "select_ext" to one of the five values in the string [] "extension". Depending on the current value of "select_ext", a check mark should be displayed next to a button.



lol, I imagined that

I mean from user side... If I have a dxf and I click on png what should happens?


BTW, I found this that may be interesting: "open with" file dialog


EDIT not tested, but should works:
           MenuButton FileType = new MenuButton("File Type";

           string[] extension = new string[] { "*.png", "*.svg", "*.psd", "*.pdf", "*.dxf", "*.dwg" };

           for (int i = 0; i < extension.Length; i++)
           {
               FileType.AppendChild(extension[0], delegate(MenuButtonArgs args)
                                    {
                                        ((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext = extension[i];
                                    });

               if (((ImageEdit.ImageRegion)args.CurrentRegion).GetCanvas().select_ext == extension[i])
                   FileType.Children[i].Checked = true;
           }


Hi, Davide, sorry for not replying – I was at work. The workflow for image type selection is:

1. Select the extension (.png is preselected)
2. Double click empty region
3. Blank file will be created on the fly (if no file exists already)

It might make more sense to rename the button to Blank File Type.

Also do you think that "open with" on double click is better than open? Sounds like extra step..
  • New Posts
  • No New Posts