我是XAML和C#的新手,但在我玩过它的几周内一直很喜欢使用它.我已经开始在一个应用程序上工作,并在XAML中组合了一个简单的"设置"页面; 现在我正在尝试将事件连接到控件以(a)在用户与它们交互时更新应用程序状态,以及(b)在访问页面时具有当前状态.
我打了两个(相关的)路障但是:
工具包:当我在XAML中定义"ListPickerItem"时,ListPicker控件似乎不能正常工作,所以在SettingsPage构造函数中,我手动设置了内容:
lpColour.ItemsSource = new List<string>()
{
"Red","Blue","Green","Custom…"
};
lpColour.SelectedIndex = 1; // set the currently selected item to "Blue"
Run Code Online (Sandbox Code Playgroud)
但是,因为控件(在此示例中为lpColour)在SelectionChanged上有一个事件,所以会触发两个事件(一个选中"红色"作为框填充,然后另一个选择"蓝色").我现在不想处理"SelectionChanged"; 只有当用户自己与控件交互时(例如,如果他们选择"自定义..."),我可以显示一个单独的文本框并给出焦点;但我不想在我设置时这样做页面,他们之前选择了"自定义...",否则用户在打开"设置"页面时会立即显示键盘...)
我想也许有一些方法可以从"SelectionChangedEventArgs"或"RoutedEventArgs"获得事件的"起源"(例如"代码"或"用户输入")......但也许不是?
我还尝试设置一个"初始化"bool值(默认情况下为"false",运行构造函数后设置为"true",并将事件处理代码包装为"if(initialized){...}";但是在构造函数完成"lpColour.ItemSource = ..."和"lpColour.SelectedIndex = 1"代码完成时,"初始化"为"假"时,事件似乎仍然被触发.非常奇怪.:P
我希望我能清楚地解释一下 - 我以前从未在这里发布过!
我很感激您提供的任何帮助.谢谢!
更新 - 感谢@ MyKuLLSKI的回答,这给了我一个很棒的工作场所.
作为旁注,在这个想法的基础上,我尝试将它们保持为'List',并将"IgnoreSelectionChanged"作为一个"倒计时"的int(所以在设置ListPicker的ItemSource之前,我设置"IgnoreSelectionChanged + = 2" (考虑将被解雇的两个事件);类似地,我在手动设置SelectedIndex之前设置"IgnoreSelectionChanged ++"......这似乎也有效.
但是,使用绑定到ListPicker的"ObservableCollection"并依赖它来表示更改似乎比使用ListPicker自己的"SelectionChanged"事件更好,所以我将修改我的代码以使用它.
再次感谢!