當前位置: 首頁>>代碼示例>>C#>>正文


C# Rect.Intersect方法代碼示例

本文整理匯總了C#中Windows.Foundation.Rect.Intersect方法的典型用法代碼示例。如果您正苦於以下問題:C# Rect.Intersect方法的具體用法?C# Rect.Intersect怎麽用?C# Rect.Intersect使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Windows.Foundation.Rect的用法示例。


在下文中一共展示了Rect.Intersect方法的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: RectsOverlap

 private static bool RectsOverlap(Rect r1, Rect r2)
 {
     r1.Intersect(r2);
     if (r1.Width > 0 || r1.Height > 0)
         return true;
     return false;
 }
開發者ID:HeberAlvarez,項目名稱:HeadFirst,代碼行數:7,代碼來源:BeeStarModel.cs

示例2: GetCoordinatesInView

        public Point GetCoordinatesInView()
        {
            // TODO reasearch posibility to replace this code to GetClickablePoint()
            var visualRoot = WiniumVirtualRoot.Current.VisualRoot.Element;
            var element = this.Element;

            var point = element.TransformToVisual(visualRoot).TransformPoint(new Point(0, 0));
            var center = new Point(point.X + (int)(element.ActualWidth / 2), point.Y + (int)(element.ActualHeight / 2));
            var bounds = new Rect(point, new Size(element.ActualWidth, element.ActualHeight));
            var boundsInView = new Rect(new Point(0, 0), visualRoot.RenderSize);
            boundsInView.Intersect(bounds);

            var result = boundsInView.IsEmpty
                             ? center
                             : new Point(
                                   boundsInView.X + (int)(boundsInView.Width / 2), 
                                   boundsInView.Y + (int)(boundsInView.Height / 2));
            return ScreenCoordinatesHelper.LogicalPointToScreenPoint(result);
        }
開發者ID:krishachetan89,項目名稱:Winium.StoreApps,代碼行數:19,代碼來源:WiniumElement.Location.cs

示例3: PlacePopup

        private Point PlacePopup(Rect window, Point[] target, Point[] flyout, PlacementMode placement)
        {
            Point[] pointArray;
            double y = 0.0;
            double x = 0.0;
            Rect bounds = GetBounds(target);
            Rect rect2 = GetBounds(flyout);
            double width = rect2.Width;
            double height = rect2.Height;
            if (placement == PlacementMode.Right)
            {
                double num5 = Math.Max(0.0, target[0].X);
                double num6 = window.Width - Math.Min(window.Width, target[1].X + 1.0);
                if ((num6 < width) && (num6 < num5))
                {
                    placement = PlacementMode.Left;
                }
            }
            else if (placement == PlacementMode.Left)
            {
                double num7 = window.Width - Math.Min(window.Width, target[1].X + 1.0);
                double num8 = Math.Max(0.0, target[0].X);
                if ((num8 < width) && (num8 < num7))
                {
                    placement = PlacementMode.Right;
                }
            }
            else if (placement == PlacementMode.Top)
            {
                double num9 = Math.Max(0.0, target[0].Y);
                double num10 = window.Height - Math.Min(window.Height, target[2].Y + 1.0);
                if ((num9 < height) && (num9 < num10))
                {
                    placement = PlacementMode.Bottom;
                }
            }
            else if (placement == PlacementMode.Bottom)
            {
                double num11 = Math.Max(0.0, target[0].Y);
                double num12 = window.Height - Math.Min(window.Height, target[2].Y + 1.0);
                if ((num12 < height) && (num12 < num11))
                {
                    placement = PlacementMode.Top;
                }
            }
            switch (placement)
            {
                case PlacementMode.Bottom:
                    pointArray = new Point[] { new Point(target[2].X, Math.Max((double)0.0, (double)(target[2].Y + 1.0))), new Point((target[3].X - width) + 1.0, Math.Max((double)0.0, (double)(target[2].Y + 1.0))), new Point(0.0, Math.Max((double)0.0, (double)(target[2].Y + 1.0))) };
                    break;

                case PlacementMode.Right:
                    pointArray = new Point[] { new Point(Math.Max((double)0.0, (double)(target[1].X + 1.0)), target[1].Y), new Point(Math.Max((double)0.0, (double)(target[3].X + 1.0)), (target[3].Y - height) + 1.0), new Point(Math.Max((double)0.0, (double)(target[1].X + 1.0)), 0.0) };
                    break;

                case PlacementMode.Left:
                    pointArray = new Point[] { new Point(Math.Min(window.Width, target[0].X) - width, target[1].Y), new Point(Math.Min(window.Width, target[2].X) - width, (target[3].Y - height) + 1.0), new Point(Math.Min(window.Width, target[0].X) - width, 0.0) };
                    break;

                case PlacementMode.Top:
                    pointArray = new Point[] { new Point(target[0].X, Math.Min(target[0].Y, window.Height) - height), new Point((target[1].X - width) + 1.0, Math.Min(target[0].Y, window.Height) - height), new Point(0.0, Math.Min(target[0].Y, window.Height) - height) };
                    break;

                default:
                    pointArray = new Point[] { new Point(0.0, 0.0) };
                    break;
            }
            double num13 = width * height;
            int index = 0;
            double num15 = 0.0;
            for (int i = 0; i < pointArray.Length; i++)
            {
                Rect rect3 = new Rect(pointArray[i].X, pointArray[i].Y, width, height);
                rect3.Intersect(window);
                double d = rect3.Width * rect3.Height;
                if (double.IsInfinity(d))
                {
                    index = pointArray.Length - 1;
                    break;
                }
                if (d > num15)
                {
                    index = i;
                    num15 = d;
                }
                if (d == num13)
                {
                    index = i;
                    break;
                }
            }
            // x = pointArray[index].X;
            x = pointArray[0].X; // TODO: taking this solves my horizontal nudging, but is a hack...keeping it though until a better solution
            y = pointArray[index].Y;
            if (index > 1)
            {
                if ((placement == PlacementMode.Left) || (placement == PlacementMode.Right))
                {
                    if (((y != target[0].Y) && (y != target[1].Y)) && (((y + height) != target[0].Y) && ((y + height) != target[1].Y)))
                    {
//.........這裏部分代碼省略.........
開發者ID:larsduewel,項目名稱:callisto,代碼行數:101,代碼來源:Flyout.cs

示例4: CheckCollision

 //Check collision with flower and butterfly
 public void CheckCollision()
 {
     // get rectangles
     Rect r1 = new Rect(butterfly.LocationX, butterfly.LocationY, butterfly.ActualWidth, butterfly.ActualHeight);
     Rect r2 = new Rect(flower.LocationX, flower.LocationY, flower.ActualWidth, flower.ActualHeight);
     // does intersect...
     r1.Intersect(r2);
     if(!r1.IsEmpty) //not empty --> intersect happened
     {
         //remove flower
         MyCanvas.Children.Remove(flower);
         //play tada
         mediaElement.Play();
         //Add a new flower
         AddFlower();
     }
 }
開發者ID:FiraxisGlow,項目名稱:O-O-T,代碼行數:18,代碼來源:MainPage.xaml.cs

示例5: Blit

        public static void Blit(BitmapContext destContext, int dpw, int dph, Rect destRect, BitmapContext srcContext, Rect sourceRect, int sourceWidth)
        {
            const BlendMode blendMode = BlendMode.Alpha;

            int dw = (int)destRect.Width;
            int dh = (int)destRect.Height;

            Rect intersect = new Rect(0, 0, dpw, dph);
            intersect.Intersect(destRect);
            if (intersect.IsEmpty)
            {
                return;
            }
#if WPF
            var isPrgba = srcContext.Format == PixelFormats.Pbgra32 || srcContext.Format == PixelFormats.Prgba64 || srcContext.Format == PixelFormats.Prgba128Float;
#endif

            var sourcePixels = srcContext.Pixels;
            var destPixels = destContext.Pixels;
            int sourceLength = srcContext.Length;
            int sourceIdx = -1;
            int px = (int)destRect.X;
            int py = (int)destRect.Y;
            int x;
            int y;
            int idx;
            double ii;
            double jj;
            int sr = 0;
            int sg = 0;
            int sb = 0;
            int dr, dg, db;
            int sourcePixel;
            int sa = 0;
            int da;

            var sw = (int)sourceRect.Width;
            var sdx = sourceRect.Width / destRect.Width;
            var sdy = sourceRect.Height / destRect.Height;
            int sourceStartX = (int)sourceRect.X;
            int sourceStartY = (int)sourceRect.Y;
            int lastii, lastjj;
            lastii = -1;
            lastjj = -1;
            jj = sourceStartY;
            y = py;
            for (var j = 0; j < dh; j++)
            {
                if (y >= 0 && y < dph)
                {
                    ii = sourceStartX;
                    idx = px + y * dpw;
                    x = px;
                    sourcePixel = sourcePixels[0];

                    // Pixel by pixel copying
                    for (var i = 0; i < dw; i++)
                    {
                        if (x >= 0 && x < dpw)
                        {
                            if ((int)ii != lastii || (int)jj != lastjj)
                            {
                                sourceIdx = (int)ii + (int)jj * sourceWidth;
                                if (sourceIdx >= 0 && sourceIdx < sourceLength)
                                {
                                    sourcePixel = sourcePixels[sourceIdx];
                                    sa = ((sourcePixel >> 24) & 0xff);
                                    sr = ((sourcePixel >> 16) & 0xff);
                                    sg = ((sourcePixel >> 8) & 0xff);
                                    sb = ((sourcePixel) & 0xff);
                                }
                                else
                                {
                                    sa = 0;
                                }
                            }

                            if (sa > 0)
                            {
                                int destPixel = destPixels[idx];
                                da = ((destPixel >> 24) & 0xff);
                                if ((sa == 255 || da == 0))
                                {
                                    destPixels[idx] = sourcePixel;
                                }
                                else
                                {
                                    dr = ((destPixel >> 16) & 0xff);
                                    dg = ((destPixel >> 8) & 0xff);
                                    db = ((destPixel) & 0xff);
                                    var isa = 255 - sa;
#if NETFX_CORE
                                    // Special case for WinRT since it does not use pARGB (pre-multiplied alpha)
                                    destPixel = ((da & 0xff) << 24) |
                                                ((((sr * sa + isa * dr) >> 8) & 0xff) << 16) |
                                                ((((sg * sa + isa * dg) >> 8) & 0xff) <<  8) |
                                                (((sb * sa + isa * db) >> 8) & 0xff);
#elif WPF
                                    if (isPrgba)
                                    {
//.........這裏部分代碼省略.........
開發者ID:teichgraf,項目名稱:WriteableBitmapEx,代碼行數:101,代碼來源:WriteableBitmapBlitExtensions.cs

示例6: UpdateImageSource

            private void UpdateImageSource(Rect updateRectangle)
            {
                if (Window.Current.Visible)
                {
                    var imageRectangle = new Rect(new Point(), _canvasImageSource.Size);
                    updateRectangle.Intersect(imageRectangle);

                    using (var drawingSession = _canvasImageSource.CreateDrawingSession(Colors.Transparent, updateRectangle))
                    {
                        drawingSession.DrawImage(_accumulationRenderTarget); // Render target has the composed frame
                    }
                }
            }
開發者ID:mhdubose,項目名稱:Windows-universal-samples,代碼行數:13,代碼來源:GifView.xaml.cs

示例7: CheckCollision

 // Check Collision of Flower and Butterfly
 public void CheckCollision()
 {
     // Get Rectangles
     Rect r1 = new Rect(butterfly.LocationX, butterfly.LocationY, butterfly.ActualWidth, butterfly.ActualHeight);
     Rect r2 = new Rect(flower.LocationX, flower.LocationY, flower.ActualWidth, flower.ActualHeight);
     // Does Intersect...
     r1.Intersect(r2);
     if (!r1.IsEmpty) // Not Empty --> Intersected
     {
         // Remove Flower
         MyCanvas.Children.Remove(flower);
         // Play Tada
         mediaElement.Play();
         // Add a New Flower
         AddFlower();
     }
 }
開發者ID:Bjorter,項目名稱:Derpsauce-Coding,代碼行數:18,代碼來源:MainPage.xaml.cs

示例8: IsUserVisible

        internal bool IsUserVisible()
        {
            /* TODO: There is IsOffscreen method on AutomationPeer that can be used.
             * But it returns true even if currentElement is on another pivot (i.e. invisible)
             * var peer = FrameworkElementAutomationPeer.FromElement(this.Element);
             * return peer != null && peer.IsOffscreen();
             * This might improve speed but will make all non user interactable elements, like border, scrollbiew "invisible"
             */
            var visualRoot = WiniumVirtualRoot.Current.VisualRoot.Element;
            var currentElement = this.Element;

            var currentElementSize = new Size(currentElement.ActualWidth, currentElement.ActualHeight);

            // Check if currentElement is of zero size
            if (currentElementSize.Width <= 0 || currentElementSize.Height <= 0)
            {
                return false;
            }

            var zero = new Point(0, 0);

            var rect = new Rect(zero, currentElementSize);
            var bound = currentElement.TransformToVisual(visualRoot).TransformBounds(rect);
            var rootRect = new Rect(zero, visualRoot.RenderSize);
            rootRect.Intersect(bound);

            // Check if currentElement is offscreen. Save time on traversing tree if currentElement is not in root rect
            if (rootRect.IsEmpty)
            {
                return false;
            }

            while (true)
            {
                if (currentElement.Visibility != Visibility.Visible || !currentElement.IsHitTestVisible
                    || !(currentElement.Opacity > 0))
                {
                    return false;
                }

                var container = VisualTreeHelper.GetParent(currentElement) as FrameworkElement;
                if (container == null)
                {
                    return true;
                }

                if (container.RenderSize.IsEmpty)
                {
                    // There are some currentElements in UI tree that always return zero size, e.g. ContentControl, etc.
                    continue;
                }

                // FIXME we only check if currentElement is visible in parent and parent visible in his parent and so on
                // we do not actully check if any part of original currentElement is visible in grandparents
                currentElementSize = new Size(currentElement.ActualWidth, currentElement.ActualHeight);
                rect = new Rect(zero, currentElementSize);
                bound = currentElement.TransformToVisual(container).TransformBounds(rect);
                var containerRect = new Rect(zero, container.RenderSize);

                containerRect.Intersect(bound);

                // Check if currentElement is offscreen
                if (containerRect.IsEmpty)
                {
                    return false;
                }

                currentElement = container;
            }
        }
開發者ID:krishachetan89,項目名稱:Winium.StoreApps,代碼行數:70,代碼來源:WiniumElement.IsUserVisible.cs

示例9: CheckCollision

        //check collision with flower and butterfly
        public void CheckCollision()
        {
            //get rects
            Rect r1 = new Rect(butterfly.LocationX,butterfly.LocationY,butterfly.ActualWidth,butterfly.ActualHeight);
            Rect r2 = new Rect(flower.LocationX, flower.LocationY,flower.ActualWidth,flower.ActualHeight);

            //does intersect
            r1.Intersect(r2);
            if (!r1.IsEmpty) //not empty, intersect happened
            {
                // remove flower
                MyCanvas.Children.Remove(flower);
                // add a new flower
                AddFlower();
                //play sound
                mediaElement.Play();
                points++;
                textBlock.Text = points.ToString();
            }
        }
開發者ID:Lawryy,項目名稱:Ekat20tehtavaa,代碼行數:21,代碼來源:MainPage.xaml.cs

示例10: CheckBounds

        private bool CheckBounds(Vector2 bounds)
        {
            foreach(var rect in MapManager.Map)
            {
                var rectPac = new Rect(x + dx, y + dy, size, size);
                rectPac.Intersect(rect);
                if(!rectPac.IsEmpty)
                    return false;
            }

            return true;

            //if (x < -size)
            //{
            //    x = bounds.X;
            //}
            //else if (x > bounds.X)
            //{
            //    x = 0;
            //}

            //if (y < -size)
            //{
            //    y = bounds.Y;
            //}
            //else if (y > bounds.Y)
            //{
            //    y = 0;
            //}
        }
開發者ID:juanpaexpedite,項目名稱:MasterDetailsComposition,代碼行數:30,代碼來源:PacmanCharacter.cs

示例11: RectsOverlap

 /// <summary>
 /// Checks if two rectangles overlapping 
 /// </summary>
 /// <param name="r1">First rectangle</param>
 /// <param name="r2">Second rectangle</param>
 /// <returns>True if rectangles overlapping</returns>
 private static bool RectsOverlap(Rect r1, Rect r2)
 {
     r1.Intersect(r2); // Saves intersection rectangle to r1
     if (r1.Width > 0 || r1.Height > 0)
         return true;
     else
         return false;
 }
開發者ID:Arasz,項目名稱:StarrySky,代碼行數:14,代碼來源:BeeStarModel.cs

示例12: consillionMouseAnother

        public bool consillionMouseAnother(Image at)
        {
            Rect r1 = new Rect(Canvas.GetLeft(Mouse), Canvas.GetTop(Mouse), Mouse.Width, Mouse.Height);
            Rect r2 = new Rect(Canvas.GetLeft(at), Canvas.GetTop(at), at.Width, at.Height);
            r1.Intersect(r2);

            if (!r1.IsEmpty)
            {
                createCheese();
                return true;
            }
            else
            {
                return false;
            }
        }
開發者ID:QuangNguyen263,項目名稱:Freakin-Mouse-Windows-App,代碼行數:16,代碼來源:MainPage.xaml.cs

示例13: consillionMatrix

        public bool consillionMatrix(Image a)
        {
            Rect rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
            Rect rt1 = new Rect(Canvas.GetLeft(rec1), Canvas.GetTop(rec1), rec1.Width, rec1.Height);
            rt.Intersect(rt1);
            if (!rt.IsEmpty)
            {
                return true;
            }
            else
            {
                rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                rt1 = new Rect(Canvas.GetLeft(rec2), Canvas.GetTop(rec2), rec2.Width, rec2.Height);
                rt.Intersect(rt1);
                if (!rt.IsEmpty)
                {
                    return true;
                }
                else
                {
                    rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                    rt1 = new Rect(Canvas.GetLeft(rec3), Canvas.GetTop(rec3), rec3.Width, rec3.Height);
                    rt.Intersect(rt1);
                    if (!rt.IsEmpty)
                    {
                        return true;
                    }
                    else
                    {
                        rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                        rt1 = new Rect(Canvas.GetLeft(rec4), Canvas.GetTop(rec4), rec4.Width, rec4.Height);
                        rt.Intersect(rt1);
                        if (!rt.IsEmpty)
                        {
                            return true;
                        }
                        else
                        {
                            rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                            rt1 = new Rect(Canvas.GetLeft(rec5), Canvas.GetTop(rec5), rec5.Width, rec5.Height);
                            rt.Intersect(rt1);
                            if (!rt.IsEmpty)
                            {
                                return true;
                            }
                            else
                            {
                                rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                                rt1 = new Rect(Canvas.GetLeft(rec6), Canvas.GetTop(rec6), rec6.Width, rec6.Height);
                                rt.Intersect(rt1);
                                if (!rt.IsEmpty)
                                {
                                    return true;
                                }
                                else
                                {

                                    rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                                    rt1 = new Rect(Canvas.GetLeft(rec7), Canvas.GetTop(rec7), rec7.Width, rec7.Height);
                                    rt.Intersect(rt1);
                                    if (!rt.IsEmpty)
                                    {
                                        return true;
                                    }
                                    else
                                    {
                                        rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                                        rt1 = new Rect(Canvas.GetLeft(rec8), Canvas.GetTop(rec8), rec8.Width, rec8.Height);
                                        rt.Intersect(rt1);
                                        if (!rt.IsEmpty)
                                        {
                                            return true;
                                        }
                                        else
                                        {
                                            rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                                            rt1 = new Rect(Canvas.GetLeft(rec9), Canvas.GetTop(rec9), rec9.Width, rec9.Height);
                                            rt.Intersect(rt1);
                                            if (!rt.IsEmpty)
                                            {
                                                return true;
                                            }
                                            else
                                            {
                                                rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                                                rt1 = new Rect(Canvas.GetLeft(rec10), Canvas.GetTop(rec10), rec10.Width, rec10.Height);
                                                rt.Intersect(rt1);
                                                if (!rt.IsEmpty)
                                                {
                                                    return true;
                                                }
                                                else
                                                {
                                                    rt = new Rect(Canvas.GetLeft(a), Canvas.GetTop(a), a.Width, a.Height);
                                                    rt1 = new Rect(Canvas.GetLeft(rec11), Canvas.GetTop(rec11), rec11.Width, rec11.Height);
                                                    rt.Intersect(rt1);
                                                    if (!rt.IsEmpty)
                                                    {
                                                        return true;
                                                    }
//.........這裏部分代碼省略.........
開發者ID:QuangNguyen263,項目名稱:Freakin-Mouse-Windows-App,代碼行數:101,代碼來源:MainPage.xaml.cs


注:本文中的Windows.Foundation.Rect.Intersect方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。