Xamarin.Forms之OnElementPropertyChanged那些事

这是一篇不完善的笔记,并不是教程。

今天遇到一些奇怪的问题,使用CustomRenderer为Picker添加TextColor属性,始终无法触发OnElementPropertyChanged,进过几轮测试后发现一些问题。

1.在Control创建的过程中,自定义的属性是无法接受到消息的

OnElementPropertyChanged中实际上是有触发的,但不是TextColorProperty,而是Renderer Width X Y Height 5个VisualElement的属性,即使是Picker的Title属性或者VisualElement的其他属性,譬如IsEnabled,均无法触发,Control创建时触发的仅且只有那5个属性

但是在创建完成后,修改BinableProperty的任何属性均会触发

这个好像是Forms的设定问题,下面有该问题的讨论

http://forums.xamarin.com/discussion/26060/why-is-onelementpropertychanged-not-called-on-viewrenderer

2.如果Property的属性设置的是同一值,则也不会触发OnElementPropertyChanged

ViewRenderer<TView,TNativeView>中的:

protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e)
{
    if (e.get_PropertyName() == VisualElement.BackgroundColorProperty.PropertyName)
    {
        this.UpdateBackgroundColor();
        return;
    }
    if (e.get_PropertyName() == VisualElement.InputTransparentProperty.PropertyName)
    {
        TElement element = this.Element;
        this.InputTransparent = element.InputTransparent;
    }
    if (e.get_PropertyName() == VisualElement.IsEnabledProperty.PropertyName)
    {
        this.UpdateIsEnabled();
    }
}

大部分Control的Renderer都是继承上面的,但实际上该方法仅对三个Property进行了默认处理,未对值是否一致进行判断(可以通过去掉base.OnElementPropertyChanged (sender, e);进行测试),也就是问题2,是在这之前进行处理的,暂未发现在哪里

时间: 2024-10-12 17:14:41

Xamarin.Forms之OnElementPropertyChanged那些事的相关文章

Xamarin.Forms之Effects的使用

在 Xamarin.Forms 2.1.0-pre1 ,Xamarin.Forms新增了新的Effects API. Effects是一系列方法,为了给View的渲染器添加运行时改变. 然而,我想强调的是, Effects天生被设计为高可复用的. 如果一个Effect能够解决一个难题, 它可能能够在你的整个APP中使用.如果你写了一个Effect来解决你的一个难题, 你能够分享它给其他遇到同样问题的人. 这篇文章尝试展示一种方式,能够帮助我们使分享Effects这件事变得很简单. public

Xamarin.Forms学习之Platform-specific API和文件操作

这篇文章的分享原由是由于上篇关于Properties的保存不了,调用SavePropertiesAsync()方法也不行,所以我希望通过操作文件的方式保存我的需要的数据,然后我看了一下电子书中的第二十章和需要相关知识的第九章,这篇文章中的内容则是我学习这两章的一点记录和分享,还是那样,有错请留言指正,谢谢! 不同的平台存在着一些特定的API,通过在电子书中两章的学习,实践一下如何调用这些API和将这些API封装成公共的库,供以后的项目调用.以一个显示平台信息的小实例开始做一个简单的演示,其运行效

菜鸟的Xamarin.Forms前行之路——实现按钮的字体图标(可扩展)

在实际的APP中,带有图标的按钮用到地方还是蛮多的,字体图标往往能更快更生动的传达信息,并且相对于背景图片,字体图标也有着绝对的优势,所以实现按钮的字体图标是值得尝试的. 实现方法:各平台自定义渲染按钮 PCL 添加名为Fonts.cs的类,作用各平台的字体文件(ios-android-uwp,ios字体文件不要后缀并且大写,安卓全称) public static class Fonts { public static string IconFont= Device.OnPlatform("Ic

菜鸟的Xamarin.Forms前行之路——原生Toast的简单实现方法

项目中信息提示框,貌似只有个DisplayAlert,信息提示太过于单一,且在有些场合Toast更加实用,以下是一个简单的原生Toast的实现方法 项目地址:https://github.com/weiweu/TestProject/tree/dev/Toast 共享项目 定义一个接口IToast,包括Short和Long两个方法: public interface IToast { void LongAlert(string message); void ShortAlert(string m

张高兴的 Xamarin.Forms 开发笔记:为 Android 与 iOS 引入 UWP 风格的汉堡菜单 ( MasterDetailPage )

所谓 UWP 样式的汉堡菜单,我曾在"张高兴的 UWP 开发笔记:汉堡菜单进阶"里说过,也就是使用 Segoe MDL2 Assets 字体作为左侧 Icon,并且左侧使用填充颜色的矩形用来表示 ListView 的选中.如下图 但怎样通过 Xamarin.Forms ,将这一样式的汉堡菜单带入到 Android 与 iOS 中呢? 一.大纲-细节模式简介 讲代码前首先来说说这种导航模式,官方称"大纲-细节模式"(MasterDetail).左侧的汉堡菜单称为&qu

菜鸟的Xamarin.Forms前行之路——绪言

作者入门时间不是很久,差不多一年,期间自学的东西比较杂乱,到目前为止,编程方面的知识比较薄弱.之所以做这个系列,也只是因为做了两个月的Xamarin.Forms方面的东西,由于资料和自身实力的原因,过程走的比较艰难,但所幸的是也解决了部分的问题,积累了一些经验.期望通过这个系列,和大家分享经验,查漏纠错. 作为一个菜鸟,在解决问题的时候,往往比较直接,就是仅仅为了解决问题,期间可能根本没有考虑性能等方面的问题.所以在这个系列中,问题肯定是作者亲身实践能够解决的,但是在性能资源等方面作者没有做过考

Xamarin.Forms开发APP

Xamarin.Forms+Prism(1)-- 开发准备 准备: 1.VS2017(推荐)或VS2015: 2.JDK 1.8以上: 3.Xamarin.Forms 最新版: 4.Prism 扩展,打开VS的扩展和更新,在联机中,搜索Prism,安装第一个扩展Prism Template Pack: 5.Android SDK,这个下载已经非常快了,国内已经支持Android环境下载. 6.都准备好后,请确保创建一个新的Xamarin.Forms程序后,能正常调试运行,不能调试运行的,请百度或

Xamarin.Forms之MessagingCenter

MessagingCenter是Xamarin.Forms中很有用但是很难用的东西,使用起来很方便,但是要注意的地方很多 1.Sender能为空 MessagingCenter.Send<CacheUserInfo>(UserInfo.Instance.CurrentLoginUser, "UpdateMenuIconList"); CurrentLoginUser为空的时候,会直接造成界面卡死(不执行下面的代码,但是也不报错,坑爹的地方)

菜鸟的Xamarin.Forms前行之路——按钮的按下抬起事件的监控(可扩展至其他事件)

提问:监控按钮的点击事件,可以通过按钮的Click事件,或者Command绑定,那么如何监控按钮的按下与抬起,或者移动,长按,双击等事件? 解决方法:各个平台自定义渲染依赖注入. 共享项目PCL: 1先定义一个继承Button的实体类NewButton.cs public class NewButton : Button { public event EventHandler Pressed; public event EventHandler Released; public virtual