Xamarin Android 工具栏如何动态添加项目

Xamarin Android toolbar how to add items dynamically

我已经按照 xamarin android 指南 here

中给出的说明实现了 android 工具栏

使用示例代码:

public override bool OnCreateOptionsMenu(IMenu menu)
        {           
            MenuInflater.Inflate(Resource.Menu.mainMenu, menu);

            return base.OnCreateOptionsMenu(menu);
        }

和xml:

<?xml version="1.0" encoding="utf-8" ?>
<menu xmlns:android="http://schemas.android.com/apk/res/android"
      xmlns:local="http://schemas.android.com/apk/res-auto">
  <item
       android:id="@+id/menu_share"
       local:showAsAction="ifRoom"
       android:title="Share" />
  <item
       android:id="@+id/menu_settings"
       local:showAsAction="ifRoom"
       android:title="Settings" />
</menu>

现在我想将来自我的网站 api 的项目添加到工具栏,它们基本上是指向我们页面的链接,例如隐私政策等。但我在 menu.Add 上找不到任何示例这样做的方法。基本上我需要的是从我的 json 中构建许多项目,其中 returns:

[{
pageid:1,
pagename:"home",
pagehtmllink:"....."
},
{
pageid:2,
pagename:"About",
pagehtmllink:"....."
},
...........
]

如何从后面的代码实现这个?

IMenu 有一个 Add 方法可以调用:

public override bool OnCreateOptionsMenu(IMenu menu)
{
        MenuInflater.Inflate(Resource.Menu.main_menu, menu);

        menu.Add(0, 99, 0, "DB Copy to SDCard (Debug)");

        return base. OnCreateOptionsMenu(menu);
}

有关参数,请查看 Android 文档:Menu.html#add

要捕获菜单选择,您可以检查 IMenuItem.ItemId 值:

public override bool OnOptionsItemSelected(IMenuItem item)
{
    switch (item.ItemId)
    {
        case 99:
            DoSomething();
            return true;
        default:
            return false;
    }
}

您不需要可以创建标签页并在每个页面上创建一个 webview

public partial class MainPage : TabbedPage
{
    public MainPage()
    {
        InitializeComponent();
        this.BarBackgroundColor = Color.Gray;

        var homePage = new HomePage();
        var accountPage = new AccountPage();
        var ordersPage = new OrdersPage();
        var promotionsPage = new PromotionsPage();
        var searchPage = new SearchPage();

        homePage.Icon = "imgs_main.png";
        accountPage.Icon = "imgs_account.png";
        ordersPage.Icon = "imgs_orders.png";
        promotionsPage.Icon = "imgs_promotions.png";
        searchPage.Icon = "imgs_search.png";

        homePage.Title = "Home";
        accountPage.Title = "Account";
        ordersPage.Title = "Orders";
        promotionsPage.Title = "Promotions";
        searchPage.Title = "Search";

        Children.Add(homePage);
        Children.Add(accountPage);
        Children.Add(ordersPage);
        Children.Add(promotionsPage);
        Children.Add(searchPage);

    }