Импорт таблицы перестал работать
Atom Ответить
14.01.2013


Код состоит из следующих элементов:

Код

private QuikTrader _trader;
private readonly MyTradesWindow _myTradesWindow = new MyTradesWindow();
_trader.NewMyTrades += trades => this.GuiAsync(() => _myTradesWindow.Trades.AddRange(trades));

string tstr = "А вот и мои сделочки: \n";
foreach (var myTrade in _myTradesWindow.Trades)
{
    var trade = myTrade.Trade;
    tstr = tstr + string.Format("Сделка {0} по цене {1} по бумаге {2} по объему {3} в {4}.\n", trade.Id, trade.Price, trade.Security.Code, trade.Volume, trade.Time);
}
tradestb.Text = tstr;


В итоге в TextBox выводится только инициализированная строка tstr, без сделок. Весь день ушёл на поиск причины, хотя ещё в пятницу табличка выводилась. Код не менял. В то же время стакан, например, выводится как надо. В чём может быть проблема?

Теги:


Спасибо:




24 Ответов
Den

Фотография
Дата: 14.01.2013
Ответить


Творог Перейти

В итоге в TextBox выводится только инициализированная строка tstr, без сделок. Весь день ушёл на поиск причины, хотя ещё в пятницу табличка выводилась. Код не менял. В то же время стакан, например, выводится как надо. В чём может быть проблема?


Трейдер синхронный или нет?

Возможно причина та же самая, что и у меня: не приходит newStopOrders
Спасибо:

Творог

Фотография
Дата: 14.01.2013
Ответить


Den Перейти

Трейдер синхронный или нет?

Возможно причина та же самая, что и у меня: не приходит newStopOrders


Попробовал подставить оба варианта _trader.IsAsyncMode = true; и _trader.IsAsyncMode = false;
Но всё равно вижу только строку в текстбоксе А вот и мои сделочки:
Автор топика
Спасибо:

Moadip

Фотография
Автор статей Программист
Дата: 15.01.2013
Ответить


Цитата:
Импорт таблицы перестал работать

Так а что изменилось то? Сборку новую скачали? Так и пишите тогда, и номер.

Тут, если все правильно понимаю, вы передаете пришедшие сделки в отдельное окно.
Код

private readonly MyTradesWindow _myTradesWindow = new MyTradesWindow();
_trader.NewMyTrades += trades => this.GuiAsync(() => _myTradesWindow.Trades.AddRange(trades));


Логично предположить что где - то это окно потом показывается. В котором должны показываться сделки
Код

_myTradesWindow.Show()


Но вот эти строчки не совсем понятны
Код

foreach (var myTrade in _myTradesWindow.Trades)
{
    var trade = myTrade.Trade;
    tstr = tstr + string.Format("Сделка {0} по цене {1} по бумаге {2} по объему {3} в {4}.\n", trade.Id, trade.Price, trade.Security.Code, trade.Volume, trade.Time);
}


В каком месте этот код обрабатывается? Явно не внутри _myTradesWindow.
Т.е. получается что в двух местах что ли информация о сделках показывается?
В каком то виде в окне _myTradesWindow и еще в текстбоксе?

Если только в текстбоксе, то проще сделать так
Код

private QuikTrader _trader;
string tstr = "А вот и мои сделочки: \n";

_trader.NewMyTrades += trades => this.GuiAsync(() => 
{
    foreach (var myTrade in trades)
    {
        var trade = myTrade.Trade;
        tstr += string.Format("Сделка {0} по цене {1} по бумаге {2} по объему {3} в {4}.\n", trade.Id, trade.Price, trade.Security.Code, trade.Volume, trade.Time);
    {
    tradestb.Text = tstr;
});


Теперь в чем может быть причина.
Проверьте срабатывает ли событие NewMyTrades.
Если срабатывает, то посмотрите что находится внутри trades, точнее в одной из сделок var trade = myTrade.Trade;
Есть ли в trade данные.
Спасибо: Творог

Творог

Фотография
Дата: 15.01.2013
Ответить


Ага, я просто конструкцию типа
Код
_trader.NewMyTrades += trades => this.GuiAsync(() => 
{
    foreach (var myTrade in trades)
    {


закомментил, и написал ту, которая выше. Там была проблема, что почему-то выводились только новые сделки при их появлении.

А почему тот блок который я опубликовал нежизнеспособен?
Автор топика
Спасибо:

Творог

Фотография
Дата: 15.01.2013
Ответить


И вот ещё вопросец по теме. Допустим я хочу вставить таблицу в форму и для этого вставляю следующий код

Код
        <ListView HorizontalAlignment="Left" Height="339" Margin="435,391,0,0" VerticalAlignment="Top" Width="628" x:Name="TradesDetails" Grid.Column="0" Grid.Row="0" ItemsSource="{Binding ElementName=_myTradesWindow, Path=Trades}">
            <ListView.View>
                <GridView>
                    <GridViewColumn Width="90" Header="Номер" DisplayMemberBinding="{Binding Path=Trade.Id}" />
                    <GridViewColumn Width="120" Header="Время" DisplayMemberBinding="{Binding Path=Trade.Time}" />
                    <GridViewColumn Width="70" Header="Цена" DisplayMemberBinding="{Binding Path=Trade.Price}" />
                    <GridViewColumn Width="60" Header="Кол-во" DisplayMemberBinding="{Binding Path=Trade.Volume}" />
                    <GridViewColumn Width="100" Header="Инструмент" DisplayMemberBinding="{Binding Path=Trade.Security.Code}" />
                    <GridViewColumn Width="80" Header="Направление" DisplayMemberBinding="{Binding Path=Order.Direction}" />
                    <GridViewColumn Width="90" Header="Заявка" DisplayMemberBinding="{Binding Path=Order.Id}" />
                </GridView>
            </ListView.View>
        </ListView>


Табличка не заполняется (хотя _myTradesWindow.Show() показывает окно со сделками). Я так понимаю, должен где-то "TradesDetails" прописать и что-то ещё сделать?
Автор топика
Спасибо:

Moadip

Фотография
Автор статей Программист
Дата: 15.01.2013
Ответить


Цитата:
А почему тот блок который я опубликовал нежизнеспособен?

Ну почему не жизнеспособен.
Если кроме как добавления/вытаскивания во внутреннюю коллекцию Trades объекта _myTradesWindow вы этот объект никак не используете, то это избыточный код.

Если надо куда то складывать пришедшие сделки, сделайте отдельную коллекцию типа List<MyTrade>
Код

private List<MyTrade> _myTradeList = new List<MyTrade>();


Получается следующее(в вашем примере кода)

Код

private QuikTrader _trader;
private List<MyTrade> _myTradeList = new List<MyTrade>();
_trader.NewMyTrades += trades => this.GuiAsync(() => _myTradeList .AddRange(trades));
 
string tstr = "А вот и мои сделочки: \n";
foreach (var myTrade in myTradeList )
{
    var trade = myTrade.Trade;
    tstr = tstr + string.Format("Сделка {0} по цене {1} по бумаге {2} по объему {3} в {4}.\n", trade.Id, trade.Price, trade.Security.Code, trade.Volume, trade.Time);
}
tradestb.Text = tstr;
Спасибо: Творог

Moadip

Фотография
Автор статей Программист
Дата: 15.01.2013
Ответить


Творог Перейти
И вот ещё вопросец по теме. Допустим я хочу вставить таблицу в форму и для этого вставляю следующий код

Код
        <ListView HorizontalAlignment="Left" Height="339" Margin="435,391,0,0" VerticalAlignment="Top" Width="628" x:Name="TradesDetails" Grid.Column="0" Grid.Row="0" ItemsSource="{Binding ElementName=_myTradesWindow, Path=Trades}">
            <ListView.View>
                <GridView>
                    <GridViewColumn Width="90" Header="Номер" DisplayMemberBinding="{Binding Path=Trade.Id}" />
                    <GridViewColumn Width="120" Header="Время" DisplayMemberBinding="{Binding Path=Trade.Time}" />
                    <GridViewColumn Width="70" Header="Цена" DisplayMemberBinding="{Binding Path=Trade.Price}" />
                    <GridViewColumn Width="60" Header="Кол-во" DisplayMemberBinding="{Binding Path=Trade.Volume}" />
                    <GridViewColumn Width="100" Header="Инструмент" DisplayMemberBinding="{Binding Path=Trade.Security.Code}" />
                    <GridViewColumn Width="80" Header="Направление" DisplayMemberBinding="{Binding Path=Order.Direction}" />
                    <GridViewColumn Width="90" Header="Заявка" DisplayMemberBinding="{Binding Path=Order.Id}" />
                </GridView>
            </ListView.View>
        </ListView>


Табличка не заполняется (хотя _myTradesWindow.Show() показывает окно со сделками). Я так понимаю, должен где-то "TradesDetails" прописать и что-то ещё сделать?


Зачем изобретать велосипед когда уже есть все готовое? Советую изучить Stocksharp.Xaml.
Конкретно - TradeGrid.
Как работать с этими контролами есть в примерах.
Спасибо:

Творог

Фотография
Дата: 15.01.2013
Ответить


Moadip Перейти


Зачем изобретать велосипед когда уже есть все готовое? Советую изучить Stocksharp.Xaml.
Конкретно - TradeGrid.
Как работать с этими контролами есть в примерах.


Сорри, но в хэлпе чисто справочный материал и как им воспользоваться, в данном случае, я не очень понимаю. Указанный код я как раз и забрал у Sample. Можете привести простенький пример как вставить таблицу с коллекцией в свою форму?
Автор топика
Спасибо:

Moadip

Фотография
Автор статей Программист
Дата: 15.01.2013
Ответить


Xaml

Cs
Test.rar 7 MB (0)
Спасибо:

Творог

Фотография
Дата: 15.01.2013
Ответить


Moadip, а если понадобится сделать кастомный набор колонок, эта строка как-то редактируется для вывода только нужной инфы? Ну например, как добавить столбик Ставка РЕПО?
<xaml:TradeGrid x:Name="TradeGrid" Grid.Row="2"/>
Автор топика
Спасибо:

Moadip

Фотография
Автор статей Программист
Дата: 15.01.2013
Ответить


Нет, это готовый контрол. Если нужен кастомный набор, то тогда разбираться с примерами.
Посмотрел примеры, думал там готовый контрол используется. Но там как раз кастомный набор колонок делается в ListView.
Спасибо:

VassilSanych

Фотография
Дата: 15.01.2013
Ответить


Moadip Перейти
Если надо куда то складывать пришедшие сделки, сделайте отдельную коллекцию типа List<MyTrade>
+1
Использовать визуальный контрол в качестве промежуточного хранилища информации - это плохой стиль.

Спасибо:

Творог

Фотография
Дата: 16.01.2013
Ответить


А почему моя встроенная в форму табличка (пост #6) компилируется, но не выводится?
Автор топика
Спасибо:

VassilSanych

Фотография
Дата: 16.01.2013
Ответить


Творог Перейти
А почему моя встроенная в форму табличка (пост #6) компилируется, но не выводится?

Во-первых, для проброса изменений в XAML необходимо реализовывать INotifyPropertyChanged или использовать специальные коллекции и назначать их источником данных в коде,
во-вторых, если в Binding есть ошибки, WPF об этом не скажет. Просто не будут подтягиваться данные и всё.

Спасибо:

Творог

Фотография
Дата: 16.01.2013
Ответить


Честно говоря, не очень понимаю как это реализовывать на практике. С примером было бы легче.

Вот я создаю новую коллекцию
Код
private readonly List<MyTrade> _myTradeList = new List<MyTrade>();


Подписываюсь
Код
_trader.NewMyTrades += trades => this.GuiAsync(() => _myTradeList.AddRange(trades));


Пытаюсь вывести
Код
<ListView ItemsSource="{Binding ElementName=_myTradeList, Path=Trades}">
            <ListView.View>
                <GridView>
                    <GridViewColumn Width="90" Header="Номер" DisplayMemberBinding="{Binding Path=Trade.Id}" />
                    ......


Что не так?

P.S.
Рискнул предположить, что это другой тип коллекции

Код
private readonly ObservableCollection<MyTrade> _myTradeList = new ObservableCollection<MyTrade>();


но это ничего не меняет. По крайней мере в моём коде.
Автор топика
Спасибо:

Moadip

Фотография
Автор статей Программист
Дата: 16.01.2013
Ответить


Цитата:
Рискнул предположить, что это другой тип коллекции

Правильно рискнули.Smile
Т.к. ObservableCollection реализует интерфейс INotifyPropertyChanged.

В примерах как раз данная коллекция и используется:
Код

	public partial class MyTradesWindow
	{
		public MyTradesWindow()
		{
			Trades = new ObservableCollection<MyTrade>();
			InitializeComponent();
		}

		public ObservableCollection<MyTrade> Trades { get; private set; }
	}


Цитата:

Пытаюсь вывести
Код

<ListView ItemsSource="{Binding ElementName=_myTradeList, Path=Trades}">
            <ListView.View>
                <GridView>
                    <GridViewColumn Width="90" Header="Номер" DisplayMemberBinding="{Binding Path=Trade.Id}" />
                    ......


Что не так?


Вы понимаете смысл написанного?
Код
ItemsSource="{Binding ElementName=_myTradeList, Path=Trades}"


Чтобы не выносить себе мозг привязкой в Xaml, делайте привязку в коде.
Удалите это ItemsSource="{Binding ElementName=_myTradeList, Path=Trades}", обзовите как нибудь ListView, например MyTrades
Код

<ListView x:Name="MyTrades">
            <ListView.View>
                <GridView>
                    <GridViewColumn Width="90" Header="Номер" DisplayMemberBinding="{Binding Path=Trade.Id}" />
                    ......


В коде, в конструкторе главного окна сделайте привязку.
Код

		public MainWindow()
		{
			InitializeComponent();
			MyTrades.ItemsSource = _myTradeList;
		}


И все будет работать.
А на досуге почитайте про привязку данных. Там на этом сайте вообще много чего интересного можно найти, чтобы подтянуть свои знания по C#/WPF
Спасибо: Творог

Творог

Фотография
Дата: 16.01.2013
Ответить


Теперь всё ясно. Как раз строка ItemsSource="{Binding ElementName=_myTradesWindow, Path=Trades}" в примере меня и запутала.
Автор топика
Спасибо:

Творог

Фотография
Дата: 17.01.2013
Ответить


А как сказать программе нарисовать мне табличку со стаканом?

Делаю так
Код
private ObservableCollection<MarketDepth> _ri = new ObservableCollection<MarketDepth>();
RiQuotes.ItemsSource = _trader.GetMarketDepth("RIH3@RTS"); // тут стринги не принимаются


или как-то так
Код
_trader.MarketDepthsChanged += depths => this.GuiAsync(() => RiQuotes.ItemsSource = _ri.AddRange(depths);


Вывод сюда

Код
        <ListView x:Name="RiQuotes" HorizontalAlignment="Left" Height="567" VerticalAlignment="Top" Width="254" Margin="-4,163,0,0">
            <ListView.View>
                <GridView>
                    <GridViewColumn Width="70" Header="Продажа" DisplayMemberBinding="{Binding Path=Ask}" />
                    <GridViewColumn Width="100" Header="Цена" DisplayMemberBinding="{Binding Path=Price}" />
                    <GridViewColumn Width="70" Header="Покупка" DisplayMemberBinding="{Binding Path=Bid}" />
                </GridView>
            </ListView.View>
        </ListView>


Или так, но это тоже бред какой-то
Код
_trader.MarketDepthsChanged += depths => this.GuiAsync(() => RiQuotes.ItemsSource = _ri.GetMarketDepth((Security)"RIH3@RTS");


В примерах, например, выще не понятно, где в trader.RegisterMarketDepth(lkoh) берётся именно LKOH@EQBR
Автор топика
Спасибо:

NattyD

Фотография
Дата: 24.01.2013
Ответить


Код

private const string _ri_code = "RIH3";

.......................................

 _trader.NewSecurities += securities => 
                {
                    var ri = securities.FirstOrDefault(sec => sec.Code == _ri_code);
                    if (ri != null)
                    {
                        _ri = ri;
                        _trader.RegisterMarketDepth(_ri);
                        _trader.RegisterTrades(_ri);
                    }
                };
Спасибо:

Творог

Фотография
Дата: 24.01.2013
Ответить


А вот кстати я так и не смог найти описание функции FirstOrDefault. Интуитивно я догадываюсь что она делает, но всё же хотелось бы увидеть её описание.
Автор топика
Спасибо:

VassilSanych

Фотография
Дата: 24.01.2013
Ответить



Код
_trader.MarketDepthsChanged += depths => this.GuiAsync(() => RiQuotes.ItemsSource = _ri.AddRange(depths);


Этот код каждый раз меняет привязку. Простого обновления содержимого _ri будет достаточно.
Спасибо:

Alexander

Фотография
Дата: 24.01.2013
Ответить


Творог Перейти
А вот кстати я так и не смог найти описание функции FirstOrDefault. Интуитивно я догадываюсь что она делает, но всё же хотелось бы увидеть её описание.


Гугл в помощь. Он помогает. Часто.
Спасибо:

Den

Фотография
Дата: 24.01.2013
Ответить


Alexander Mukhanchikov Перейти
Творог Перейти
А вот кстати я так и не смог найти описание функции FirstOrDefault. Интуитивно я догадываюсь что она делает, но всё же хотелось бы увидеть её описание.


Гугл в помощь. Он помогает. Часто.


и ведь не поспоришь. супер ответ! +100500 )))

видел тут где-то в топиках ссылку на WPF, там и про LINQ оказалось.
продолжу распространять знания: http://www.professorweb....LINQ/base/level3/3_5.php
Спасибо:

Alexander

Фотография
Дата: 24.01.2013
Ответить


Мне кажется для всех таких вещей лучший источник - MSDN
Спасибо:


Добавить файлы через драг-н-дроп, , или вставить из буфера обмена.

loading
clippy