How to detect Mobile Device Browsers?
We can easily detect the Mobile device browsers using the following C# code.
- public bool IsMobileDevice(string UserAgent)
- {
- bool result = false;
- Regex b = new Regex(@"(android|bb\d+|meego).+mobile|avantgo|bada\/|blackberry|blazer|compal|elaine|fennec|hiptop|iemobile|ip(hone|od)|iris|kindle|lge |maemo|midp|mmp|mobile.+firefox|netfront|opera m(ob|in)i|palm( os)?|phone|p(ixi|re)\/|plucker|pocket|psp|series(4|6)0|symbian|treo|up\.(browser|link)|vodafone|wap|windows (ce|phone)|xda|xiino", RegexOptions.IgnoreCase | RegexOptions.Multiline);
- Regex v = new Regex(@"1207|6310|6590|3gso|4thp|50[1-6]i|770s|802s|a wa|abac|ac(er|oo|s\-)|ai(ko|rn)|al(av|ca|co)|amoi|an(ex|ny|yw)|aptu|ar(ch|go)|as(te|us)|attw|au(di|\-m|r |s )|avan|be(ck|ll|nq)|bi(lb|rd)|bl(ac|az)|br(e|v)w|bumb|bw\-(n|u)|c55\/|capi|ccwa|cdm\-|cell|chtm|cldc|cmd\-|co(mp|nd)|craw|da(it|ll|ng)|dbte|dc\-s|devi|dica|dmob|do(c|p)o|ds(12|\-d)|el(49|ai)|em(l2|ul)|er(ic|k0)|esl8|ez([4-7]0|os|wa|ze)|fetc|fly(\-|_)|g1 u|g560|gene|gf\-5|g\-mo|go(\.w|od)|gr(ad|un)|haie|hcit|hd\-(m|p|t)|hei\-|hi(pt|ta)|hp( i|ip)|hs\-c|ht(c(\-| |_|a|g|p|s|t)|tp)|hu(aw|tc)|i\-(20|go|ma)|i230|iac( |\-|\/)|ibro|idea|ig01|ikom|im1k|inno|ipaq|iris|ja(t|v)a|jbro|jemu|jigs|kddi|keji|kgt( |\/)|klon|kpt |kwc\-|kyo(c|k)|le(no|xi)|lg( g|\/(k|l|u)|50|54|\-[a-w])|libw|lynx|m1\-w|m3ga|m50\/|ma(te|ui|xo)|mc(01|21|ca)|m\-cr|me(rc|ri)|mi(o8|oa|ts)|mmef|mo(01|02|bi|de|do|t(\-| |o|v)|zz)|mt(50|p1|v )|mwbp|mywa|n10[0-2]|n20[2-3]|n30(0|2)|n50(0|2|5)|n7(0(0|1)|10)|ne((c|m)\-|on|tf|wf|wg|wt)|nok(6|i)|nzph|o2im|op(ti|wv)|oran|owg1|p800|pan(a|d|t)|pdxg|pg(13|\-([1-8]|c))|phil|pire|pl(ay|uc)|pn\-2|po(ck|rt|se)|prox|psio|pt\-g|qa\-a|qc(07|12|21|32|60|\-[2-7]|i\-)|qtek|r380|r600|raks|rim9|ro(ve|zo)|s55\/|sa(ge|ma|mm|ms|ny|va)|sc(01|h\-|oo|p\-)|sdk\/|se(c(\-|0|1)|47|mc|nd|ri)|sgh\-|shar|sie(\-|m)|sk\-0|sl(45|id)|sm(al|ar|b3|it|t5)|so(ft|ny)|sp(01|h\-|v\-|v )|sy(01|mb)|t2(18|50)|t6(00|10|18)|ta(gt|lk)|tcl\-|tdg\-|tel(i|m)|tim\-|t\-mo|to(pl|sh)|ts(70|m\-|m3|m5)|tx\-9|up(\.b|g1|si)|utst|v400|v750|veri|vi(rg|te)|vk(40|5[0-3]|\-v)|vm40|voda|vulc|vx(52|53|60|61|70|80|81|83|85|98)|w3c(\-| )|webc|whit|wi(g |nc|nw)|wmlb|wonu|x700|yas\-|your|zeto|zte\-", RegexOptions.IgnoreCase | RegexOptions.Multiline);
- if ((b.IsMatch(userAgent) || v.IsMatch(userAgent.Substring(0, 4))))
- {
- result = true;
- }
- return result;
- }
- string userAgent = Context.Request.ServerVariables["HTTP_USER_AGENT"];
- var IsMobile = IsMobileDevice(userAgent);
How to hide the first option of a select using jQuery
When using "jquery.selectbox.js" plugin the "select & option" tags will be converted into "ul li" at run time. In this case it's hard to hide the first option using the normal select option script. The following solution rectifies this situation.
HTML:
- <div class="language">
- <select id="language" name="language" sb="76231018" style="display: none;">
- <option value="0">Select Language</option>
- <option value="http://www.example.com/en/" page="master">English</option>
- <option value="http://www.example.com/fr/" page="master">French</option>
- <option value="http://www.example.com/es/" page="master">Spanish</option>
- </select>
- <div id="sbHolder_76231018" class="sbHolder" tabindex="0">
- <a id="sbToggle_76231018" href="#" class="sbToggle"></a>
- <a id="sbSelector_76231018" href="#" class="sbSelector">Select Language</a>
- <ul id="sbOptions_76231018" class="sbOptions" style="display: none;">
- <li><a href="#0" rel="0" class="sbFocus">Select Language</a></li>
- <li><a href="http://www.example.com/en/" rel="http://preview.smp.com/en/">English</a></li>
- <li><a href="http://www.example.com/fr/" rel="http://preview.smp.com/fr/">French</a></li>
- <li><a href="http://www.example.com/es/" rel="http://preview.smp.com/es/">Spanish</a></li>
- </ul>
- </div>
- </div>
jQuery:
- <script type="text/javascript">
- $(document).ready(function () {
- $(".language .sbHolder").click(function () {
- $(".language .sbHolder ul.sbOptions li:first").hide();
- });
- });
- </script>
Find the Distance between 2 Latitude Longitude Co-Ordinates using Haversine formula
The following function is used to find the distance between two Latitude & Longitude co-ordinates using Haversine formula.
The haversine formula is an equation important in navigation, giving great-circle distances between two points on a sphere from their longitudes and latitudes. It is a special case of a more general formula in spherical trigonometry, the law of haversines, relating the sides and angles of spherical triangles.
The haversine formula is an equation important in navigation, giving great-circle distances between two points on a sphere from their longitudes and latitudes. It is a special case of a more general formula in spherical trigonometry, the law of haversines, relating the sides and angles of spherical triangles.
- public double HaversineDistance(LatLng pos1, LatLng pos2, DistanceUnit unit)
- {
- double R = (unit == DistanceUnit.Miles) ? 3959 : 6371;
- var la1 = pos1.Latitude;
- var lo1 = pos1.Longitude;
- var la2 = pos2.Latitude;
- var lo2 = pos2.Longitude;
- var lat1 = la1 * Math.PI / 180;
- var lon1 = lo1 * Math.PI / 180;
- var lat2 = la2 * Math.PI / 180;
- var lon2 = lo2 * Math.PI / 180;
- var dLat = lat2 - lat1;
- var dLon = lon2 - lon1;
- var a = Math.Sin(dLat / 2) * Math.Sin(dLat / 2) + Math.Cos(lat1) * Math.Cos(lat2) * Math.Sin(dLon / 2) * Math.Sin(dLon / 2);
- var c = 2 * Math.Atan2(Math.Sqrt(a), Math.Sqrt(1 - a));
- var d = R * c;
- return d;
- }
- public class LatLng
- {
- public double Latitude { get; set; }
- public double Longitude { get; set; }
- public LatLng()
- {
- }
- public LatLng(double lat, double lng)
- {
- this.Latitude = lat;
- this.Longitude = lng;
- }
- }
Microsoft SQL Server Function to Get Ordinal Suffix of a Number
This AddOrdinal function will be useful when we needed to display the date format as 1st July -3rd October. There is nothing in there about ordinals, but it can't be done using String.Format. However it's not really that hard to write a function to do it. The following Microsoft SQL Server Function is used to get the Ordinal Suffix of any number.
- CREATE FUNCTION [Internal].[GetNumberAsOrdinalString]
- (
- @num int
- )
- RETURNS nvarchar(max)
- AS
- BEGIN
- DECLARE @Suffix nvarchar(2);
- DECLARE @Ones int;
- DECLARE @Tens int;
- SET @Ones = @num % 10;
- SET @Tens = FLOOR(@num / 10) % 10;
- IF @Tens = 1
- BEGIN
- SET @Suffix = 'th';
- END
- ELSE
- BEGIN
- SET @Suffix =
- CASE @Ones
- WHEN 1 THEN 'st'
- WHEN 2 THEN 'nd'
- WHEN 3 THEN 'rd'
- ELSE 'th'
- END
- END
- RETURN CONVERT(nvarchar(max), @num) + @Suffix;
- END
Related Function in other languages:
C# Code to Get Ordinal Suffix of a Number
PHP Code to Get Ordinal Suffix of a Number
PHP Code to Get Ordinal Suffix of a Number
It's a user-defined function which is a lot simpler than you think. Though there might be a .NET function already in existence for this, the following function (written in PHP) does the job. It shouldn't be too hard to port it over. This ordinal function will be useful when we needed to display the date format as 1st December 2013.
- function ordinal($num) {
- $ones = $num % 10;
- $tens = floor($num / 10) % 10;
- if ($tens == 1) {
- $suff = "th";
- } else {
- switch ($ones) {
- case 1 : $suff = "st"; break;
- case 2 : $suff = "nd"; break;
- case 3 : $suff = "rd"; break;
- default : $suff = "th";
- }
- }
- return $num . $suff;
- }
Related Function in other languages:
C# Code to Get Ordinal Suffix of a Number
Microsoft SQL Server Function to Get Ordinal Suffix of a Number
C# Code to Get the Latitude and Longitude Co-Ordinates of a Place using Address or Zip-code
The following C# Code is used to get the Latitude and Longitude Co-Ordinates of a particular place anywhere in the World using the Address or Zip-code. To get the Latitude and Longitude Co-Ordinates using Address, call the function like this, getLatLong("Briarwood, NY 11435-2694",""). To get the Latitude and Longitude Co-Ordinates using the Zip-code, call the function like this, getLatLong("","11435").
- public string getLatLong(string Address, string Zip)
- {
- string latlong = "", address = "";
- if (Address!=string.Empty)
- {
- address = "http://maps.googleapis.com/maps/api/geocode/xml?address=" + Address + "&sensor=false";
- }
- else
- {
- address = "http://maps.googleapis.com/maps/api/geocode/xml?components=postal_code:" + Zip.Trim() + "&sensor=false";
- }
- var result = new System.Net.WebClient().DownloadString(address);
- XmlDocument doc = new XmlDocument();
- doc.LoadXml(result);
- XmlNodeList parentNode = doc.GetElementsByTagName("location");
- var lat = "";
- var lng = "";
- foreach (XmlNode childrenNode in parentNode)
- {
- lat = childrenNode.SelectSingleNode("lat").InnerText;
- lng = childrenNode.SelectSingleNode("lng").InnerText;
- }
- latlong = Convert.ToString(lat) + "," + Convert.ToString(lng);
- return latlong;
- }
C# Code to Get Ordinal Suffix of a Number
There is no inbuilt capability in the .NET Base Class Library to get the Ordinals. This AddOrdinal function will be useful when we needed to display the date format as 1st July -3rd October. There is nothing in there about ordinals, but it can't be done using
String.Format. However it's not really that hard to write a function to
do it. The following C# code is used to get the Ordinal Suffix of any number.
- public static string AddOrdinal(int num)
- {
- if (num <= 0) return num.ToString();
- switch (num % 100)
- {
- case 11:
- case 12:
- case 13:
- return num + "th";
- }
- switch (num % 10)
- {
- case 1:
- return num + "st";
- case 2:
- return num + "nd";
- case 3:
- return num + "rd";
- default:
- return num + "th";
- }
- }
Another way:
- public static string[] SuffixLookup = { "th","st","nd","rd","th","th","th","th","th","th" };
- public static string AppendOrdinalSuffix(int number)
- {
- if (number % 100 >= 11 && number % 100 <= 13)
- {
- return number + "th";
- }
- return number + SuffixLookup[number% 10];
- }
And the more simplest way:
- private static string GetOrdinalSuffix(int num)
- {
- if (num.ToString().EndsWith("11")) return "th";
- if (num.ToString().EndsWith("12")) return "th";
- if (num.ToString().EndsWith("13")) return "th";
- if (num.ToString().EndsWith("1")) return "st";
- if (num.ToString().EndsWith("2")) return "nd";
- if (num.ToString().EndsWith("3")) return "rd";
- return "th";
- }