Мой первый вопрос StackexChange, так что скажите мне, если я сделаю что -нибудь не так. Я добился успеха большую часть времени, но я применяю свою первую таблицу данных, включающую привязку данных. Похоже, что сложнее всего конвертировать, поскольку связывание обрабатывается в основном в XAML, а не коде. столбцы в виде сочетания. В настоящее время он представлен как число (1-10), но мне нужно описание, которое содержится с номером, которое находится в другой таблице в базе данных.
число, которое первоначально отображалось до того, как переключение его на ComboBox был нерезовым. Я хочу, чтобы это значение было выбранным в настоящее время элементом в Combobox. />[*]intcaseno
[*]newreferral
[*]screendate
[*]eligible
[*]noneligibilityreason(this is the one to make into a combobox)
noneligesse < /strong> (это подтабл, который согласуется с неэлигационнокоменной) < /p>
Неэлигрозонья < /li>
Код, который, по -видимому, что -то, что должно быть, что, по -видимому, что -то, что, по -видимому, что -то, что может быть соблюдение. Я думаю, ItemsSource: < /p>
NERList.GetNameValueList();
< /code>
Что касается элементов, я хочу все значения Nonelygreasondesc. Конечно, тогда есть вопрос, когда есть невидийность, чтобы соответствовать неэлигрозонномуиду. Я нашел этот пример, который, кажется, делает то же самое, но без базы данных вместо этого используя классы: < /p>
Я пытался дублировать это, так как я думал, что он должен работать здесь в моем XAML: < /p>
< /code>
< /p>
и код позади: < /p>
using CslaFactoryBusinessObjects;
...
namespace WpfTestProject
{
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
private void Window_Loaded(object sender, RoutedEventArgs e)
{
WpfTestProject.caseviewDataSet caseviewDataSet = ((WpfTestProject.caseviewDataSet)(this.FindResource("caseviewDataSet")));
// Load data into the table modreview. You can modify this code as needed.
WpfTestProject.caseviewDataSetTableAdapters.modreviewTableAdapter caseviewDataSetmodreviewTableAdapter = new WpfTestProject.caseviewDataSetTableAdapters.modreviewTableAdapter();
caseviewDataSetmodreviewTableAdapter.Fill(caseviewDataSet.modreview);
System.Windows.Data.CollectionViewSource modreviewViewSource = ((CollectionViewSource)(this.FindResource("modreviewViewSource")));
modreviewViewSource.View.MoveCurrentToFirst();
noneligibilityreasonColumn.ItemsSource = NERList.GetNameValueList();
}
}
< /code>
} < /p>
Большая часть этого кода была сгенерирована, когда я перетаскивал из источников данных, но последняя строка в коде - это то, где я думаю, я должен был добавить элементы. Не уверен, что он принадлежит загруженному, но кажется, что там может быть нормально. Также не уверен, есть ли способ сделать это в XAML. Кодекса). Я думаю, что он использует скрытый Combobox для настройки привязки, затем добавляет его в таблицу: < /p>
//from Program.cs used in setupModRvwGrdHdr()
public static void ListControlBinding(ref UltraCombo comboBox, object lkupdataSource, string displayMember,
string valueMember, object objDataSource, string objProp) {
comboBox.DataSource = lkupdataSource;
comboBox.DisplayMember = displayMember;
if (!string.IsNullOrEmpty(valueMember))
comboBox.ValueMember = valueMember;
if (objDataSource != null)
comboBox.DataBindings.Add("Value", objDataSource, objProp);
}
//from the code for the specific winform
private void setupModRvwGrdHdr() {
cbNonEligReason.DataBindings.Clear();
grdModReviews.DataSource = bsModRvws;
Program.ListControlBinding(ref cbNonEligReason, NERList.GetNameValueList(), "Value", "Key", bsModRvws,
"NonEligibleReasonIDStr");
cbNonEligReason.DisplayLayout.Bands[0].Columns["Key"].Hidden = true;
cbNonEligReason.DisplayLayout.Bands[0].Columns["Value"].Header.Caption = "Noneligiblity Reason";
grdModReviews.DisplayLayout.Bands[0].Columns["reviewnum"].CellActivation = Activation.NoEdit;
grdModReviews.DisplayLayout.Bands[0].Columns["intcaseno"].Hidden = true;
grdModReviews.DisplayLayout.Bands[0].Columns["noneligibilityreason"].Hidden = true;
grdModReviews.DisplayLayout.Bands[0].Columns["screendate"].Hidden = false;
grdModReviews.DisplayLayout.Bands[0].Columns["screendate"].Header.Caption = "Date of Screen";
grdModReviews.DisplayLayout.Bands[0].Columns["screendate"].Width = 100;
grdModReviews.DisplayLayout.Bands[0].Columns["screendate"].EditorComponent = dteModRvwDate;
grdModReviews.DisplayLayout.Bands[0].Columns["eligible"].Hidden = false;
grdModReviews.DisplayLayout.Bands[0].Columns["eligible"].Header.Caption = "Eligible";
grdModReviews.DisplayLayout.Bands[0].Columns["eligible"].Width = 70;
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].Hidden = false;
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].Header.Caption =
"Reason for Noneligibility";
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].Width = 250;
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].EditorComponent = cbNonEligReason;
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].Nullable =
Infragistics.Win.UltraWinGrid.Nullable.Nothing;
}
< /code>
Это довольно большая программа, и в классах CslafactorybusinessObjects могут быть некоторые полезные функции, но я должен научиться сделать это, чтобы лучше понять манипуляции с данными в WPF. Я просто не уверен, как работает каждое из связующих свойств и как они применяются в этом конкретном случае. Наконец пришлось добавить полотенце и сделать аккаунт здесь. Извините за длину, но я хотел быть конкретным и показать, что я был в этом некоторое время. < /P>
Пожалуйста, помогите! < /P>
Подробнее здесь: https://stackoverflow.com/questions/314 ... base-table
Установка itemsource в DataGridComboboxColumn с использованием отдельной таблицы баз данных ⇐ C#
Место общения программистов C#
1755429000
Anonymous
Мой первый вопрос StackexChange, так что скажите мне, если я сделаю что -нибудь не так. Я добился успеха большую часть времени, но я применяю свою первую таблицу данных, включающую привязку данных. Похоже, что сложнее всего конвертировать, поскольку связывание обрабатывается в основном в XAML, а не коде. столбцы в виде сочетания. В настоящее время он представлен как число (1-10), но мне нужно описание, которое содержится с номером, которое находится в другой таблице в базе данных.
число, которое первоначально отображалось до того, как переключение его на ComboBox был нерезовым. Я хочу, чтобы это значение было выбранным в настоящее время элементом в Combobox. />[*]intcaseno
[*]newreferral
[*]screendate
[*]eligible
[*][b]noneligibilityreason[/b](this is the one to make into a combobox)
noneligesse < /strong> (это подтабл, который согласуется с неэлигационнокоменной) < /p>
Неэлигрозонья < /li>
Код, который, по -видимому, что -то, что должно быть, что, по -видимому, что -то, что, по -видимому, что -то, что может быть соблюдение. Я думаю, ItemsSource: < /p>
NERList.GetNameValueList();
< /code>
Что касается элементов, я хочу все значения Nonelygreasondesc. Конечно, тогда есть вопрос, когда есть невидийность, чтобы соответствовать неэлигрозонномуиду. Я нашел этот пример, который, кажется, делает то же самое, но без базы данных вместо этого используя классы: < /p>
Я пытался дублировать это, так как я думал, что он должен работать здесь в моем XAML: < /p>
< /code>
< /p>
и код позади: < /p>
using CslaFactoryBusinessObjects;
...
namespace WpfTestProject
{
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
}
private void Window_Loaded(object sender, RoutedEventArgs e)
{
WpfTestProject.caseviewDataSet caseviewDataSet = ((WpfTestProject.caseviewDataSet)(this.FindResource("caseviewDataSet")));
// Load data into the table modreview. You can modify this code as needed.
WpfTestProject.caseviewDataSetTableAdapters.modreviewTableAdapter caseviewDataSetmodreviewTableAdapter = new WpfTestProject.caseviewDataSetTableAdapters.modreviewTableAdapter();
caseviewDataSetmodreviewTableAdapter.Fill(caseviewDataSet.modreview);
System.Windows.Data.CollectionViewSource modreviewViewSource = ((CollectionViewSource)(this.FindResource("modreviewViewSource")));
modreviewViewSource.View.MoveCurrentToFirst();
noneligibilityreasonColumn.ItemsSource = NERList.GetNameValueList();
}
}
< /code>
} < /p>
Большая часть этого кода была сгенерирована, когда я перетаскивал из источников данных, но последняя строка в коде - это то, где я думаю, я должен был добавить элементы. Не уверен, что он принадлежит загруженному, но кажется, что там может быть нормально. Также не уверен, есть ли способ сделать это в XAML. Кодекса). Я думаю, что он использует скрытый Combobox для настройки привязки, затем добавляет его в таблицу: < /p>
//from Program.cs used in setupModRvwGrdHdr()
public static void ListControlBinding(ref UltraCombo comboBox, object lkupdataSource, string displayMember,
string valueMember, object objDataSource, string objProp) {
comboBox.DataSource = lkupdataSource;
comboBox.DisplayMember = displayMember;
if (!string.IsNullOrEmpty(valueMember))
comboBox.ValueMember = valueMember;
if (objDataSource != null)
comboBox.DataBindings.Add("Value", objDataSource, objProp);
}
//from the code for the specific winform
private void setupModRvwGrdHdr() {
cbNonEligReason.DataBindings.Clear();
grdModReviews.DataSource = bsModRvws;
Program.ListControlBinding(ref cbNonEligReason, NERList.GetNameValueList(), "Value", "Key", bsModRvws,
"NonEligibleReasonIDStr");
cbNonEligReason.DisplayLayout.Bands[0].Columns["Key"].Hidden = true;
cbNonEligReason.DisplayLayout.Bands[0].Columns["Value"].Header.Caption = "Noneligiblity Reason";
grdModReviews.DisplayLayout.Bands[0].Columns["reviewnum"].CellActivation = Activation.NoEdit;
grdModReviews.DisplayLayout.Bands[0].Columns["intcaseno"].Hidden = true;
grdModReviews.DisplayLayout.Bands[0].Columns["noneligibilityreason"].Hidden = true;
grdModReviews.DisplayLayout.Bands[0].Columns["screendate"].Hidden = false;
grdModReviews.DisplayLayout.Bands[0].Columns["screendate"].Header.Caption = "Date of Screen";
grdModReviews.DisplayLayout.Bands[0].Columns["screendate"].Width = 100;
grdModReviews.DisplayLayout.Bands[0].Columns["screendate"].EditorComponent = dteModRvwDate;
grdModReviews.DisplayLayout.Bands[0].Columns["eligible"].Hidden = false;
grdModReviews.DisplayLayout.Bands[0].Columns["eligible"].Header.Caption = "Eligible";
grdModReviews.DisplayLayout.Bands[0].Columns["eligible"].Width = 70;
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].Hidden = false;
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].Header.Caption =
"Reason for Noneligibility";
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].Width = 250;
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].EditorComponent = cbNonEligReason;
grdModReviews.DisplayLayout.Bands[0].Columns["NonEligibleReasonIDStr"].Nullable =
Infragistics.Win.UltraWinGrid.Nullable.Nothing;
}
< /code>
Это довольно большая программа, и в классах CslafactorybusinessObjects могут быть некоторые полезные функции, но я должен научиться сделать это, чтобы лучше понять манипуляции с данными в WPF. Я просто не уверен, как работает каждое из связующих свойств и как они применяются в этом конкретном случае. Наконец пришлось добавить полотенце и сделать аккаунт здесь. Извините за длину, но я хотел быть конкретным и показать, что я был в этом некоторое время. < /P>
Пожалуйста, помогите! < /P>
Подробнее здесь: [url]https://stackoverflow.com/questions/31482083/setting-itemsource-in-datagridcomboboxcolumn-using-separate-database-table[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия