MoI discussion forum
MoI discussion forum

Full Version: Moi + Affinity : Moi for 2D workflows

Show messages:  1-17  18-37  38-57  58-77  78-90

From: mkdm
20 Oct 2017   [#38] In reply to [#37]
Hi Metin.

@You : "...Maybe I'll wait for the official release after all..."

I think I'll do so!

Cheers.
From: mkdm
22 Oct 2017   [#39]
Hi everyone!

I'm back with a new quick and dirt tutorial about Moi with Affinity Designer

This time...."Dot circles vector image"!

Here's the video : http://take.ms/A2zPf



For this tutorial I have used a simple but very useful external tool : Halftoner 1.7
These are the links :
Zip file : http://jasondorie.com/downloads/HalftonerV1.7.zip
Home page : http://jasondorie.com/page_cnc.html



We'll catch up.

Ciao!
From: amur (STEFAN)
23 Oct 2017   [#40]
Hi Marco,

nice looking tiger!

Here is one more abstract image from me, done with MoI (lot's of trimming and joining)
and the help of Vector Raster and Art Text 3. Have to explore this workflow a bit more.

Good thing is that with Art Text 3 you can generate really quick poster sized images,
without loosing sharpness etc.

Best regards
Stefan




Image Attachments:
me.jpg  me_abstract.jpg 


From: mkdm
23 Oct 2017   [#41] In reply to [#40]
Hi STEFAN.

Thanks a lot for sharing!

Very interesting for Mac users.

If you want to remain within Moi without using any external tool you can use the great Max's "HeightMap" commands!

It generates curves (or point) from an input b&w or greyscale image.

Although the resulting curves needs to be a tweaked a little bit with the "rebuild" command to make them "lighter" ,
before export them to PDF, for importing into Affinity Designer or any other vector graphic software.

You can get the Max's command here : http://take.ms/e2vSN
N.B. In windows you need to run Moi in Administrator mode in order to make HeightMap works.

This is a brief video I made : http://take.ms/fVOE0




Ciao!
From: amur (STEFAN)
23 Oct 2017   [#42]
Hi Marco,

Max's Script, in this case, is IMHO not good, because it gives you jaggies!

I use for this task the super cool free Zsurf4 in combination with Photoshop,
which runs also under Wine, for OS X users :-)

Best regards
Stefan

Image Attachments:
ZSURF4.jpg 


From: mkdm
23 Oct 2017   [#43] In reply to [#42]
Hi STEFAN.

Oh yeah...ZSurf is very useful and in many cases is the right choice!

I have used it sometimes in the past with good results.

Thanks.

But because here I'm trying always to find "old and new" workflows for Moi and Affinity I'm more interested in playing with curves rather than surfaces.

Anyway, you're right. In many cases ZSurf generates surfaces with a good smoothness, and the Iso curves that I can extract are better than those
generated from "HeightMap" script.

Ciao!

Stay tuned for new stuff involving Moi and Affinity :)
From: amur (STEFAN)
31 Oct 2017   [#44]
Hi Marco and all,

just took your tiger drawing into Art Text 3. I really like what one can do with it. :-)



P.S. i added also one Penrose tiling image, done with MoI and Art Text 3, to the MoI Gallery.

Best regards
Stefan

Image Attachments:
tiger.png 


From: mkdm
31 Oct 2017   [#45] In reply to [#44]
Hi Stefan!

Very nice!


@You "...your tiger drawing..."

As I said in my original post the tiger is not mine. I get it in Freepik.com
(https://www.freepik.com/free-vector/animals-tribal-tattoo-collection_1168322.htm#term=tiger&page=1&position=5)

Thanks for sharing!

Stay tuned...I hope to upgrade soon my scripts for 2D Workflows. (bug fixing)

Ciao!
From: mkdm
31 Oct 2017   [#46] In reply to [#44]
P.S. I only tweaked the tiger a little bit with Affinity Designer to make some cleanup, then I exported it in PNG and then I have used the png for
my 2D Workflow tutorial (original post : http://moi3d.com/forum/index.php?webtag=MOI&msg=8629.39)

Ciao!
From: amur (STEFAN)
31 Oct 2017   [#47]
Thanks for the info Marco!

I overlooked that the original image was from there...

Best regards
Stefan
From: mkdm
4 Nov 2017   [#48]
Hi Michael.

I'm pretty sure that you already answered me a long time ago, about this question, but I don't remember where is your answer.
I've searched trough the forum by I didn't find what I'm looking for.

The question is this :

If we simply take into account the "speed of execution" factor, can we state that the code executed inside a the "hmtl" page of a command
or inside a script placed into the "scripts" folder, is faster (and many times faster) the the execution of "js code" present in the "js" counterpart of command's html ?

I ask you this because I have in mind to turn the next version of my "script for 2D workflow" from "script" into "command" just in order to
handle more easily the various working mode of that scripts.

For what I've experienced and learned I've seen that the "js" code executed inside the Hml file of command is much more faster that the counterpart executed into the "js" file of the command :

For example consider the "ScaleIndividual" commands that Max wrote times ago :

1) the original version of Max Smirnov :
get it at https://drive.google.com/open?id=1waO3TgOQSUl2ZIBJ8adixPz5Qes_ja21

2) A version that I have modified and that do the main task into the "js" code inside the Html file of the command :
get it at https://drive.google.com/open?id=1N6qWe_lzyJA-aTOrmESLRPhzky_XHhoB


Why the 2nd version, is much more faster than the first (to make a good test you have to select many objects, I tested with hundreds) ?


This is the code of the original version of ScaleIndividual.js and ScaleIndividual.htm :

code:
#include "GetObjects.js"
#include "WaitForDialogDone.js"

function ScaleObject( obj, factor )
{
	var center = obj.getBoundingBox().center;
	var list = moi.geometryDatabase.createObjectList();
	list.addObject( obj );

	var factory = moi.command.createFactory( 'scale' );
	factory.setInput( 0, list );
	factory.setInput( 1, center );
	factory.setInput( 2, factor );
	factory.commit();
}

function DoIndividualScale()
{
	var objectpicker = moi.ui.createObjectPicker();
	if ( !GetObjects( objectpicker ) )
		return;
		
	var objects = objectpicker.objects;
		
	moi.ui.beginUIUpdate();
	moi.ui.hideUI( 'SelectPrompt' );
	moi.ui.showUI( 'OptionsPrompt' );
	moi.ui.showUI( 'options' );
	moi.ui.endUIUpdate();
	
	if ( !WaitForDialogDone() )
		return;
		
	var scalefactor = moi.ui.commandUI.factor.value;
		
	for ( var i = 0; i < objects.length; ++i )
	{
		var obj = objects.item(i);
		ScaleObject( obj, scalefactor );
	}
}

DoIndividualScale();


code:
<html>
	<body class="commandbody">
		<div class="commandheader">
			<div id="SelectPrompt" class="commandprompt">Select objects to scale</div>
			<div id="OptionsPrompt" class="hiddencommandprompt">Scale options</div>
		</div>
		
		<div id="options" class="hiddencommandoptions">
			<table>
				<tr>
					<td>Scale factor:</td>
					<td><moi:NumericInput id="factor"/></td>
				</tr>		
			</table>
		</div>

		<moi:CommandDoneCancel />
	</body>
</html>



And this is the code of my modified version of ScaleIndividualMainThread.js and ScaleIndividualMainThread.htm :

code:
#include "GetObjects.js"
#include "WaitForDialogDone.js"

function DoIndividualScaleInit() {
	var objectpicker = moi.ui.createObjectPicker();
	if ( !GetObjects( objectpicker ) )
		return;
		
	var objects = objectpicker.objects;
		
	moi.ui.beginUIUpdate();
	moi.ui.hideUI( 'SelectPrompt' );
	moi.ui.showUI( 'OptionsPrompt' );
	moi.ui.showUI( 'options' );
	moi.ui.endUIUpdate();
	
	if ( !WaitForDialogDone() )
		return;
	
	moi.ui.commandUI.DoIndividualScale(objects);
}

DoIndividualScaleInit();


code:
<html>
	<head>
		<script>		
			function ScaleObject( obj, factor ) {
				var center = obj.getBoundingBox().center;
				var list = moi.geometryDatabase.createObjectList();
				list.addObject( obj );

				var factory = moi.command.createFactory( 'scale' );
				factory.setInput( 0, list );
				factory.setInput( 1, center );
				factory.setInput( 2, factor );
				factory.commit();
			}

			function DoIndividualScale(objects) {
				var scalefactor = moi.ui.commandUI.factor.value;
					
				for ( var i = 0; i < objects.length; ++i ) {
					var obj = objects.item(i);
					ScaleObject( obj, scalefactor );
				}
			}
		</script>
	</head>
	<body class="commandbody">
		<div class="commandheader">
			<div id="SelectPrompt" class="commandprompt">Select objects to scale</div>
			<div id="OptionsPrompt" class="hiddencommandprompt">Scale options</div>
		</div>
		
		<div id="options" class="hiddencommandoptions">
			<table>
				<tr>
					<td>Scale factor:</td>
					<td><moi:NumericInput id="factor"/></td>
				</tr>		
			</table>
		</div>

		<moi:CommandDoneCancel />
	</body>
</html>



Thanks a lot for the support :)

Have a nice day.

Ciao!

Marco (mkdm)
From: mkdm
4 Nov 2017   [#49]
P.S. Michael, I will read your answer in five-six hours because now I have to go :)

Thanks.
From: Michael Gibson
4 Nov 2017   [#50] In reply to [#48]
Hi Marco,

> If we simply take into account the "speed of execution" factor, can we state that the code
> executed inside a the "hmtl" page of a command or inside a script placed into the "scripts"
> folder, is faster (and many times faster) the the execution of "js code" present in the "js"
> counterpart of command's html ?

For V3 yes that's true - the .js code is run in a separate process and uses inter-process communication on every MoI API call. The reason for this is it makes it impossible for the script to freeze MoI if it runs in an endless loop or something like that, the worker process can be torn down independently from the script's cooperation.

But the inter-process communication has a performance penalty. The regular default commands in MoI never use script to do heavy calculations in loops or things like that, and so are ok with that.

Code in the HTML side runs in the main process thread and so it doesn't have that same overhead.

For V4 this will be different though, in V4 the .js script will be run on the main thread and not on a worker thread anymore and so in v4 there won't be any difference for which file the code is contained in.

- Michael
From: mkdm
4 Nov 2017   [#51] In reply to [#50]
Thank you very much Michael for reminding me this behaviour.

Ciao :)
From: mkdm
11 Jul 2018   [#52]
Hello everyone!

I'm sorry for the uppercase but THIS IS THE LONG AWAITED DAY for all passionate pro artists/amateurs of 2D workflow/vector things!!

THE DAY has come :)

AFFINITY DESIGNER is ready for iOS!!!!!!

Still not of App Store but you can download here if you're on iPad: https://itunes.apple.com/us/app/affinity-designer/id1274090551?mt=8
From: Frenchy Pilou (PILOU)
11 Jul 2018   [#53]
Yep the challenger of Procreate! :)


Affinity Designer for iPad - official video from Affinity on Vimeo.
From: mkdm
11 Jul 2018   [#54] In reply to [#53]
This is a GREAT day for all the iPad crowd!!

Anyway, Procreate and Affinity Designer are not competitor at all.
They are focused on very different things.
But...what a wonderful DUO!!!!!
And don't forget Affinity Photo!

Great things for 2d graphics :)

These apps destroys everything on Android/Windows mobile side!
From: ycarry
13 Jul 2018   [#55]
Yes, its THE Adobe Illustrator challenger...
From: mkdm
13 Jul 2018   [#56] In reply to [#55]
But with the golden bonus that actually there isn't any iOS version of Adobe Illustrator!!

So actually Affinity Designer is the "Lion King" for vector things on iOS (and IMHO for mobile in general).

It was launched only some days ago so actually is still young and needs a certain amount of bug fixes obviously, and in fact I have already reported some bugs on Affinity Forum, but for what I've seen in the last three days of hard use it's really a game changer for all 2D graphics on mobile.

It's the missing link between Procreate and Affinity Photo.

Procreate (or Artstudio Pro) + Affinity Designer + Affinity Photo = almost ALL you need for a REAL professional 2D graphic pipeline on Mobile!

This is what I'm experiencing with my iPad Pro 12.9 2017.

Cheers.
From: Frenchy Pilou (PILOU)
13 Jul 2018   [#57]
...as third thief free Gravit Designer ;)
https://www.designer.io

Show messages:  1-17  18-37  38-57  58-77  78-90