2 * Copyright (c) 2016 Samsung Electronics Co., Ltd All Rights Reserved
4 * Licensed under the Apache License, Version 2.0 (the License);
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an AS IS BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
22 /// The Point is a struct that defines the 2D point as a pair of generic type.
24 /// <since_tizen> preview </since_tizen>
25 public struct Point : IEquatable<Point>
28 /// Location along the horizontal axis.
30 /// <since_tizen> preview </since_tizen>
34 /// Location along the vertical axis.
36 /// <since_tizen> preview </since_tizen>
40 /// A human readable representation of <see cref="Point"/>.
42 /// <returns>The string is formatted as "{{X={0} Y={1}}}".</returns>
43 /// <since_tizen> preview </since_tizen>
44 public override string ToString()
46 return string.Format("{{X={0} Y={1}}}", X, Y);
50 /// Gets the hash code.
52 /// <returns>The hash code.</returns>
53 /// <since_tizen> preview </since_tizen>
54 public override int GetHashCode()
58 return X.GetHashCode() ^ (Y.GetHashCode() * 397);
63 /// Indicates whether this instance and a specified object are equal.
65 /// <param name="obj">The object to compare with the current instance.</param>
67 /// true if the object and this instance are of the same type and represent the same value,
70 /// <since_tizen> preview </since_tizen>
71 public override bool Equals(object obj)
76 return Equals((Point)obj);
80 /// Indicates whether this instance and a <see cref="Point"/> object are equal.
82 /// <param name="other">The <see cref="Point"/> to compare with the current instance.</param>
84 /// true if the object and this instance are the same type and represent the same value,
87 /// <since_tizen> preview </since_tizen>
88 public bool Equals(Point other)
90 return X.Equals(other.X) && Y.Equals(other.Y);
94 /// Whether both <see cref="Point"/>s are equal.
96 /// <param name="p1">A <see cref="Point"/> on the left hand side.</param>
97 /// <param name="p2">A <see cref="Point"/> on the right hand side.</param>
98 /// <returns>True if both <see cref="Point"/>s have equal values.</returns>
99 /// <since_tizen> preview </since_tizen>
100 public static bool operator ==(Point p1, Point p2)
102 return p1.Equals(p2);
106 /// Whether both <see cref="Point"/>s are not equal.
108 /// <param name="p1">A <see cref="Point"/> on the left hand side.</param>
109 /// <param name="p2">A <see cref="Point"/> on the right hand side.</param>
110 /// <returns>True if both <see cref="Point"/>s do not have equal values.</returns>
111 /// <since_tizen> preview </since_tizen>
112 public static bool operator !=(Point p1, Point p2)
114 return !p1.Equals(p2);