-
Notifications
You must be signed in to change notification settings - Fork 254
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[NUI] Add value type: color, vector2, shadow
Introduce the value type of color, vector2 and shadow. They will replace existing reference types gradually. Signed-off-by: Jiyun Yang <[email protected]>
- Loading branch information
1 parent
b227a82
commit 50a72bc
Showing
3 changed files
with
259 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
/* | ||
* Copyright(c) 2025 Samsung Electronics Co., Ltd. | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
*/ | ||
using System.ComponentModel; | ||
|
||
namespace Tizen.NUI.L | ||
{ | ||
/// <summary> | ||
/// Defines a value type of color. | ||
/// </summary> | ||
[EditorBrowsable(EditorBrowsableState.Never)] | ||
public struct Color | ||
{ | ||
public static readonly Color Transparent = new Color(0, 0, 0, 0); | ||
public static readonly Color Black = new Color(0, 0, 0, 1); | ||
public static readonly Color White = new Color(1, 1, 1, 1); | ||
public static readonly Color Red = new Color(1, 0, 0, 1); | ||
public static readonly Color Green = new Color(0, 1, 0, 1); | ||
public static readonly Color Blue = new Color(0, 0, 1, 1); | ||
|
||
/// <summary> | ||
/// Initializes a new instance of the <see cref="Color"/> struct. | ||
/// </summary> | ||
/// <param name="r">The red component.</param> | ||
/// <param name="g">The green component.</param> | ||
/// <param name="b">The blue component.</param> | ||
/// <param name="a">The alpha component.</param> | ||
public Color(float r, float g, float b, float a) | ||
{ | ||
R = r; | ||
G = g; | ||
B = b; | ||
A = a; | ||
} | ||
|
||
/// <summary> | ||
/// Gets the red component of the color. | ||
/// </summary> | ||
public float R | ||
{ | ||
get; | ||
} | ||
|
||
/// <summary> | ||
/// Gets the green component of the color. | ||
/// </summary> | ||
public float G | ||
{ | ||
get; | ||
} | ||
|
||
/// <summary> | ||
/// Gets the blue component of the color. | ||
/// </summary> | ||
public float B | ||
{ | ||
get; | ||
} | ||
|
||
/// <summary> | ||
/// Gets the alpha component of the color. | ||
/// </summary> | ||
public float A | ||
{ | ||
get; | ||
} | ||
|
||
/// <summary> | ||
/// Multiplies the alpha component of the color by the specified value. | ||
/// </summary> | ||
/// <param name="alpha">The value to multiply the alpha component by.</param> | ||
/// <returns>The new color.</returns> | ||
public readonly Color MultiplyAlpha(float alpha) => new Color(R, G, B, A * alpha); | ||
|
||
/// <summary> | ||
/// Returns a new color object with the specified alpha value. | ||
/// </summary> | ||
/// <param name="alpha">The new alpha value.</param> | ||
/// <returns>A new color object with the specified alpha value.</returns> | ||
public readonly Color WithAlpha(float alpha) => new Color(R, G, B, alpha); | ||
|
||
internal readonly NUI.Color ToReferenceType() => new NUI.Color(R, G, B, A); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,94 @@ | ||
/* | ||
* Copyright(c) 2025 Samsung Electronics Co., Ltd. | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
*/ | ||
using System.ComponentModel; | ||
|
||
namespace Tizen.NUI.L | ||
{ | ||
/// <summary> | ||
/// Defines a value type of shadow. | ||
/// </summary> | ||
[EditorBrowsable(EditorBrowsableState.Never)] | ||
public struct Shadow | ||
{ | ||
/// <summary> | ||
/// Create a Shadow. | ||
/// </summary> | ||
/// <param name="blurRadius">The blur radius value for the shadow. Bigger value, much blurry.</param> | ||
public Shadow(float blurRadius) : this(blurRadius, L.Color.Black, Vector2.Zero, Vector2.Zero) | ||
{ | ||
} | ||
|
||
/// <summary> | ||
/// Create a Shadow. | ||
/// </summary> | ||
/// <param name="blurRadius">The blur radius value for the shadow. Bigger value, much blurry.</param> | ||
/// <param name="color">The color for the shadow.</param> | ||
/// <param name="offset">Optional. The position offset value (x, y) from the top left corner.</param> | ||
/// <param name="extents">Optional. The shadow will extend its size by specified amount of length.</param> | ||
public Shadow(float blurRadius, L.Color color, Vector2 offset, Vector2 extents) | ||
{ | ||
BlurRadius = blurRadius; | ||
Color = color; | ||
Offset = offset; | ||
Extents = extents; | ||
} | ||
|
||
/// <summary> | ||
/// The blur radius value for the shadow. Bigger value, much blurry. | ||
/// </summary> | ||
/// <remarks> | ||
/// Negative value is ignored. (no blur) | ||
/// </remarks> | ||
public float BlurRadius | ||
{ | ||
get; | ||
set; | ||
} | ||
|
||
/// <summary> | ||
/// The color for the shadow. | ||
/// </summary> | ||
public L.Color Color | ||
{ | ||
get; | ||
set; | ||
} | ||
|
||
/// <summary> | ||
/// The position offset value (x, y) from the top left corner. | ||
/// </summary> | ||
public Vector2 Offset | ||
{ | ||
get; | ||
set; | ||
} | ||
|
||
/// <summary> | ||
/// The shadow will extend its size by specified amount of length.<br /> | ||
/// If the value is negative then the shadow will shrink. | ||
/// For example, when View's size is (100, 100) and the Shadow's Extents is (5, -5), | ||
/// the output shadow will have size (105, 95). | ||
/// </summary> | ||
public Vector2 Extents | ||
{ | ||
get; | ||
set; | ||
} | ||
|
||
internal readonly NUI.Shadow ToShadow() => new NUI.Shadow(BlurRadius, Color.ToReferenceType(), Offset.ToReferenceType(), Extents.ToReferenceType()); | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
/* | ||
* Copyright(c) 2025 Samsung Electronics Co., Ltd. | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
*/ | ||
using System.ComponentModel; | ||
|
||
namespace Tizen.NUI.L | ||
{ | ||
/// <summary> | ||
/// Defines a value type of vector2. | ||
/// </summary> | ||
[EditorBrowsable(EditorBrowsableState.Never)] | ||
public readonly struct Vector2 | ||
{ | ||
public static readonly Vector2 Zero = new Vector2(0.0f, 0.0f); | ||
|
||
/// <summary> | ||
/// Initializes a new instance of the <see cref="Vector2"/> struct. | ||
/// </summary> | ||
/// <param name="x">The x value.</param> | ||
/// <param name="y">The y value.</param> | ||
public Vector2(float x, float y) | ||
{ | ||
X = x; | ||
Y = y; | ||
} | ||
|
||
/// <summary> | ||
/// Gets the x component of the vector2. | ||
/// </summary> | ||
public float X | ||
{ | ||
get; | ||
} | ||
|
||
/// <summary> | ||
/// Gets the y component of the vector2. | ||
/// </summary> | ||
public float Y | ||
{ | ||
get; | ||
} | ||
|
||
/// <summary> | ||
/// Gets the width component of the vector2. | ||
/// </summary> | ||
public float Width => X; | ||
|
||
/// <summary> | ||
/// Gets the height component of the vector2. | ||
/// </summary> | ||
public float Height => Y; | ||
|
||
internal readonly NUI.Vector2 ToReferenceType() => new NUI.Vector2(X, Y); | ||
} | ||
} |