Opticon Stockholm is on Tuesday September 10th, hope to see you there!
Opticon Stockholm is on Tuesday September 10th, hope to see you there!
Hi Thomas!
This can be done by using property settings in admin. See this link for more information http://imagevault.se/en/documentation/api-documentation/?page=episerverplugin/propertymedia.html.
If you want to set the values of the property settings by code Linus has written a great post about that as well, http://world.episerver.com/blogs/Linus-Ekstrom/Dates/2014/10/typed-property-settings/
/Johan
Hi Johan,
I tried to set the properties with code, according to the second link you sent:
[Display( Name = "Test product image", Description = "Test product image", GroupName = SystemTabNames.Content, Order = 1)] [BackingType(typeof(PropertyMedia))] [EPiServer.DataAnnotations.PropertySettings(typeof(TestImageSettings))] public virtual MediaReference TestProductImage20150111 { get; set; } [ServiceConfiguration(ServiceType = typeof(PropertySettings))] public class TestImageSettings : PropertySettings<PropertyMediaSettings> { public TestImageSettings() { DisplayName = "Fixed ratio"; } public override PropertyMediaSettings GetPropertySettings() { return new PropertyMediaSettings { Height = 200, Width = 200, ResizeMode = ResizeMode.ScaleToFit }; } public override Guid ID { get { return new Guid("{9A53D3D4-921E-4E45-8C79-6B877A1C59C5}"); } } }
And it does show as default in the CMS admin panel:
However, the CMS image resize-functionality does not respect proportions given in default settings.
It only respects the propertions, if they are given as custom settings.
Do you have an example, where this is working?
Our problem is that for commerce content, it is apparently not possible to manually define custom settings.
Best regards
Theis Iversen
Hello Theis.
If I understand your problem correctly, you might want to use the ResizeMode.ScaleToFill instead of ScaleToFit.
That will bring your image to be rendered with the given width and height, and it will be automatically cropped if its proportions doesn't conform to the displayarea.
Please let me know if I misunderstood your problem.
Best regards
/Richard
Hi Richard,
Thanks for your reply.
I think you misunderstood the problem, so I'll try to make it more clear :)
When I go to the property settings in CMS -> Admin -> Content Type -> MyPageType -> MyImageVaultProperty -> Custom Settings tab, I see the following:
However, when I go to an instance of this page in CMS -> Edit -> MyPageTypeInstance, and edit the MyImageVaultProperty, I get the following window:
As you see, the crop-window does not enforce the 200x200 property settings. It allows the user to decide arbitrary dimensions.
So our question is basically, why does the crop-window not respect the property settings?
Best regards
Hi Theis.
When implementing custom PropertySettings, for ImageVault.EPiServer.PropertyMediaSettings, the settings will automatically show up as a Global setting (from code).
The problem is that the setting is not marked as a Default setting, so you will have to select it manually from admin mode, for properties of your choice.
If your goal is to achieve a globally, default setting for PropertyMedia properties, you will have to mark your PropertySettings as a Default setting by inserting one line of code, like this:
[ServiceConfiguration(ServiceType = typeof(PropertySettings))] public class TestImageSettings : PropertySettings<PropertyMediaSettings> { public TestImageSettings() { DisplayName = "Fixed ratio"; ////////////////////////////////////////////////////////// // Add the following line to mark the setting as Default: IsDefault = true; } public override PropertyMediaSettings GetPropertySettings() { return new PropertyMediaSettings { Height = 200, Width = 200, ResizeMode = ResizeMode.ScaleToFit }; } public override Guid ID { get { return new Guid("{9A53D3D4-921E-4E45-8C79-6B877A1C59C5}"); } } }
Of course, it means these settings will apply to all instances of PropertyMedia, so it wont be an instance-specific setting.
According to EPiServer, it is currently not possible to programatically bind a setting to a specific property instance, but in the future it will be.
So, for now you will have to find other means to reach your goal.
You could have a look at the following blogspot (in Swedish) that present one way of dealing with this problem:
https://www.meridium.se/sv/blogg/forenkla-hanteringen-av-egenskapsinstallningar-i-episerver/
Hope it helps!
Best regards
/Richard
Hi,
I am using ImageVault with EPiServer for the first time. How do I set a default size for a image for the editor?
I have a mediareference on my page model like so:
However, the editor can still chose whichever width and height he wants in edit mode. I would like to limit that. How is that possible?
Thanks
Thomas