本文整理匯總了C#中System.Windows.Documents.List.Min方法的典型用法代碼示例。如果您正苦於以下問題:C# List.Min方法的具體用法?C# List.Min怎麽用?C# List.Min使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類System.Windows.Documents.List
的用法示例。
在下文中一共展示了List.Min方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: AddPlotSeries
private void AddPlotSeries(List<Tuple<List<Tuple<double, double>>, double>> ansv, double stepX, double stepY)
{
_stepX = stepX;
_stepY = stepY;
if (!_firstLoaded)
{
DrawGrid(ansv.Min(item => item.Item1.Min(it => it.Item1)), ansv.Max(item => item.Item1.Max(it => it.Item1)), stepX,
ansv.Min(item => item.Item1.Min(it => it.Item2)), ansv.Max(item => item.Item1.Max(it => it.Item2)), stepY);
PopulateSlider(ansv.Min(it => it.Item2), ansv.Max(it => it.Item2),
(from a in ansv from b in ansv let d = Math.Abs(a.Item2 - b.Item2) where a.Item1 != b.Item1 select d).Min());
}
_XandYandParam.Add(ansv);
Redraw();
}
示例2: On_GetDelayedButton_Click
private void On_GetDelayedButton_Click(object sender, RoutedEventArgs e)
{
List<Data> data = Data.Get_All();
if (data.Count == 0)
MessageBox.Show("No Data!");
else
{
List<TimeSpan> timeSpans = new List<TimeSpan>();
for (int i = 0; i < data.Count - 1; i++)
timeSpans.Add(data[i].LoggingOn - data[i + 1].LoggingOn);
if (timeSpans.Count != 0)
{
TimeSpan acceptTimeSpan = timeSpans.Min<TimeSpan>().Add(new TimeSpan(0, 0, Int32.Parse(Mistake_TextBox.Text)));
StringBuilder delayedStringBuilder = new StringBuilder();
int delayCounter = 0;
for (int i = 0; i < timeSpans.Count; i++)
{
if (timeSpans[i] > acceptTimeSpan)
{
delayedStringBuilder.AppendFormat("{0} == ({1})", data[i + 1].ToString(), timeSpans[i].ToString());
delayedStringBuilder.AppendLine();
delayCounter++;
}
}
delayedStringBuilder.AppendLine((delayCounter * 1.0 / data.Count).ToString());
Log_TextBox.Text = delayedStringBuilder.ToString();
}
}
}
示例3: MainWindow
public MainWindow()
{
InitializeComponent();
int highestPrice = 65;
List<int> vals = new List<int>() { 10, 20, 30, 40, 50 };
int min = vals.Min();
int max = vals.Max();
max = highestPrice > max ? highestPrice : max;
double range = max - min;
// Draw max in red
Color c = new Color() { ScA = 1, ScR = 1, ScG = 0, ScB = 0 };
// y = 0 is at the top of the canvas
var line = new Line() { X1 = 0, Y1 = 0, X2 = canvas.Width, Y2 = 0, Stroke = new SolidColorBrush(c), StrokeThickness = 2.0 };
canvas.Children.Add(line);
// Add txt so we can visualize better
var txt = new TextBlock() { Text = max.ToString() };
Canvas.SetLeft(txt, canvas.Width / 2);
Canvas.SetTop(txt, 0 - 9);
canvas.Children.Add(txt);
foreach (int val in vals)
{
double percent = 1.0 - ((val - min) / range); // 0 is at the top, so invert it by doing 1.0 - xxx
double y = percent * canvas.Height;
// Draw line in a shade of blue/green
c = new Color() { ScA = 1, ScR = 0, ScG = 0.5f, ScB = (float)percent };
line = new Line() { X1 = 0, Y1 = y, X2 = canvas.Width, Y2 = y, Stroke = new SolidColorBrush(c), StrokeThickness = 2.0 };
canvas.Children.Add(line);
// Add txt so we can visualize better
txt = new TextBlock() { Text = val.ToString() };
Canvas.SetLeft(txt, canvas.Width / 2);
Canvas.SetTop(txt, y - 9);
canvas.Children.Add(txt);
}
}
示例4: btn_simulate_Click
private void btn_simulate_Click(object sender, RoutedEventArgs e)
{
int nbrSim = Convert.ToInt32(txt_nbrsim.Text);
double initWealth = Properties.Settings.Default.InitWealth;
List<double> finalEarnings = new List<double>();
List<int> counts = new List<int>();
for (int i = 0; i < nbrSim; i++)
{
MartStrategy MStrat = new MartStrategy(5, 250, initWealth);
double bid = MStrat.Bet();
Number res;
double payoff;
int count = 0;
while (bid <= MStrat.Wealth)
{
MStrat.PlaceBet(bid);
res = _RGame.Play();
payoff = _RGame.GetPayoffColor(NumberColor.Red, bid, res);
MStrat.Setup(payoff);
bid = MStrat.Bet();
count++;
}
finalEarnings.Add(MStrat.Earnings-initWealth);
counts.Add(count);
}
txt_earnings.Text = finalEarnings.Average().ToString();
txt_plays.Text = counts.Average().ToString();
txt_maxEarnings.Text = finalEarnings.Max().ToString();
txt_maxLosses.Text = finalEarnings.Min().ToString();
txt_totEarnings.Text = finalEarnings.Where(x => x > 0).Sum().ToString();
txt_totLosses.Text = finalEarnings.Where(x => x < 0).Sum().ToString();
txt_balance.Text = finalEarnings.Sum().ToString();
}
示例5: GetPercentOfWeight
/// <summary>
/// This takes in a list of distances, and returns a list of percents (the int just comes along for the ride)
/// </summary>
private static List<Tuple<int, double>> GetPercentOfWeight(List<Tuple<int, double>> distances, double searchRadiusMultiplier)
{
const double OFFSET = .1d;
// Find the smallest distance in the list
double min = distances.Min(o => o.Item2);
// Figure out what the maximum possible distance would be
double maxRange = (min * searchRadiusMultiplier) - min;
// Figure out ratios based on distance
double[] ratios = new double[distances.Count];
for (int cntr = 0; cntr < ratios.Length; cntr++)
{
// Normalize the distance
ratios[cntr] = UtilityCore.GetScaledValue_Capped(0d, 1d, 0d, maxRange, distances[cntr].Item2 - min);
// Run it through a function
ratios[cntr] = 1d / (ratios[cntr] + OFFSET); // need to add an offset, because one of these will be zero
}
double total = ratios.Sum();
// Turn those ratios into percents (normalizing the ratios)
List<Tuple<int, double>> retVal = new List<Tuple<int, double>>();
for (int cntr = 0; cntr < ratios.Length; cntr++)
{
retVal.Add(new Tuple<int, double>(distances[cntr].Item1, ratios[cntr] / total));
}
// Exit Function
return retVal;
}
示例6: mmMove
/// <summary>
/// Make a move on the board
/// </summary>
/// <param name="board"></param>
/// <param name="player"></param>
/// <returns></returns>
private Tuple<int, int[]> mmMove(TTTBoard board, Player player)
{
if ((int)board.CheckWin() == 1)
{
return new Tuple<int, int[]>(Score(board.CheckWin()), new int[] { -1, -1 });
}
else if ((board.GetEmptySquares()).Count == (board.Dim * board.Dim))
{
return new Tuple<int, int[]>(0, new int[] { rnd.Next(board.Dim), rnd.Next(board.Dim) });
}
else if (board.GetEmptySquares().Count == 0)
{
return new Tuple<int, int[]>(Score(board.CheckWin()), new int[] { -1, -1 });
}
List<int> listScore = new List<int>();
List<int[]> listMove = new List<int[]>();
Player newPlayer = player == Player.PLAYERO ? Player.PLAYERX : Player.PLAYERO;
List<int[]> moves = board.GetEmptySquares();
foreach (int[] move in moves)
{
TTTBoard newBoard = board.Clone();
newBoard.Move(move[0], move[1], player);
int newScore = mmMove(newBoard, newPlayer).Item1;
listScore.Add(newScore);
listMove.Add(move);
if (player == Player.PLAYERX && newScore == 1) break;
else if (player == Player.PLAYERO && newScore == -1) break;
}
int[] moveNew;
int newScoreNew;
if (player == Player.PLAYERX)
{
newScoreNew = listScore.Max();
moveNew = listMove[listScore.IndexOf(newScoreNew)];
}
else
{
newScoreNew = listScore.Min();
moveNew = listMove[listScore.IndexOf(newScoreNew)];
}
return new Tuple<int, int[]>(newScoreNew, moveNew);
}
示例7: Button_Click
//比分的小按鈕事件
private void Button_Click(object sender, System.Windows.RoutedEventArgs e)
{
// TODO: Add event handler implementation here.
Button button = sender as Button;
SolidColorBrush b_Brush = (SolidColorBrush)(button.Background);
int ColorCount = 0;
if (b_Brush.Color.ToString() == "#FFFF0000")
{
foreach (StackPanel Stack in ((button.Parent as StackPanel).Parent as StackPanel).Children)
{
foreach (Button button2 in Stack.Children)
{
SolidColorBrush b_Brush2 = (SolidColorBrush)(button2.Background);
if (b_Brush2.Color.ToString() == "#FFFF0000")
{
ColorCount++;
}
}
}
if (ColorCount > 1)
{
button.Background = new SolidColorBrush(Colors.White);
}
}
else
{
button.Background = new SolidColorBrush(Colors.Red);
}
double SumMinOdds = 0.00;//指數和 最小
double SumMaxOdds = 0.00;//指數和 最大
double ProductMinOdds = 1.00;//指數積 最小
double ProductMaxOdds = 1.00;//指數積 最大
int ZhuCount = 1;
List<double> DoubleList = new List<double>();
var selfcols = this.DataGrid1.Columns[0];
foreach (var item in DataGrid1.ItemsSource)
{
//--對象所在的單元格
var cells = selfcols.GetCellContent(item);
if (cells != null)
{
//--單元格所包含的元素
Grid grid = cells as Grid;
StackPanel Sp = grid.Children[0] as StackPanel;
StackPanel Sp1 = Sp.Children[1] as StackPanel;
foreach (StackPanel StackPanel in Sp1.Children)
{
foreach (Button button1 in StackPanel.Children)
{
SolidColorBrush b_Brush1 = (SolidColorBrush)(button1.Background);
if (b_Brush1.Color.ToString() == "#FFFF0000")
{
DoubleList.Add(Netball.RetuntDouble(ToolTipService.GetToolTip(button1).ToString()));
}
}
}
ZhuCount *= DoubleList.Count;
SumMinOdds += DoubleList.Min();
SumMaxOdds += DoubleList.Max();
ProductMinOdds *= DoubleList.Min();
ProductMaxOdds *= DoubleList.Max();
}
DoubleList.Clear();
}
this.tbSum.Text = string.Format("{0:f2}", SumMinOdds) + "~" + string.Format("{0:f2}", SumMaxOdds);
this.tbProduct.Text = string.Format("{0:f2}", ProductMinOdds) + "~" + string.Format("{0:f2}", ProductMaxOdds);
this.tbPremium.Text = string.Format("{0:f2}", ProductMinOdds * 2) + "~" + string.Format("{0:f2}", ProductMaxOdds * 2);
}
示例8: RemoveFrames
private static List<Skeleton> RemoveFrames(List<Skeleton> skels, int nFrames)
{
int diff = skels.Count - nFrames;
List<Skeleton> result = new List<Skeleton>();
List<double> dists = new List<double>();
for (int i = 0; i < skels.Count - 1; i++)
{
dists.Add(GetDistBetweenFrames(skels.ElementAt(i), skels.ElementAt(i + 1)));
}
List<int> ignore = new List<int>();
int j = 0;
while (j < diff)
{
double min = dists.Min();
int index = dists.IndexOf(min);
if (index < skels.Count - 3)
{
ignore.Add(index);
j++;
}
dists.RemoveAt(index);
}
for (int i = 0; i < skels.Count; i++)
{
if (ignore.Contains(i))
{
continue;
}
result.Add(skels.ElementAt(i));
}
return AlignFrames(result, nFrames);
}
示例9: GetConnectionPointForAutoConnect
// Within the connection points with least number of connectors, get the one closest to the midpoint.
private static ConnectionPoint GetConnectionPointForAutoConnect(List<ConnectionPoint> availableConnectionPoints)
{
int minConnectorCount = availableConnectionPoints.Min<ConnectionPoint>((p) =>
{
return p.AttachedConnectors.Count;
});
List<ConnectionPoint> connectionPoints = new List<ConnectionPoint>(availableConnectionPoints.Where<ConnectionPoint>((p) =>
{
return p.AttachedConnectors.Count == minConnectorCount;
}));
ConnectionPoint midPoint = availableConnectionPoints[availableConnectionPoints.Count / 2];
if (connectionPoints.Contains(midPoint))
{
return midPoint;
}
double dist;
return ConnectionPoint.GetClosestConnectionPoint(connectionPoints, midPoint.Location, out dist);
}
示例10: FrmChild_PassDataBetweenForm
private void FrmChild_PassDataBetweenForm(object sender, PassDataWinFormEventArgs e)
{
this.Dispatcher.Invoke(new Action(delegate {
if (e.message == "文件讀取成功")
{ Finished_File--; }
win.FrontPage.Text += "\n" + e.Filename;
win.FrontPage.Text += "文件狀態:";
win.FrontPage.Text += e.message;
//結束讀取數據後,將所有時間匯總,並統計到文件中^_^
if (Finished_File == 0) {
win.Hide(); win.FrontPage.Text = "";
this.IsEnabled = true;
List<DateTime> All_File_Date = new List<DateTime>();
for (int i=0; i<Files.Count(); i++)
{
foreach(var date in Files[i].All_Date)
All_File_Date.Add(date);
}
start_time_calender.DisplayDateStart = All_File_Date.Min();
end_time_calender.DisplayDateStart = All_File_Date.Min();
start_time_calender.DisplayDateEnd = All_File_Date.Max();
end_time_calender.DisplayDateEnd = All_File_Date.Max();
start_time_calender.SelectedDate = All_File_Date.Min();
end_time_calender.SelectedDate = All_File_Date.Max();
output.IsEnabled = true;
}
win.scroll.ScrollToEnd();
}));
}
示例11: WrapItemsNewContainer
public static Tuple<DesignItem, Rect> WrapItemsNewContainer(IEnumerable<DesignItem> items, Type containerType, bool doInsert = true)
{
var collection = items;
var _context = collection.First().Context as XamlDesignContext;
var container = collection.First().Parent;
if (collection.Any(x => x.Parent != container))
return null;
//Change Code to use the Placment Operation!
var placement = container.Extensions.OfType<IPlacementBehavior>().FirstOrDefault();
if (placement == null)
return null;
var operation = PlacementOperation.Start(items.ToList(), PlacementType.Move);
var newInstance = _context.Services.ExtensionManager.CreateInstanceWithCustomInstanceFactory(containerType, null);
DesignItem newPanel = _context.Services.Component.RegisterComponentForDesigner(newInstance);
List<ItemPos> itemList = new List<ItemPos>();
foreach (var item in collection) {
itemList.Add(GetItemPos(operation, item));
//var pos = placement.GetPosition(null, item);
if (container.Component is Canvas) {
item.Properties.GetAttachedProperty(Canvas.RightProperty).Reset();
item.Properties.GetAttachedProperty(Canvas.LeftProperty).Reset();
item.Properties.GetAttachedProperty(Canvas.TopProperty).Reset();
item.Properties.GetAttachedProperty(Canvas.BottomProperty).Reset();
} else if (container.Component is Grid) {
item.Properties.GetProperty(FrameworkElement.HorizontalAlignmentProperty).Reset();
item.Properties.GetProperty(FrameworkElement.VerticalAlignmentProperty).Reset();
item.Properties.GetProperty(FrameworkElement.MarginProperty).Reset();
}
var parCol = item.ParentProperty.CollectionElements;
parCol.Remove(item);
}
var xmin = itemList.Min(x => x.Xmin);
var xmax = itemList.Max(x => x.Xmax);
var ymin = itemList.Min(x => x.Ymin);
var ymax = itemList.Max(x => x.Ymax);
foreach (var item in itemList) {
if (newPanel.Component is Canvas) {
if (item.HorizontalAlignment == HorizontalAlignment.Right) {
item.DesignItem.Properties.GetAttachedProperty(Canvas.RightProperty).SetValue(xmax - item.Xmax);
} else {
item.DesignItem.Properties.GetAttachedProperty(Canvas.LeftProperty).SetValue(item.Xmin - xmin);
}
if (item.VerticalAlignment == VerticalAlignment.Bottom) {
item.DesignItem.Properties.GetAttachedProperty(Canvas.BottomProperty).SetValue(ymax - item.Ymax);
} else {
item.DesignItem.Properties.GetAttachedProperty(Canvas.TopProperty).SetValue(item.Ymin - ymin);
}
newPanel.ContentProperty.CollectionElements.Add(item.DesignItem);
} else if (newPanel.Component is Grid) {
Thickness thickness = new Thickness(0);
if (item.HorizontalAlignment == HorizontalAlignment.Right) {
item.DesignItem.Properties.GetProperty(FrameworkElement.HorizontalAlignmentProperty).SetValue(HorizontalAlignment.Right);
thickness.Right = xmax - item.Xmax;
} else {
item.DesignItem.Properties.GetProperty(FrameworkElement.HorizontalAlignmentProperty).SetValue(HorizontalAlignment.Left);
thickness.Left = item.Xmin - xmin;
}
if (item.VerticalAlignment == VerticalAlignment.Bottom) {
item.DesignItem.Properties.GetProperty(FrameworkElement.VerticalAlignmentProperty).SetValue(VerticalAlignment.Bottom);
thickness.Bottom = ymax - item.Ymax;
} else {
item.DesignItem.Properties.GetProperty(FrameworkElement.VerticalAlignmentProperty).SetValue(VerticalAlignment.Top);
thickness.Top = item.Ymin - ymin;
}
item.DesignItem.Properties.GetProperty(FrameworkElement.MarginProperty).SetValue(thickness);
newPanel.ContentProperty.CollectionElements.Add(item.DesignItem);
} else if (newPanel.Component is Viewbox) {
newPanel.ContentProperty.SetValue(item.DesignItem);
}
}
if (doInsert)
{
PlacementOperation operation2 = PlacementOperation.TryStartInsertNewComponents(
container,
new[] {newPanel},
new[] {new Rect(xmin, ymin, xmax - xmin, ymax - ymin).Round()},
PlacementType.AddItem
);
operation2.Commit();
//.........這裏部分代碼省略.........
示例12: WrapItemsNewContainer
public static void WrapItemsNewContainer(IEnumerable<DesignItem> items, Type containerType)
{
var collection = items;
var _context = collection.First().Context as XamlDesignContext;
var oldContainer = collection.First().Parent;
if (collection.Any(x => x.Parent != oldContainer))
return;
var newInstance = Activator.CreateInstance(containerType);
DesignItem newPanel = _context.Services.Component.RegisterComponentForDesigner(newInstance);
var changeGroup = newPanel.OpenGroup("Wrap in Container");
List<ItemPos> itemList = new List<ItemPos>();
foreach (var item in collection) {
var itemPos = new ItemPos(){ DesignItem = item };
itemList.Add(itemPos);
if (oldContainer.Component is Canvas) {
var canvas = oldContainer.View as Canvas;
if (item.Properties.GetAttachedProperty(Canvas.RightProperty) != null && item.Properties.GetAttachedProperty(Canvas.RightProperty).IsSet) {
itemPos.HorizontalAlignment = HorizontalAlignment.Right;
itemPos.Xmax = canvas.ActualWidth - (double)item.Properties.GetAttachedProperty(Canvas.RightProperty).ValueOnInstance;
itemPos.Xmin = itemPos.Xmax - ((FrameworkElement)item.View).ActualWidth;
}
else if (item.Properties.GetAttachedProperty(Canvas.LeftProperty) != null && item.Properties.GetAttachedProperty(Canvas.LeftProperty).IsSet) {
itemPos.HorizontalAlignment = HorizontalAlignment.Left;
itemPos.Xmin = (double)item.Properties.GetAttachedProperty(Canvas.LeftProperty).ValueOnInstance;
itemPos.Xmax = itemPos.Xmin + ((FrameworkElement)item.View).ActualWidth;
} else {
itemPos.HorizontalAlignment = HorizontalAlignment.Left;
itemPos.Xmax = itemPos.Xmin + ((FrameworkElement)item.View).ActualWidth;
}
if (item.Properties.GetAttachedProperty(Canvas.BottomProperty) != null && item.Properties.GetAttachedProperty(Canvas.BottomProperty).IsSet) {
itemPos.VerticalAlignment = VerticalAlignment.Bottom;
itemPos.Ymax = canvas.ActualHeight - (double)item.Properties.GetAttachedProperty(Canvas.BottomProperty).ValueOnInstance;
itemPos.Ymin = itemPos.Ymax - ((FrameworkElement)item.View).ActualHeight;
}
else if (item.Properties.GetAttachedProperty(Canvas.TopProperty) != null && item.Properties.GetAttachedProperty(Canvas.TopProperty).IsSet) {
itemPos.VerticalAlignment = VerticalAlignment.Top;
itemPos.Ymin = (double)item.Properties.GetAttachedProperty(Canvas.TopProperty).ValueOnInstance;
itemPos.Ymax = itemPos.Ymin + ((FrameworkElement)item.View).ActualHeight;
} else {
itemPos.VerticalAlignment = VerticalAlignment.Top;
itemPos.Ymax = itemPos.Ymin + ((FrameworkElement)item.View).ActualHeight;
}
item.Properties.GetAttachedProperty(Canvas.RightProperty).Reset();
item.Properties.GetAttachedProperty(Canvas.LeftProperty).Reset();
item.Properties.GetAttachedProperty(Canvas.TopProperty).Reset();
item.Properties.GetAttachedProperty(Canvas.BottomProperty).Reset();
} else if (oldContainer.Component is Grid) {
var grid = oldContainer.View as Grid;
if ((HorizontalAlignment)item.Properties.GetProperty(FrameworkElement.HorizontalAlignmentProperty).ValueOnInstance == HorizontalAlignment.Right) {
itemPos.HorizontalAlignment = HorizontalAlignment.Right;
itemPos.Xmax = grid.ActualWidth - ((Thickness)item.Properties.GetProperty(FrameworkElement.MarginProperty).ValueOnInstance).Right;
itemPos.Xmin = itemPos.Xmax - ((FrameworkElement)item.View).ActualWidth;
} else {
itemPos.HorizontalAlignment = HorizontalAlignment.Left;
itemPos.Xmin = ((Thickness)item.Properties.GetProperty(FrameworkElement.MarginProperty).ValueOnInstance).Left;
itemPos.Xmax = itemPos.Xmin + ((FrameworkElement)item.View).ActualWidth;
}
if ((VerticalAlignment)item.Properties.GetProperty(FrameworkElement.VerticalAlignmentProperty).ValueOnInstance == VerticalAlignment.Bottom) {
itemPos.VerticalAlignment = VerticalAlignment.Bottom;
itemPos.Ymax = grid.ActualHeight - ((Thickness)item.Properties.GetProperty(FrameworkElement.MarginProperty).ValueOnInstance).Bottom;
itemPos.Ymin = itemPos.Ymax - ((FrameworkElement)item.View).ActualHeight;
} else {
itemPos.VerticalAlignment = VerticalAlignment.Top;
itemPos.Ymin = ((Thickness)item.Properties.GetProperty(FrameworkElement.MarginProperty).ValueOnInstance).Top;
itemPos.Ymax = itemPos.Ymin + ((FrameworkElement)item.View).ActualHeight;
}
item.Properties.GetProperty(FrameworkElement.HorizontalAlignmentProperty).Reset();
item.Properties.GetProperty(FrameworkElement.VerticalAlignmentProperty).Reset();
item.Properties.GetProperty(FrameworkElement.MarginProperty).Reset();
}
var parCol = item.ParentProperty.CollectionElements;
parCol.Remove(item);
}
var xmin = itemList.Min(x => x.Xmin);
var xmax = itemList.Max(x => x.Xmax);
var ymin = itemList.Min(x => x.Ymin);
var ymax = itemList.Max(x => x.Ymax);
if (oldContainer.Component is Canvas) {
newPanel.Properties.GetProperty(FrameworkElement.WidthProperty).SetValue(xmax - xmin);
newPanel.Properties.GetProperty(FrameworkElement.HeightProperty).SetValue(ymax - ymin);
newPanel.Properties.GetAttachedProperty(Canvas.LeftProperty).SetValue(xmin);
newPanel.Properties.GetAttachedProperty(Canvas.TopProperty).SetValue(ymin);
} else if (oldContainer.Component is Grid) {
//.........這裏部分代碼省略.........
示例13: buttonScalingScore_Click
private void buttonScalingScore_Click(object sender, RoutedEventArgs e)
{
int cols, rows;
double horizLength, vertLength;
if (!parseChessboardParameters(out cols, out rows, out horizLength, out vertLength))
{
return;
}
// 以下改造
MotionDataHandler handler;
string path;
if (openMotionData(out handler, out path))
{
CvMat displayMat1 = null;
CvMat displayMat3 = null;
CvMat displayMat4 = null;
CvMat gray = null;
int length = handler.FrameCount;
if (length == 0) { return; }
CvSize boardSize = new CvSize(cols, rows);
CvSize imageSize = new CvSize();
List<Tuple<double, double>> pairs = new List<Tuple<double, double>>();
CvPoint2D32f[] lastCorners = null;
IEnumerable<CvMat> colorImages, depthImages;
Utility.LoadImages(handler.GetColorImagePaths(), out colorImages);
Utility.LoadImages(handler.GetDepthImagePaths(), out depthImages);
var images = colorImages.Zip(depthImages, (first, second) => Tuple.Create(first, second));
foreach (Tuple<CvMat, CvMat> imagePair in images)
{
CvMat imageMat = imagePair.Item1;
CvMat depthMat = imagePair.Item2;
if (displayMat4 == null)
{
displayMat4 = CvEx.InitCvMat(imageMat);
}
imageSize = new CvSize(imageMat.Cols, imageMat.Rows);
CvPoint2D32f[] corners;
int count;
CvEx.InitCvMat(ref gray, imageMat, MatrixType.U8C1);
imageMat.CvtColor(gray, ColorConversion.RgbToGray);
if (gray.FindChessboardCorners(boardSize, out corners, out count, ChessboardFlag.AdaptiveThresh))
{
CvEx.CloneCvMat(ref displayMat1, imageMat);
CvTermCriteria criteria = new CvTermCriteria(50, 0.01);
gray.FindCornerSubPix(corners, count, new CvSize(3, 3), new CvSize(-1, -1), criteria);
CvPoint3D32f?[] cornerPoints = new CvPoint3D32f?[corners.Length];
for (int j = 0; j < corners.Length; j++)
{
CvPoint2D32f corner = corners[j];
double? value = CalcEx.BilateralFilterDepthMatSinglePixel(corner, depthMat, 100, 4, 9);
if (value.HasValue)
{
cornerPoints[j] = new CvPoint3D32f(corner.X, corner.Y, value.Value);
}
}
for (int x = 0; x < cols; x++)
{
for (int y = 0; y < rows; y++)
{
if (!cornerPoints[x + y * cols].HasValue)
continue;
CvPoint3D32f point1 = cornerPoints[x + y * cols].Value;
CvPoint3D64f undistortPoint1 = this.UndistortionData.GetRealFromScreenPos(point1, imageSize);
foreach (var offset in new[] { new { X = 1, Y = 0, D = horizLength }, new { X = 0, Y = 1, D = vertLength } })
{
int dx = x + offset.X;
int dy = y + offset.Y;
if (dx >= cols || dy >= rows)
continue;
if (!cornerPoints[dx + dy * cols].HasValue)
continue;
CvPoint3D32f point2 = cornerPoints[dx + dy * cols].Value;
CvPoint3D64f undistortPoint2 = this.UndistortionData.GetRealFromScreenPos(point2, imageSize);
double distance = Math.Sqrt(CvEx.GetDistanceSq(undistortPoint1, undistortPoint2));
double scale = distance / offset.D;
CvColor color = CalcEx.HSVtoRGB(Math.Max(0, Math.Min(300, scale * 600 - 450)), scale, 2 - scale);
displayMat4.DrawLine((int)point1.X, (int)point1.Y, (int)point2.X, (int)point2.Y, new CvScalar(color.R, color.G, color.B), 1, LineType.AntiAlias);
pairs.Add(new Tuple<double, double>(distance, offset.D));
}
}
}
CvEx.DrawChessboardCornerFrame(displayMat1, boardSize, corners, new CvScalar(64, 128, 64));
displayMat1.DrawChessboardCorners(boardSize, corners, true);
lastCorners = corners;
putImage(displayMat1, PixelFormats.Rgb24);
}
else
{
CvEx.CloneCvMat(ref displayMat3, imageMat);
putImage(displayMat3, PixelFormats.Rgb24);
}
}
//.........這裏部分代碼省略.........
示例14: Timer_Tick
//初始化指數和、指數積、獎金的方法
void Timer_Tick(object sender, EventArgs e)
{
//throw new NotImplementedException();
string[] ZhuArr = null;
string ButtonContext = string.Empty;
int i = 0;
double SumMinOdds = 0.00;//指數和 最小
double SumMaxOdds = 0.00;//指數和 最大
double ProductMinOdds = 1.00;//指數積 最小
double ProductMaxOdds = 1.00;//指數積 最大
List<double> DoubleList = new List<double>();
var selfcols = this.DataGrid1.Columns[0];
foreach (var item in DataGrid1.ItemsSource)
{
//--對象所在的單元格
var cells = selfcols.GetCellContent(item);
if (cells != null)
{
//--單元格所包含的元素
Grid grid = cells as Grid;
StackPanel Sp = grid.Children[0] as StackPanel;
StackPanel Sp1 = Sp.Children[1] as StackPanel;
ZhuArr = GameNumber[i].Substring(GameNumber[i].IndexOf('(') + 1, GameNumber[i].LastIndexOf(')') - GameNumber[i].IndexOf('(') - 1).Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries);
foreach (string s in ZhuArr)
{
Button b = ReturnShowNum(Sp1.Children[0] as StackPanel, s);
if (b == null)
{
b = ReturnShowNum(Sp1.Children[1] as StackPanel, s);
if (b == null)
{
b = ReturnShowNum(Sp1.Children[2] as StackPanel, s);
}
}
if (b != null)
{
b.Background = new SolidColorBrush(Colors.Red);//改變按鈕顏色
DoubleList.Add(Netball.RetuntDouble(ToolTipService.GetToolTip(b).ToString()));
}
}
SumMinOdds += DoubleList.Min();
SumMaxOdds += DoubleList.Max();
ProductMinOdds *= DoubleList.Min();
ProductMaxOdds *= DoubleList.Max();
}
i++;
DoubleList.Clear();
}
this.tbSum.Text = string.Format("{0:f2}", SumMinOdds) + "~" + string.Format("{0:f2}", SumMaxOdds);
this.tbProduct.Text = string.Format("{0:f2}", ProductMinOdds) + "~" + string.Format("{0:f2}", ProductMaxOdds);
this.tbPremium.Text = string.Format("{0:f2}", ProductMinOdds * 2) + "~" + string.Format("{0:f2}", ProductMaxOdds * 2);
Timer.Stop();
}
示例15: GetPercentOfWeight_OLD
private static List<Tuple<int, double>> GetPercentOfWeight_OLD(List<Tuple<int, double>> distances, double searchRadiusMultiplier)
{
const double AMOUNTATMAX = .01d;
double min = distances.Min(o => o.Item2);
double max = min * searchRadiusMultiplier * 10; // making max greater so that there is more of a distance
// The equation will be y=1/kx
// Where x is the distance from center
// So solving for k, k=1/xy
double k = 1d / (max * AMOUNTATMAX);
double[] scaled = distances.Select(o => 1d / (k * o.Item2)).ToArray();
double total = scaled.Sum();
List<Tuple<int, double>> retVal = new List<Tuple<int, double>>();
for (int cntr = 0; cntr < distances.Count; cntr++)
{
retVal.Add(new Tuple<int, double>(distances[cntr].Item1, scaled[cntr] / total));
}
// Exit Function
return retVal;
}