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


C# Canvas.FillCircleSegment方法代碼示例

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


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

示例1: Draw

		public override void Draw(Canvas target, Vector3 basePos, float baseRotation, float baseScale)
		{
			float circleRadius = 5.0f;
			float borderRadius = DefaultOutlineWidth;

			// Scale anti-proportional to perspective scale in order to keep a constant size 
			// in screen space even when actually drawing in world space.
			{
				float scale = 1.0f;
				Vector3 posTemp = this.pos + basePos;
				target.DrawDevice.PreprocessCoords(ref posTemp, ref scale);
				circleRadius /= scale;
				borderRadius /= scale;
			}

			// Determine circle position
			Vector3 circlePos = this.pos;
			MathF.TransformCoord(ref circlePos.X, ref circlePos.Y, baseRotation, baseScale);
			circlePos += basePos;

			// Draw circle
			target.State.ColorTint *= this.Color;
			target.FillCircle(
				circlePos.X, 
				circlePos.Y, 
				circlePos.Z, 
				circleRadius - borderRadius * 0.5f);

			// Draw circle outline
			if (target.DrawDevice.DepthWrite) target.State.ZOffset -= 1;
			target.State.ColorTint *= ColorRgba.Black;
			target.FillCircleSegment(
				circlePos.X, 
				circlePos.Y, 
				circlePos.Z, 
				circleRadius, 
				0.0f, 
				MathF.RadAngle360, 
				borderRadius);
		}
開發者ID:ChrisLakeZA,項目名稱:duality,代碼行數:40,代碼來源:VisualLogPointEntry.cs

示例2: Draw

        public override void Draw(Canvas target, Vector3 basePos, float baseRotation, float baseScale)
        {
            float borderRadius = DefaultOutlineWidth;
            float circleRadius = this.radius * baseScale;

            // Scale anti-proportional to perspective scale in order to keep a constant size
            // in screen space even when actually drawing in world space.
            {
                float scale = 1.0f;
                Vector3 posTemp = this.pos + basePos;
                target.DrawDevice.PreprocessCoords(ref posTemp, ref scale);
                borderRadius /= scale;
                if (this.invariantScale) circleRadius /= scale;
            }

            // Determine circle position
            Vector3 circlePos = this.pos;
            MathF.TransformCoord(ref circlePos.X, ref circlePos.Y, baseRotation, baseScale);
            circlePos += basePos;

            // Draw circle
            target.State.ColorTint *= this.Color;
            target.FillCircleSegment(
                circlePos.X,
                circlePos.Y,
                circlePos.Z,
                circleRadius - borderRadius * 0.5f,
                this.minAngle + baseRotation,
                this.maxAngle + baseRotation);

            // Draw circle outline
            if (target.DrawDevice.DepthWrite) target.State.ZOffset -= 0.1f;
            target.State.ColorTint *= ColorRgba.Black;
            target.FillCircleSegment(
                circlePos.X,
                circlePos.Y,
                circlePos.Z,
                circleRadius,
                this.minAngle + baseRotation,
                this.maxAngle + baseRotation,
                borderRadius);
            if (MathF.CircularDist(this.minAngle, this.maxAngle) > MathF.RadAngle1 * 0.001f)
            {
                Vector2 minAngleVec = Vector2.FromAngleLength(this.minAngle + baseRotation, circleRadius);
                Vector2 maxAngleVec = Vector2.FromAngleLength(this.maxAngle + baseRotation, circleRadius);
                target.FillThickLine(
                    circlePos.X,
                    circlePos.Y,
                    circlePos.Z,
                    circlePos.X + minAngleVec.X,
                    circlePos.Y + minAngleVec.Y,
                    circlePos.Z,
                    borderRadius);
                target.FillThickLine(
                    circlePos.X,
                    circlePos.Y,
                    circlePos.Z,
                    circlePos.X + maxAngleVec.X,
                    circlePos.Y + maxAngleVec.Y,
                    circlePos.Z,
                    borderRadius);
            }
        }
開發者ID:ruzli,項目名稱:duality,代碼行數:63,代碼來源:VisualLogCircleEntry.cs

示例3: DrawTestImageRow

		private void DrawTestImageRow(Canvas c, int baseX, int baseY)
		{
			Vector2[] polygon = new Vector2[]
			{ 
				new Vector2(0.0f, 0.0f), 
				new Vector2(50.0f, 0.0f), 
				new Vector2(50.0f, 45.0f), 
				new Vector2(5.0f, 50.0f), 
			};

			int x = baseX;
			int y = baseY;

			// Outline Shapes
			c.PushState();
			{
				c.DrawCircle(x, y, 25);
				x += 100;

				c.DrawCircleSegment(x, y, 25, 0.0f, MathF.RadAngle30 * 4, true);
				x += 100;

				c.DrawLine(x, y , x + 50, y + 25);
				c.DrawDashLine(x, y + 25, x + 50, y + 50);
				c.DrawThickLine(x, y + 50, x + 50, y + 75, 3);
				x += 100;

				c.DrawOval(x, y, 50, 50);
				x += 100;

				c.DrawOvalSegment(x, y, 50, 50, 0.0f, MathF.RadAngle30 * 4, true);
				x += 100;

				c.DrawPolygon(polygon, x, y);
				x += 100;

				c.DrawRect(x, y, 50, 50);
				x += 100;

				c.DrawText("Hello World", x, y, drawBackground: true);
				x = baseX;
				y += 100;
			}
			c.PopState();

			// Filled Shapes
			c.PushState();
			{
				c.FillCircle(x, y, 25);
				x += 100;

				c.FillCircleSegment(x, y, 0, 25, MathF.RadAngle30 * 0, MathF.RadAngle30 * 4);
				c.FillCircleSegment(x, y, 0, 25, MathF.RadAngle30 * 5, MathF.RadAngle30 * 9, 10);
				x += 100;

				c.FillThickLine(x, y + 25, x + 50, y + 50, 3);
				x += 100;

				c.FillOval(x, y, 50, 50);
				x += 100;

				c.FillOvalSegment(x, y, 0, 50, 50, MathF.RadAngle30 * 0, MathF.RadAngle30 * 4);
				c.FillOvalSegment(x, y, 0, 50, 50, MathF.RadAngle30 * 5, MathF.RadAngle30 * 9, 10);
				x += 100;

				c.FillPolygon(polygon, x, y);
				x += 100;

				c.FillRect(x, y, 50, 50);
				x = baseX;
				y += 100;
			}
			c.PopState();
		}
開發者ID:KSLcom,項目名稱:duality,代碼行數:74,代碼來源:CanvasTest.cs

示例4: Draw

        public override void Draw(Canvas target, Vector3 basePos, float baseRotation, float baseScale)
        {
            float originRadius = 5.0f;
            float vectorThickness = 4.0f;
            float borderRadius = DefaultOutlineWidth;

            // Scale anti-proportional to perspective scale in order to keep a constant size
            // in screen space even when actually drawing in world space.
            {
                float scale = 1.0f;
                Vector3 posTemp = this.posA + basePos;
                target.DrawDevice.PreprocessCoords(ref posTemp, ref scale);
                originRadius /= scale;
                borderRadius /= scale;
                vectorThickness /= scale;
            }

            // Determine base and target positions
            Vector3 originPos = this.posA;
            Vector3 targetPos = this.posB;
            MathF.TransformCoord(ref originPos.X, ref originPos.Y, baseRotation, baseScale);
            MathF.TransformCoord(ref targetPos.X, ref targetPos.Y, baseRotation, baseScale);
            originPos += basePos;
            targetPos += basePos;

            // Create connection polygon
            float vectorLen = (targetPos.Xy - originPos.Xy).Length;
            Vector2 dirForward = (targetPos.Xy - originPos.Xy).Normalized;
            Vector2 dirLeft = dirForward.PerpendicularLeft;
            Vector2 dirRight = -dirLeft;
            Vector2[] connection = new Vector2[4];
            connection[0] = dirLeft * vectorThickness * 0.5f;
            connection[1] = dirLeft * vectorThickness * 0.5f + dirForward * vectorLen;
            connection[2] = dirRight * vectorThickness * 0.5f + dirForward * vectorLen;
            connection[3] = dirRight * vectorThickness * 0.5f;

            // Draw vector and outline
            ColorRgba areaColor = target.State.ColorTint * this.Color;
            ColorRgba outlineColor = areaColor * ColorRgba.Black;
            target.State.ColorTint = areaColor;
            target.FillPolygon(
                connection,
                originPos.X,
                originPos.Y,
                originPos.Z);
            if (target.DrawDevice.DepthWrite) target.State.ZOffset -= 0.1f;
            target.State.ColorTint = outlineColor;
            target.FillPolygonOutline(
                connection,
                borderRadius,
                originPos.X,
                originPos.Y,
                originPos.Z);

            // Draw connection points and outline
            if (target.DrawDevice.DepthWrite) target.State.ZOffset -= 0.1f;
            target.State.ColorTint = areaColor;
            target.FillCircle(
                originPos.X,
                originPos.Y,
                originPos.Z,
                originRadius - borderRadius * 0.5f);
            target.FillCircle(
                targetPos.X,
                targetPos.Y,
                targetPos.Z,
                originRadius - borderRadius * 0.5f);
            if (target.DrawDevice.DepthWrite) target.State.ZOffset -= 0.1f;
            target.State.ColorTint = outlineColor;
            target.FillCircleSegment(
                originPos.X,
                originPos.Y,
                originPos.Z,
                originRadius,
                0.0f,
                MathF.RadAngle360,
                borderRadius);
            target.FillCircleSegment(
                targetPos.X,
                targetPos.Y,
                targetPos.Z,
                originRadius,
                0.0f,
                MathF.RadAngle360,
                borderRadius);
        }
開發者ID:ruzli,項目名稱:duality,代碼行數:86,代碼來源:VisualLogConnectionEntry.cs

示例5: DrawShapeOutline

        private void DrawShapeOutline(Canvas canvas, Transform transform, CircleShapeInfo shape)
        {
            Vector3 pos = transform.Pos;
            float angle = transform.Angle;
            float scale = transform.Scale;

            if (this.wrapTexture)
            {
                canvas.State.TextureCoordinateRect = new Rect(
                    shape.Radius * 2.0f / canvas.State.TextureBaseSize.X,
                    shape.Radius * 2.0f / canvas.State.TextureBaseSize.Y);
            }
            canvas.State.TransformScale = new Vector2(scale, scale);
            canvas.State.TransformAngle = angle;
            canvas.State.TransformHandle = -shape.Position;
            canvas.FillCircleSegment(
                pos.X,
                pos.Y,
                pos.Z,
                shape.Radius,
                0.0f,
                MathF.RadAngle360,
                this.outlineWidth);
        }
開發者ID:ninja2003,項目名稱:duality,代碼行數:24,代碼來源:RigidBodyRenderer.cs

示例6: Draw

		public override void Draw(Canvas target, Vector3 basePos, float baseRotation, float baseScale)
		{
			float originRadius = 5.0f;
			float vectorThickness = 4.0f;
			float borderRadius = DefaultOutlineWidth;
			float vectorLengthFactor = 1.0f;

			// Scale anti-proportional to perspective scale in order to keep a constant size 
			// in screen space even when actually drawing in world space.
			{
				float scale = 1.0f;
				Vector3 posTemp = this.origin + basePos;
				target.DrawDevice.PreprocessCoords(ref posTemp, ref scale);
				originRadius /= scale;
				borderRadius /= scale;
				vectorThickness /= scale;
				if (this.invariantScale) vectorLengthFactor /= scale;
			}


			// Determine base and target positions
			Vector3 originPos = this.origin;
			Vector3 targetPos = this.origin + new Vector3(this.vec * vectorLengthFactor);
			MathF.TransformCoord(ref originPos.X, ref originPos.Y, baseRotation, baseScale);
			MathF.TransformCoord(ref targetPos.X, ref targetPos.Y, baseRotation, baseScale);
			originPos += basePos;
			targetPos += basePos;

			// Downscale vector arrow, if too small for display otherwise
			float vectorLen = (targetPos.Xy - originPos.Xy).Length;
			float vectorLenScale = MathF.Clamp(vectorLen / (vectorThickness * 7.0f), 0.0f, 1.0f);
			vectorThickness *= vectorLenScale;

			// Create arrow polygon
			Vector2 dirForward = (targetPos.Xy - originPos.Xy).Normalized;
			Vector2 dirLeft = dirForward.PerpendicularLeft;
			Vector2 dirRight = -dirLeft;
			Vector2[] arrow = new Vector2[7];
			arrow[0] = dirLeft * vectorThickness * 0.5f;
			arrow[1] = dirLeft * vectorThickness * 0.5f + dirForward * (vectorLen - vectorThickness * 2);
			arrow[2] = dirLeft * vectorThickness * 1.25f + dirForward * (vectorLen - vectorThickness * 2);
			arrow[3] = dirForward * vectorLen;
			arrow[4] = dirRight * vectorThickness * 1.25f + dirForward * (vectorLen - vectorThickness * 2);
			arrow[5] = dirRight * vectorThickness * 0.5f + dirForward * (vectorLen - vectorThickness * 2);
			arrow[6] = dirRight * vectorThickness * 0.5f;
			Vector2[] arrowHead = new Vector2[3];
			arrowHead[0] = arrow[2];
			arrowHead[1] = arrow[3];
			arrowHead[2] = arrow[4];
			Vector2[] arrowLine = new Vector2[4];
			arrowLine[0] = arrow[0];
			arrowLine[1] = arrow[1];
			arrowLine[2] = arrow[5];
			arrowLine[3] = arrow[6];

			// Draw vector and outline
			ColorRgba areaColor = target.State.ColorTint * this.Color;
			ColorRgba outlineColor = areaColor * ColorRgba.Black;
			target.State.ColorTint = areaColor;
			target.FillPolygon(
				arrowLine, 
				originPos.X, 
				originPos.Y, 
				originPos.Z);
			target.FillPolygon(
				arrowHead, 
				originPos.X, 
				originPos.Y, 
				originPos.Z);
			if (target.DrawDevice.DepthWrite) target.State.ZOffset -= 0.1f;
			target.State.ColorTint = outlineColor;
			target.FillPolygonOutline(
				arrow, 
				borderRadius,
				originPos.X, 
				originPos.Y, 
				originPos.Z);

			// Draw origin and outline
			if (target.DrawDevice.DepthWrite) target.State.ZOffset -= 0.1f;
			target.State.ColorTint = areaColor;
			target.FillCircle(
				originPos.X, 
				originPos.Y, 
				originPos.Z, 
				originRadius - borderRadius * 0.5f);
			if (target.DrawDevice.DepthWrite) target.State.ZOffset -= 0.1f;
			target.State.ColorTint = outlineColor;
			target.FillCircleSegment(
				originPos.X, 
				originPos.Y, 
				originPos.Z, 
				originRadius, 
				0.0f, 
				MathF.RadAngle360, 
				borderRadius);
		}
開發者ID:KSLcom,項目名稱:duality,代碼行數:97,代碼來源:VisualLogVectorEntry.cs


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