问题
I want to have a toolbar for my mobile application in xamarin.forms. I surfed throught the net and got to know about toolbaritems but i think it just works for the windows phone not for android. Any help regarding this issue would is heartly appreciated. Ps: I need a toolbar in the tabbed pages also.
Here is my piece of code:
//main page
namespace eSewaXamarin
{
public class App:Application
{
public App ()
{
MainPage = new TabbedPageClass ();
}
protected override void OnStart ()
{
// Handle when your app starts
}
protected override void OnSleep ()
{
// Handle when your app sleeps
}
protected override void OnResume ()
{
// Handle when your app resumes
}
}
}
//tabbed page
namespace eSewaXamarin
{
public class TabbedPageClass: TabbedPage
{
public TabbedPageClass ()
{
//this.SwipeEnabled = true;
ToolbarItems.Add(new ToolbarItem("Click", null, () => {
Console.WriteLine("Clicked");
}));
//this.Title = "eSewa";
//TabbedPageClass tabbedPage=new TabbedPageClass();
this.Children.Add (new MainMenu ());
this.Children.Add (new QuickMenu ());
this.Children.Add (new AboutPage ());
}
}
}
//about page
namespace eSewaXamarin
{
public class AboutPage:ContentPage
{
public AboutPage(){
Title="About";
this.BackgroundColor = Colors.lightGrey;
Padding = new Thickness (0,Device.OnPlatform(20, 0, 0),0,0);
var listView = new ListView ();
listView.ItemTemplate = new DataTemplate (typeof(AboutCell));
listView.ItemsSource = AboutClass.getAboutText ();
listView.RowHeight = 80;
var fonePayIcon = new Image{
Aspect = Aspect.AspectFit,
};
fonePayIcon.Source = ImageSource.FromFile ("footer_logo.png");
this.Content = new ScrollView {
Content = new StackLayout{
Children={listView,new StackLayout{
Padding=new Thickness(0,8,0,8),
BackgroundColor=Color.FromHex ("dfdfdf"),
VerticalOptions=LayoutOptions.EndAndExpand,
Children={fonePayIcon}
}
}
}
};
listView.ItemSelected += (sender, e) => {
if (e.SelectedItem != null) {
AboutClass aboutClass=(AboutClass)e.SelectedItem;
int id=aboutClass.id;
AppLog.showlog ("Selected item:::::" + aboutClass.id);
if(id==0){
Navigation.PushModalAsync (new NavigationPage(new Registration()));
}else if(id==1){
Navigation.PushModalAsync(new NavigationPage(new AbouteSewa()));
}else if(id==2){
Navigation.PushModalAsync(new AboutFonePay());
}else if(id==3){
Navigation.PushModalAsync(new AboutSecurityTips());
}else if(id==4){
Navigation.PushModalAsync(new AboutAppInfo());
}
}
((ListView)sender).SelectedItem = null;
};
}
}
}
//registration page
namespace eSewaXamarin
{
public class Registration: ContentPage
{
public Registration ()
{
this.Title="Registration";
ToolbarItems.Add(new ToolbarItem("Click", null, () => {
Console.WriteLine("Clicked");
}));
this.BackgroundColor = Colors.lightGrey;
var label = new Label {
Text = Strings.eSewaRegistratinAbout,
Style=Styles.LabelStyle
};
var registerButton=new Button{
Text="Register",
Style= Styles.buttonStyleGrey
};
var esewa_icon = new Image {
Aspect = Aspect.AspectFit,
};
esewa_icon.Source = ImageSource.FromFile ("header_logo.png");
Content = new StackLayout {
Style = Styles.toolbarStyle,
Children = {new StackLayout{
Style=Styles.stackLayoutStyleForAboutSection,
Children={label,registerButton}}
}
};
registerButton.Clicked+=delegate{
var SmsTask = MessagingPlugin.SmsMessenger;
if (SmsTask.CanSendSms)
SmsTask.SendSms("9801063628", "hello aqhtar ");
};
}
}
}
回答1:
Add this to your
Page
constructor:ToolbarItems.Add(new ToolbarItem("Click", null, () => { Console.WriteLine("Clicked"); }));
Make sure you're using the newest version of Xamarin.Forms. It works just fine.
Wrap your
MainPage
insideNavigationPage
:MainPage = new NavigationPage(new YourHomePage());
来源:https://stackoverflow.com/questions/32437645/how-do-i-add-toolbar-for-android-in-xamarin-forms-as-toolbaritem-is-not-working