Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to correctly use the Image Source property with Xamarin.Forms?

I am having difficulty bringing up an image on the content page in a stack layout. I looked through Xamarin API Documentation and found Xamarin.Forms.Image.Source Property, but no sample code to see how it's written. I also checked to see how it was written in C# and seems to match my code in terms of filename path, but in Xamarin, it may be slightly different since it's the first time doing this. The code I'm currently testing through an Android emulator (Google Nexus 5) in Visual Studio 2013 which runs fine, with the exception of the Image not showing.

Image Source:

new Image {      VerticalOptions = LayoutOptions.Center,      HorizontalOptions = LayoutOptions.Center,      Source = "/Assets/xamarin_logo.png", }, 

Full Code:

public NFCPage()     {         StackLayout stackLayout = new StackLayout // instantiate a StackLayout object to layout its children         {             Spacing = 5, // amount of spae between each child element             //HorizontalOptions = LayoutOptions.Center,             VerticalOptions = LayoutOptions.FillAndExpand, // defines how the elements should be laid out; fill the entire width of the content to the screen             BackgroundColor = Color.Blue,              Children = // gets a list of child elements             {                 new Label                 {                        TextColor = Color.White,                     BackgroundColor = Color.Red,                     XAlign = TextAlignment.Center, // set text alignment horizontally                     Text = "Google",                 },                 new Label                 {                     Text = "Place your device directly at the symbol.",                     XAlign = TextAlignment.Center,                     TextColor = Color.White,                 },                 new Image                 {                     VerticalOptions = LayoutOptions.Center,                     HorizontalOptions = LayoutOptions.Center,                     Source = "/Assets/xamarin_logo.png",                 },                 new Button                 {                     Text = "QR Code",                     TextColor = Color.White,                 },                 new Button                 {                     Text = "?",                     TextColor = Color.White,                 },             }         };         Content = stackLayout; // apply stackLayout to Content     } 
like image 869
TheAmazingKnight Avatar asked Jun 15 '15 16:06

TheAmazingKnight


People also ask

How do you bind an image source in Xamarin forms?

In Xamarin. Forms SfAvatarView, you can set the key for ImageSource by using ResourceDictionary and bind image from ViewModel to ImageSource. An ImageSource instance, can be either File, Uri or Resource, which sets the image to display.

What is the use of application properties property in Xamarin forms?

Developers can use this property to store persistent application state across all application code. This values in the dictionary are preserved on the device when the application is paused or shut down.


2 Answers

You shouldn't reference the path because the source property is cross-platform and since every platform has a different folder for assets like images, you only need to specify the filename and extension. The Image class knows where to look to find the file.

Image files can be added to each application project and referenced from Xamarin.Forms shared code. To use a single image across all apps, the same filename must be used on every platform, and it should be a valid Android resource name (which means no spaces and special characters). Place images in the Resources/drawable directory with Build Action: AndroidResource . High- and low-DPI versions of an image can also be supplied (in appropriately named Resources subdirectories such as drawable-ldpi , drawable-hdpi , and drawable-xhdpi ).

enter image description here

var beachImage = new Image { Aspect = Aspect.AspectFit }; beachImage.Source = ImageSource.FromFile("waterfront.jpg"); 

Source: https://docs.microsoft.com/en-us/xamarin/xamarin-forms/user-interface/images?tabs=windows#local-images

like image 178
Adam Avatar answered Sep 28 '22 04:09

Adam


If you are willing to add images using code, try this

Downloaded automatically and display the image

        var webImage = new Image { Aspect = Aspect.AspectFit };         webImage.Source = ImageSource.FromUri(new Uri("https://xamarin.com/content/images/pages/forms/example-app.png")); 
like image 34
Asbar Ali Avatar answered Sep 28 '22 04:09

Asbar Ali