前言: 話說前陣子爸爸家陽台不斷出現米奇老鼠,立刻清理陽台所有東西,然後又跟市政部門反映問題,可是情況還沒有好轉,米老鼠來完一隻又一隻,我爸陽台在老鼠界應該是網紅打卡聖地(誤),要不然就是米奇老鼠版米奇林三星餐廳(?) 雖然我們抓到了三隻,到上兩個禮拜為止還有至少一隻一直抓不到,每天淩晨還會來吃事後煙留下老鼠屎,真_北。 這隻老鼠對傳統攻擊有抗性,有IT9朋友前陣子用Raspberry pi自製了一台electric mouse trap ,用pi的超聲波雷達放在鞋盒裡,鞋盒裡有一堆食物,底部佈了鐵網,偵測到有老鼠進去以後立即關門通9V電,通個1分鐘再放牠離開,大推我自己也造一台 (Youtube片搜尋一大堆,人類真變態啊,朋友好變態啊)。可是我覺得這樣又好像有點太殘忍,不如先偵測牠們什麼時候來,嚇嚇牠們看看有沒有效果再說吧。 目的: 用Raspberry pi及手上有的感測器弄一隻放陽台用來偵測和嚇嚇老鼠的東西,並把紀錄圖像化到雲端給老爸使用。 邏輯及設計: 當老鼠進入偵測範圍,Motion Sensor偵測到生物活動Raspberry pi 處理來自Motion Sensor的訊號,如果夠強的話開始準備作出回應 Raspberry pi在Angry cats sounds中隨機選出叫聲,再經由Speaker輸出貓叫聲 Raspberry pi指示強光元件發出強光束照射目標 把偵測計數上傳到雲端圖表 材料: Sensor 在網路上看了一些Raspberry pi wild animal camera ,很多也是用Motion Sensor先偵測動物再來,我用的是PIR Motion Sensor被動式紅外線感測器,有低耗電成本便宜的好處。[1],而且可手動調整靈敏度及反應時間。 PIR Motion Sensor就是下面這個 圖片來源: learn.adafruit.com 可手動調整敏感度還有反應時間,這個有點不好調,要試好多遍才找到最佳位置。 可以在Raspbian中輸入pinout查詢GPIO避免插錯 圖片來源: learn.adafruit.com . 一台Raspberry pi 這次使用較舊的Raspberry pi model B+ 萬一老鼠生氣被咬爛錢包也不太痛 . ...
前言:
上一篇提到怎樣把原本在資料庫的foreign ID在presentation layer中轉為給人看的值. 這一次談一下小弟的經驗, 利用GridView去修改已經轉為顯示值的foreign ID.
例如現在需要像下圖一樣把ID為2的那筆資料的CategoryName從糖水鋪轉為其他
方法:
上一篇提到怎樣把原本在資料庫的foreign ID在presentation layer中轉為給人看的值. 這一次談一下小弟的經驗, 利用GridView去修改已經轉為顯示值的foreign ID.
例如現在需要像下圖一樣把ID為2的那筆資料的CategoryName從糖水鋪轉為其他
我需要提供可供選擇的DropDownList
- 先把CategoryName轉成TemplateField. 在Gridview上按一下SmartTag, 選取Edit Columns. 在Selected fields中選取CategoryName, 然後在右邊選"Convert this field into a TemplateField". 然後按OK.
- 再次在Gridview中按一下SmartTag, 選擇"Edit Template", 然後在Smart Tag中選擇CategoryName的EditItemTemplate. 把原來的TextBox刪除, 然後拉一個DropdownList, 一個ObjectDatasource進去.
- 先設定ObjectDatasourceCompanyType. 按一下smart tag, 然後選"Configure Data Source", 然後選取放置文字的資料表, 像我這裡在COMPANY_TYPE, 選好以後按finish.
- 把DropDownList連結到ObjectDataSourceCompanyType. 按一下DropDownList-> smartTag -> Choose Data Souce. 把要顯示值還有data field設好. 按OK.
- 把DropDownList綁定GridView上的Category ID, 即是告訴系統說我這個DropDownList的值其實就是Category ID. 在DropDowdList中-> SmartTag->Edit Databindings
- 在"Bindable properties"中選取"SelectedValue", 在右邊Bound to選取儲存Category ID的欄位"CATEGORY", 勾選"Two-way databinding", 然後按OK.
- 最後, 把儲存category ID的欄位隱藏起來, 不然就會出現foreign ID跟顯示的值一起出現....像這樣.
按一下GridView->SmartTag->Edit Columns, 找到foreign ID的欄位, 把Visible設為False. 為什麼不直接把這欄位刪掉? 小弟試過這樣DropDownList就無法跟foreign key的欄位做連結了. - 這樣就搞定了!!!
Comments
Post a Comment