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);
}
我已经按照 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);
}