zoukankan      html  css  js  c++  java
  • Xamarin.Forms一些常见问题

    安装

    1、查看Xaramin.Forms的版本

    在vs项目中查看引用的包(Xamarin.Forms)的版本,或者直接进文件夹看 C:MicrosoftXamarinNuGetxamarin.forms

    可以通过 NuGet 更新到最新的 Xamarin 版本。 

    开发

    XAML

    1、xaml中用到的StaticResource的定义

    <Setter Property="FontFamily"  Value="{StaticResource MontserratRegular}" />

    一般在App.xaml中的<Application.Resources><ResourceDictionary>中定义

    2、xaml中实例化对象

    在xaml上面定义的命名空间别名, xmlns:behaviors="clr-namespace:SkillPool.Core.Behaviors"

    使用的时候其实是 实例化的过,例如,类:EventToCommandBehavior,可绑定属性:EventName、Command

    <Entry.Behaviors>
    <behaviors:EventToCommandBehavior EventName="TextChanged"
    Command="{Binding ValidateUserNameCommand}" />
    </Entry.Behaviors>

    3、xaml中定义一些按平台OnPlatform显示的资源值(Padding、Height)

     <OnPlatform x:Key="GridPadding"
                            x:TypeArguments="Thickness">
                    <On Platform="iOS" Value="20,0,10,15" />
                    <On Platform="Android, UWP, WinRT, WinPhone" Value="20,15,10,15" />
                </OnPlatform>
                <OnPlatform x:Key="GridHeightRequest"
                            x:TypeArguments="x:Double">
                    <On Platform="iOS" Value="135" />
                    <On Platform="Android, UWP, WinRT, WinPhone" Value="150" />
                </OnPlatform>
                <OnPlatform x:Key="PaddingTop"
                            x:TypeArguments="x:Double">
                    <On Platform="iOS" Value="0" />
                    <On Platform="Android, UWP, WinRT, WinPhone" Value="15" />
                </OnPlatform>
                <OnPlatform x:Key="FirstRowHeight"
                            x:TypeArguments="GridLength">
                    <On Platform="iOS" Value="65" />
                    <On Platform="Android, UWP, WinRT, WinPhone" Value="80" />
                </OnPlatform>
    Padding="{StaticResource GridPadding}"
    HeightRequest="{StaticResource GridHeightRequest}" 
    
    <Grid.RowDefinitions> 
    <RowDefinition Height="{StaticResource FirstRowHeight}"/>
    <RowDefinition Height="30"/> 
    <RowDefinition Height="40"/> 
    </Grid.RowDefinitions> 
    View Code

     x:TypeArguments的类型,取决于控件的属性的类型(查看其定义就知道了),可能位于以下两个命名空间中:

    xmlns="http://xamarin.com/schemas/2014/forms"
    xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"

    还可以有简便写法:

     <Style TargetType="Label">
     <Setter Property="FontSize" Value="{d:OnPlatform Android=15,Default=12}"/>
    <Setter Property="BackgroundColor" Value="{OnPlatform Android='Red',Default='Yellow'}"/>
     </Style>

    4、Xaml中引用控件通过Name和x:Reference

    <StackLayout.GestureRecognizers>
                            <TapGestureRecognizer
                            Command="{Binding ChildFolderShowOrHideCommand}" NumberOfTapsRequired="1" CommandParameter="{x:Reference childenImg}" />
                    </StackLayout.GestureRecognizers>
                    <Image x:Name="childenImg" Margin="0" HeightRequest="20" WidthRequest="12" VerticalOptions="Center" HorizontalOptions="StartAndExpand" 
                           Source="{Binding ChilrensIsVisible,Mode=OneWay,Converter={StaticResource MailChilrenFolderVisibleConverter}}" IsVisible="{Binding IsHaveChilren,Mode=OneWay}" />
    View Code

    5、布局中Label被挤压

    在一行布局中,第一个Labe(长度很短),第二个Label(长度可能很长),他们样式不同,第三个是一些图片。需要不换行显示,第二个label截断就好。但是以下xaml在实际中,当第二个label很长时,会造成第一个label显示不全,给它设置长度都不行,设置HorizontalOptions="FillAndExpand"也不行

    <StackLayout Grid.Row="4" Orientation="Horizontal" Margin="0,3,0,0">
                    
                        <Label  Margin="0" Text="发件人"   FontSize="15" TextColor="Black" />
                            <Label  Margin="0" Text="huy casfdf@as.com1afdgadhh23456" MaxLines="1" FontSize="15" FontAttributes="Bold" TextColor="#1c86ee" 
                           HorizontalOptions="FillAndExpand" LineBreakMode="MiddleTruncation"  />
                            <Label 
                        FontSize="15"  Text="cadsffs.com" TextColor="Black" IsVisible="False" LineBreakMode="MiddleTruncation" />
                            <ImageButton
                       Style="{StaticResource ImageButtonSmallStyle}" Source="SenderEncrypt.png"/>
                            <ImageButton
                       Style="{StaticResource ImageButtonSmallStyle}" Source="SenderSignature.png" />
                            <ImageButton
                       Style="{StaticResource ImageButtonSmallStyle}" Source="lv1.png"/>
                            <ImageButton
                       Style="{StaticResource ImageButtonSmallStyle}" Source="authenticated.png"/>
                      
                </StackLayout>
    View Code

    不过想到Grid布局,以下可以解决:

    <StackLayout Grid.Row="4" Orientation="Horizontal" Margin="0,3,0,0">
                    
                        <Label  Margin="0" Text="发件人"   FontSize="15" TextColor="Black" />
                            <Label  Margin="0" Text="huy casfdf@as.com1afdgadhh23456" MaxLines="1" FontSize="15" FontAttributes="Bold" TextColor="#1c86ee" 
                           HorizontalOptions="FillAndExpand" LineBreakMode="MiddleTruncation"  />
                            <Label 
                        FontSize="15"  Text="cadsffs.com" TextColor="Black" IsVisible="False" LineBreakMode="MiddleTruncation" />
                            <ImageButton
                       Style="{StaticResource ImageButtonSmallStyle}" Source="SenderEncrypt.png"/>
                            <ImageButton
                       Style="{StaticResource ImageButtonSmallStyle}" Source="SenderSignature.png" />
                            <ImageButton
                       Style="{StaticResource ImageButtonSmallStyle}" Source="lv1.png"/>
                            <ImageButton
                       Style="{StaticResource ImageButtonSmallStyle}" Source="authenticated.png"/>
                      
                </StackLayout>
    View Code

    6、W/StaticLayout: maxLineHeight should not be -1. maxLines:1 lineCount:1

    查看了下xaml中是否有行相关的设置,删掉试试,什么原因暂时没搞清

    7、页面的静态资源无法自动提示

    发现xaml中格式字符串引起的,<Label TextColor="Gray" FontSize="15" VerticalOptions="Center" Text="{Binding MailDetailModel.MailDate,StringFormat='{0:yyyy-MM-dd HH:mm:ss}' }"/>

    将StringFormat改为Converter去做转换则可以了。

    8、ImageButton的单击命令去切换图片显示的时候,图像不知怎么的就变小了,改了Aspect属性也不行

    可以改为用Image控件,添加GestureRecognizers去做切换图片,图像大小不会变

    ViewModel绑定

    1、在ViewModel中引用xaml中用x:Name定义的变量

    首先获取页面:Application.Current.MainPage as MailIndexView; 

    然后取定义的变量(或者控件),但是控件需要在xaml中命名如下,

    x:Name="tabSelectedLayout" x:FieldModifier="Public" 

     2、控件的Binding 必须是属性,不能是字段

    自定义控件

    细微的样式更改,用效果;复杂的外观和行为自定义,用自定义呈现器。

    1、自定义控件 属性更改事件的两种用法

    自定义控件包括多个控件时,若子控件Editor的属性例如Placeholder 需要通过使用自定义控件时 传过来。则需要将Editor的属性绑定到自定义控件上,有两种方式:

    • 在属性的OnPropertyChanged(); 事件中设置

    private static void OnPlaceholderChanged(BindableObject bindable, object oldValue, object newValue)
    {
    if (bindable is AutoCompleteView autocomplete)
    {
    autocomplete.Placeholder = (string)newValue;
    autocomplete.Editor.Placeholder = autocomplete.Placeholder;
    }
    }

    • 在xaml中指定, Placeholder="{Binding Placeholder,Source={x:Reference fm}}",(同时就不用定义OnPropertyChanged参数及事件)
    <Frame xmlns="http://xamarin.com/schemas/2014/forms" 
                 xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
                 xmlns:d="http://xamarin.com/schemas/2014/forms/design"
                 xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
                 mc:Ignorable="d"
                 xmlns:behavior="clr-namespace:MeSince.Behaviors"
                 xmlns:effect="clr-namespace:MeSince.Effects"
                 x:Class="MeSince.Controls.RoundRadiusEntry" x:Name="fm" HeightRequest="40" Padding="5,0,5,0" CornerRadius="4" HasShadow="False" Margin="0">
        <StackLayout Orientation="Horizontal" Padding="0" Margin="0" VerticalOptions="FillAndExpand">
            <Entry x:Name="entry" Text="{Binding Text,Source={x:Reference fm}}" Placeholder="{Binding Placeholder,Source={x:Reference fm}}"
    View Code

    调试

    1、System.Reflection.TargetInvocationException

    Message=Exception has been thrown by the target of an invocation.  调用的目标引发异常。

    1.1、注:遇到报错,首先从VS中看下有没有具体的原因,而不是一开始就去 Internet找解决方案。

    很明显看出是XAML解析错误:EntryStyle资源不存在导致。

    1.2、若输出中没有明显的提示,则用断点调试,定位到哪一块代码报错的,再去分析问题

    例如,今天遇到这个问题,将事件改为命令在Viewmodel中执行,始终报上面的错,定位到问题是如下xaml:

    <?xml version="1.0" encoding="utf-8" ?>
    <TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"
                 xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
                 xmlns:d="http://xamarin.com/schemas/2014/forms/design"
                 xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
                 mc:Ignorable="d"
                 x:Class="MeSince.Views.Main.BottomTabbedPageView"
                
                 xmlns:viewModelBase="clr-namespace:MeSince.ViewModels.Base"
                 viewModelBase:ViewModelLocator.AutoWireViewModel="True"  
                xmlns:behaviors="clr-namespace:MeSince.Behaviors"
                xmlns:converters="clr-namespace:MeSince.Converters"
                
               >
        <TabbedPage.Behaviors>
            <behaviors:EventToCommandBehavior EventName="CurrentPageChanged" Command="{Binding CurrentPageChangedCommand}" />
        </TabbedPage.Behaviors>
    View Code

    看了下EventToCommandBehavior的定义,发现其中base.OnAttachedTo(visualElement);

    visualElement的类型定义的是View,,而发现我需要附加行为的是TabbedPage(类型是Page,和View是不同的),于是改为它们的父类VisualElement,问题解决。

    即:将

    public class EventToCommandBehavior : BindableBehavior<View>

    改为

    public class EventToCommandBehavior : BindableBehavior<VisualElement>

    2、UWP.exe 已附件有调试器,但没有将该调试器配置为调试此未经处理的异常。若要调试此异常,必须分离当前的调试器

     

    解决方案:尝试“清理解决方案”,然后在文件资源管理器中打开项目,再删除 bin 和 obj 文件夹。

    https://docs.microsoft.com/zh-cn/previous-versions/hh972445(v=vs.140)?redirectedfrom=MSDN

    3、调试CollectionView报错

    报错:The class, property, or method you are attempting to use ('VerifyCollectionViewFlagEnabled') is part of CollectionView; to use it, you must opt-in by calling Forms.SetFlags("CollectionView_Experimental") before calling Forms.Init().

    意思是:您尝试使用的类,属性或方法(“ VerifyCollectionViewFlagEnabled”)是CollectionView的一部分; 要使用它,您必须在调用Forms.Init()之前通过调用Forms.SetFlags(“ CollectionView_Experimental”)选择加入。

     在特定平台初始化代码中加入,

    protected override void OnCreate(Bundle savedInstanceState)
    {
        global::Xamarin.Forms.Forms.SetFlags("CollectionView_Experimental");        
    }

    4、Specified cast is not valid  指定的转换无效

    在xaml页面初始化(InitializeComponent ())时报错,但是没有具体的信息。

    思路:

    • 看下ViewModel的绑定属性是否有误;
    • 控件属性的类型是否正确,eg:    <BoxView  CornerRadius="{StaticResource cornerRadius}"  />,CornerRadius的类型是CornerRadius而不是Double,CornerRadius写成了x:Double就会报上面的错误。
    <OnPlatform x:Key="cornerRadius"
    x:TypeArguments="CornerRadius">
    <On Platform="iOS" Value="3" />
    <On Platform="Android, UWP, WinRT, WinPhone" Value="5" />
    </OnPlatform>

    其它参考:Xamarin深坑集锦

  • 相关阅读:
    ASP.NET Core 添加统一模型验证处理机制
    【Spark】开发Spark选择Java还是Scala?
    【设计模式】单例模式-为什么是静态变量
    【Spark】SparkStreaming-如何使用checkpoint
    【Java】Java-ShutDownHook-优雅关闭系统资源
    【Scala】Scala-None-null引发的血案
    【Spark】SparkStreaming-输出到Kafka
    【Spark】Spark-Redis连接池
    【Spark】提交Spark任务-ClassNotFoundException-错误处理
    【大数据】王加林-大数据学习资料
  • 原文地址:https://www.cnblogs.com/peterYong/p/11599658.html
Copyright © 2011-2022 走看看