實現思路:html
1.隨機生成四個圖標數組
2.區域從左到右均分紅四個區域,每一個區域隨機一個點ide
3.在隨機的四個點上顯示圖標,圖標隨機旋轉必定角度。函數
4.對這四個圖標進行隨機排序,而後選擇前三個做爲點擊順序,並顯示在界面下方指引用戶。post
5.點擊漢字顯示一個定位標記,內部有個文字,按照點擊順序從1標記到3.編碼
截圖以下:url
按照順序點擊後spa
XAML代碼同 Wpf登陸驗證方式(2)-文字點選的實現code
cs代碼也基本相同。如今只貼出不一樣處htm
1.將隨機漢字改爲隨機圖標
if (IsEmoji) { var emoji = EmojiText.Emoji.OrderBy(p => ran.NextDouble()).Take(4).ToList(); str1 = emoji[0]; str2 = emoji[1]; str3 = emoji[2]; str4 = emoji[3]; } else { //調用函數產生4個隨機中文漢字編碼 object[] bytes = ChineseCode.CreateRegionCode(4); //根據漢字編碼的字節數組解碼出中文漢字 str1 = gb.GetString((byte[])Convert.ChangeType(bytes[0], typeof(byte[]))); str2 = gb.GetString((byte[])Convert.ChangeType(bytes[1], typeof(byte[]))); str3 = gb.GetString((byte[])Convert.ChangeType(bytes[2], typeof(byte[]))); str4 = gb.GetString((byte[])Convert.ChangeType(bytes[3], typeof(byte[]))); }
2. 是否爲圖標模式
public bool IsEmoji { get { return (bool)GetValue(IsEmojiProperty); } set { SetValue(IsEmojiProperty, value); } } public static readonly DependencyProperty IsEmojiProperty = DependencyProperty.Register("IsEmoji", typeof(bool), typeof(TextClickVerify), new PropertyMetadata(false));
圖標類
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace Util.Controls { class EmojiText { public static Lazy<string[]> Emoji = new Lazy<string[]>(GetEmoji); public static string[] GetEmoji() { return new string[] { "😁", "😃", "😅", "😆", "😉", "😊", "😋", "😎", "😍", "😘", "😚", "😇", "😐", "😶", "😏", "😣", "😥", "😪", "😫", "😌", "😜", "😝", "😒", "😓", "😔", "😲", "😷", "😖", "😞", "😤", "😢", "😭", "😨", "😰", "😱", "😳", "😵", "😡", "😠", "😈", "👿", "👹", "👺", "💀", "👻", "👽", "👦", "👧", "👨", "👩", "👴", "👵", "👶", "👱", "👮", "👲", "👳", "👷", "👸", "💂", "🎅", "👰", "👼", "💆", "💇", "🙍", "🙎", "🙅", "🙆", "💁", "🙋", "🙇", "🙌", "🙏", "👤", "👯", "💃", "👫", "💏", "👪", "💪", "👈", "👉", "☝", "👆", "👇", "✋", "👌", "👍", "👎", "✊", "👊", "👋", "👏", "👐", "👣", "👀", "👂", "👃", "👅", "👄", "💋", "👓", "👔", "👕", "👖", "👗", "👘", "👙", "👚", "👛", "👜", "👝", "🎒", "💼", "👞", "👟", "👠", "👡", "👢", "👑", "👒", "🎩", "🎓", "💄", "💅", "💍", "🌂", "🙈", "🙉", "🙊", "🐵", "🐒", "🐶", "🐩", "🐺", "🐱", "😺", "😸", "😹", "😻", "😼", "😽", "🙀", "😿", "😾", "🐯", "🐴", "🐎", "🐮", "🐷", "🐗", "🐽", "🐑", "🐫", "🐘", "🐭", "🐹", "🐰", "🐻", "🐨", "🐼", "🐾", "🐔", "🐣", "🐤", "🐥", "🐦", "🐧", "🐸", "🐢", "🐍", "🐲", "🐳", "🐬", "🐟", "🐠", "🐡", "🐙", "🐚", "🐌", "🐛", "🐜", "🐝", "🐞", "💐", "🌸", "💮", "🌹", "🌺", "🌻", "🌼", "🌷", "🌱", "🌴", "🌵", "🌾", "🌿", "☘", "🍀", "🍁", "🍂", "🍃", "🍇", "🍈", "🍉", "🍊", "🍌", "🍍", "🍎", "🍏", "🍑", "🍒", "🍓", "🍅", "🍆", "🌽", "🍄", "🌰", "🍞", "🍖", "🍗", "🍔", "🍟", "🍕", "🍳", "🍲", "🍱", "🍘", "🍙", "🍚", "🍛", "🍜", "🍝", "🍠", "🍢", "🍣", "🍤", "🍥", "🍡", "🍦", "🍧", "🍨", "🍩", "🍪", "🎂", "🍰", "🍫", "🍬", "🍭", "🍮", "🍯", "☕", "🍵", "🍶", "🍷", "🍸", "🍹", "🍺", "🍻", "🍴", "🎪", "🎭", "🎨", "🎰", "🛀", "🎫", "🏆", "⚽", "⚾", "🏀", "🏈", "🎾", "🎱", "🎳", "⛳", "🎣", "🎽", "🎿", "🏂", "🏄", "🏊", "🎯", "🎮", "🎲", "🎷", "🎸", "🎺", "🎻", "🎬", "👾", "🌋", "🗻", "🏠", "🏡", "🏢", "🏣", "🏥", "🏦", "🏨", "🏩", "🏪", "🏫", "🏬", "🏭", "🏯", "🏰", "💒", "🗼", "🗽", "⛪", "⛲", "🌁", "🌃", "🌆", "🌇", "🌉", "🌌", "🎠", "🎡", "🎢", "🚃", "🚄", "🚅", "🚇", "🚉", "🚌", "🚏", "🚑", "🚒", "🚓", "🚕", "🚗", "🚚", "🚲", "⛽", "🚨", "🚥", "🚧", "⚓", "⛵", "🚤", "🚢", "✈", "💺", "🚀", "🎑", "🗿", "💌", "💎", "🔪", "💈 ", "🚪 ", "🚽", "⌛", "⏳", "⌚", "⏰", "🎈", "🎉", "🎊", "🎎", "🎏", "🎐", "🎀", "🎁", "📻", "📱", "📲", "☎", "📞", "📟", "📠", "🔋", "🔌", "💻", "💽", "💾", "💿", "📀", "🎥", "📺", "📷", "📹", "📼", "🔍", "🔎", "📡", "💡", "🔦", "🏮", "📔", "📕", "📖", "📗", "📘", "📙", "📚", "📓", "📃", "📜", "📄", "📰", "📑", "🔖", "💰", "💴", "💵", "💸", "💳", "✉", "📧", "📨", "📩", "📤", "📥", "📦", "📫", "📪", "📮", "✏", "✒", "📝", "📁", "📂", "📅", "📆", "📇", "📈", "📉", "📊", "📋", "📌", "📍", "📎", "📏", "📐", "✂", "🔒", "🔓", "🔏", "🔐", "🔑", "🔨", "🔫", "🔧", "🔩", "🔗", "💉", "💊", "🚬", "🗿", "🔮", "🚩", "🎌", "💦", "💨", "💣", "💩", "⌛", "⏳", "⌚", "⏰", "💘", "❤", "💓", "💔", "💕", "💖", "💗", "💜", "💝", "💞", "💟", "💐", "🌸", "💮", "🌹", "🌺", "🌻", "🌼", "🌷", "🌑", "🌓", "🌔", "🌕", "🌙", "🌛", "🍇", "🍈", "🍉", "🍊", "🍌", "🍍", "🍎", "🍏", "🍑", "🍒", "🍓", "📱", "📲", "☎", "📞", "📟", "📠", "🔋", "🔌", "💻", "💽", "💾", "💿", "📀", "🎥", "📺", "📷", "📹", "📼", "🔍", "🔎", "📡", "📔", "📕", "📖", "📗", "📘", "📙", "📚", "📓", "📃", "📜", "📄", "📰", "📑", "🔖", "💳", "✉", "📧", "📨", "📩", "📤", "📥", "📦", "📫", "📪", "📮", "✏", "✒", "📝", "📁", "📂", "📅", "📆", "📇", "📈", "📉", "📊", "📋", "📌", "📍", "📎", "📏", "📐", "✂", "🔒", "🔓", "🔏", "🔐", "🔑", "🔃", "🔙", "🔚", "🔛", "🔜", "🔝", "📱", "📲", "📶", "📳", "📴", "☎", "📞", "📟", "📠", "♻", "🏧", "♿", "🚹", "🚺", "🚻", "🚼", "🚾", "⚠", "⛔", "🚫", "🚭", "🔞", "💈", "🚃", "🚄", "🚅", "🚇", "🚉", "🚌", "🚏", "🚑", "🚒", "🚓", "🚕", "🚗", "🚚", "🚲", "⛽", "🚨", "🚥", "🚧", "⚓", "⛵", "🚤", "🚢", "✈", "💺", "🚀", "🏠", "🏡", "🏢", "🏣", "🏥", "🏦", "🏨", "🏩", "🏪", "🏫", "🏬", "🏭", "🏯", "🏰", "💒", "🗼", "🗽", "⛪", "🌆", "🌇", "🌉", "💴", "💵", "💰", "💸", "💳", "🌿", "🍀", "🍁", "🍂", "🍃", "☘", }; } } }
控件使用方法
<util:TextClickVerify x:Name="verify3" IsEmoji="True" Width="300" Height="300"> <i:Interaction.Triggers> <i:EventTrigger EventName="ResultChanged"> <i:InvokeCommandAction Command="{Binding ResultChangedComamnd}" CommandParameter="{Binding Path=Result,ElementName=verify2}"/> </i:EventTrigger> </i:Interaction.Triggers> </util:TextClickVerify>
好了,下一章咱們寫什麼驗證方式呢?