添加MasterDetailPage之后,Xamarin.forms应用程序中的System.InvalidCastException

use*_*084 2 c# xamarin xamarin.forms visual-studio-2015

我创建了一个Xamarin表单应用程序,该应用程序将用户输入的数据存储在sqlite数据库中,然后显示在列表中。到此为止,一切工作都很好。数据已正确存储和检索。然后,我按照教程添加MasterDetailPage。该应用程序成功构建,但给出了System.InvalidCastException:指定的强制转换在mgmain JNI_OnLoad中无效。MainActivitiy.cs中的异常 LoadApplication(new App()); 方法。经过很好的搜索,我不知道问题出在哪里。

这是App.cs,其中MainMenuPage是MasterDetailPage

namespace MyListXamarinForms
{

  public class App : Application
    {

        public App()
        {

            MainPage = new MainMenuPage();
        }

        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
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

MainMenuPage.xaml(这是包含MasterPage和Detail的母版-如下所示)`

<?xml version="1.0" encoding="utf-8" ?>
<MasterDetailPage xmlns="http://xamarin.com/schemas/2014/forms"
                  xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
                  x:Class="MyListXamarinForms.MainMenuPage"
                  xmlns:local="clr-namespace:MyListXamarinForms">

  <MasterDetailPage.Master>
    <local:MasterPage x:Name="master"/>
  </MasterDetailPage.Master>

  <MasterDetailPage.Detail>
    <NavigationPage>
      <x:Arguments>
        <local:DetailPage/>
      </x:Arguments>
    </NavigationPage>
  </MasterDetailPage.Detail>
</MasterDetailPage>
Run Code Online (Sandbox Code Playgroud)

MainMenuPage.xaml.cs`

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using Xamarin.Forms;

namespace MyListXamarinForms
{
    public partial class MainMenuPage : MasterDetailPage
    {
        public MainMenuPage()
        {
            InitializeComponent();

            master.ListViews.ItemSelected += OnItemSelected;
        }

        private void OnItemSelected(object sender, SelectedItemChangedEventArgs e)
        {
            var item = e.SelectedItem as MasterPageItem;
            if(item!=null)
            {
                Detail = new NavigationPage((Page)Activator.CreateInstance(item.TargetType));
                master.ListViews.SelectedItem = null;
                IsPresented = false;
            }
        }
    }
}`
Run Code Online (Sandbox Code Playgroud)

MasterPage.xaml

<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             x:Class="MyListXamarinForms.MasterPage"
             Icon=""
             Title="Menu"
             Padding="0,50,0,0">
  <ContentPage.Content >
    <StackLayout VerticalOptions="FillAndExpand">
      <ListView x:Name="MenuList" VerticalOptions="FillAndExpand" SeparatorVisibility="None">
        <ListView.ItemTemplate>
          <DataTemplate>
            <Label x:Name="ItemNameLabel" Text="{Binding Title}"/>
          </DataTemplate>
        </ListView.ItemTemplate>            
      </ListView>          
    </StackLayout>
  </ContentPage.Content>
</ContentPage>
Run Code Online (Sandbox Code Playgroud)

MasterPage.xaml.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

using Xamarin.Forms;

namespace MyListXamarinForms
{
    public partial class MasterPage : ContentPage
    {
        public ListView ListViews { get { return MenuList; } }
        public MasterPage()
        {
            InitializeComponent();

            var masterPageItem = new List<MasterPageItem>();

            //AddItem and HomePage are two ContentPages with content
            masterPageItem.Add(new MasterPageItem {
                Title = "Add Item",
                TargetType = typeof(AddItem)
            });
            masterPageItem.Add(new MasterPageItem
            {
                Title = "View Item List",
                TargetType = typeof(HomePage)
            });

            MenuList.ItemsSource = masterPageItem;
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

MasterPageItem.cs

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace MyListXamarinForms
{
    public class MasterPageItem
    {
        public string Title { get; set; }
        public Type TargetType { get; set; }
    }
}
Run Code Online (Sandbox Code Playgroud)

MyListXamarinForms.Droid MainActivity.cs

using System;
using Android.App;
using Android.Content.PM;
using Android.Runtime;
using Android.Views;
using Android.Widget;
using Android.OS;

namespace MyListXamarinForms.Droid
{
    [Activity(Label = "MyListXamarinForms", Icon = "@drawable/icon", Theme = "@style/MainTheme", MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation)]
    public class MainActivity : global::Xamarin.Forms.Platform.Android.FormsAppCompatActivity
    {
        protected override void OnCreate(Bundle bundle)
        {
            TabLayoutResource = Resource.Layout.Tabbar;
            ToolbarResource = Resource.Layout.Toolbar;

            base.OnCreate(bundle);

            global::Xamarin.Forms.Forms.Init(this, bundle);
            LoadApplication(new App());  //Exception thrown here
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

`

小智 5

在您的情况下,您不需要ImageCell,因为您只需要显示标签,但是ListView的DataTemplate必须是Cell,因此您可以执行以下操作:

<DataTemplate> 
    <TextCell x:Name="ItemNameLabel" Text="{Binding Title}"/> 
</DataTemplate>
Run Code Online (Sandbox Code Playgroud)

-TextCell是带有标签的简单单元格。

或这个:

 <DataTemplate> 
     <ViewCell>
        <Label x:Name="ItemNameLabel" Text="{Binding Title}"/>
    </ViewCell>
</DataTemplate>
Run Code Online (Sandbox Code Playgroud)

-请注意,这只是将标签包装在ViewCell中