K-K App 生活樂園工作室 隱私權政策
更新日期:2016/02月
本文說明「K-K App 生活樂園工作室」的隱私權政策。請您詳細閱讀,本文不定期更新,您若繼續使用「K-K App 生活樂園工作室的 APP」,即代表您同意相關此政策。
1. 個人資料之類別
當您使用「K-K App 生活樂園工作室的 APP」(下稱「本APP軟體」)時,本團隊會蒐集下列類別的個人資料:網路IP、手機所屬電信商代碼等,如果您有付費使用到Google Play Store或App Store的應用程式內付費功能,則依照市集平台的系統內建功能,在付費的交易紀錄裡,收集姓名、email、以及郵遞區號資訊。
2. 資料的收集與應用
「K-K App 生活樂園工作室的 APP,有收集下述資料:
(1) 當撥打內建在APP裡的各種電話服務時,本APP不會記錄撥打次數、時間、所在國家、位置資訊(Location)。
(2) 當您透過網站或者是APP回報意見或問題時,寄信所使用之email。此蒐集目的作為處理問題後,回覆您之用途,不會販賣給第三方使用。
(4) 本APP有採用Google Analytics,匿名性的收集瀏覽各頁以及撥號紀錄狀況,以持續改善,調整出使用者最喜歡常用的內容。
(5) Google Play 付費,或者App Store 的付費版本,兩平台的市集,會紀錄您的email 、姓名,以及郵遞區號,這些都屬於系統的紀錄,我們不會拿來對外界公開。
(7) 收集手機的裝置代碼 (device ID 或device token ),作為推播訊息使用。
3. 第三方函式庫整合
(1) 本APP軟體有採用Google官方的APP流量統計軟體Google Analytics來評估APP各項功能操作的行為,目的是為了改善優化產品,提供更適合用戶偏好喜歡的內容。
(2) 本APP軟體整合行動廣告服務,會使用到第三方廣告系統的函式庫,目前使用 google Admod 公司的廣告系統 。
(3) 本APP軟體,查詢在地餐廳、咖啡廳、飲食,採用Google API,查詢時,會使用手機拿到的座標經緯度,來搜尋附近推薦店家。
4. 本軟體不會收集的項目
凡是您自行新增之撥打號碼規則,「K-K App 生活樂園工作室的 APP」不會做收集,以維護您的個人隱私。
5. 「K-K App 生活樂園工作室的 APP」的資料儲存與保護
「K-K App 生活樂園工作室的 APP」為方便用戶使用,提供多項個人化設定功能。包含「我的最愛清單 」、「新增撥號規則」。這些都是儲存在手機的記憶體內,請您妥善保管手機。
6. 同意個人資料之蒐集、處理、利用或國際傳輸:
您了解並同意本團隊依本「隱私權政策」及相關法規,蒐集、處理或利用您所提供的個人資料。
7. 除下列情形外,本團隊不會任意將您的個人資料出售、轉讓或揭露予任何第三人:
(1) 本團隊/本APP軟體將因法律規定、法院命令、行政調查或其他法律程序的要求而提供您的資料,惟在此情形下,該資料只會單純提供予調查單位,並受中華民國相關應適用法律的保護。
(2) 為了調查和防止非法活動、涉嫌詐欺、對人身安全有潛在威脅的狀況、對本團隊/本APP軟體服務條款的違反,或為了對上述情形採取應對措施。
(3) 本APP軟體或本團隊被其他公司收購或合併,我們有權利將您的個人資料移轉給該公司。如果發生這種情況,本APP軟體會在您的個人資料被移轉且將適用不同的隱私權政策前通知您。
8. 個人資料之安全
本團隊將依相關法律規定,採取適當的技術性和組織性等安全措施,保護您所提供的個人資料,並限於因業務需要必須接觸您個人資料的員工,始有權限接觸到您的個人資料。本團隊已採取符合法規要求的實體、電子和程序防護措施,以保護您個人資料的安全。但請注意,儘管本團隊會盡力保護您的個人資料,仍無法保證您的個人資料百分之百不會遭受第三人之非法攔截、傳送或盜駭。
如果您有任何關於本隱私權政策的問題,請來信討論:chiang.kevin0603@gmail.com
程式設計 Club
工作上的隨手筆記
2017年2月6日 星期一
2016年9月21日 星期三
How to create file and directory in Java.
String filePath = "logs/test.log"; File file = new File(filePath);
此時如果直接createNewFile()
if(!file.exists()) { try { file.createNewFile(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
會因為parent的資料夾不存在而失敗,而這時直接使用mkdirs()
if(!file.exists()) { file.mkdirs(); try { file.createNewFile(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
但這樣會把01.log也當成資料夾建立,就無法createNewFile,所以應該先切換到上層目錄再進行mkdirs()
if(!file.exists()) { file.getParentFile().mkdirs(); try { file.createNewFile(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } }
2016年9月20日 星期二
取得螢幕實際寬高的方法
取得螢幕實際寬高的方法
標籤: Android
基本上這方法就寫在官方的 doc 裡
網路搜尋的話也很容易找到
不過還是在此記錄一下
主要就是在 Activity 裡利用 getWindowManager() 先取得系統唯一的 WindowManager
然後取得一個 DisplayMetrics 物件
這物件主要是存放解析度相關的屬性
包含 densityDpi, widthPixels, heightPixels ... 等
所以利用 DisplayMetrics 很簡單就得到螢幕實際像素了
WindowManager 除了透過 Activity 的 getWindowManager()獲得之外
還可以透過 Context 的 getSystemService(Context.WINDOW_SERVICE) 取得
所以 code 也可以這樣改
網路搜尋的話也很容易找到
不過還是在此記錄一下
1
2
3
4
5
| DisplayMetrics displaymetrics = new DisplayMetrics(); //使用 Activity 的 getWindowManager()獲得 WindowManager getWindowManager().getDefaultDisplay().getMetrics(displaymetrics); int height = displaymetrics.heightPixels; int width = displaymetrics.widthPixels; |
主要就是在 Activity 裡利用 getWindowManager() 先取得系統唯一的 WindowManager
然後取得一個 DisplayMetrics 物件
這物件主要是存放解析度相關的屬性
包含 densityDpi, widthPixels, heightPixels ... 等
所以利用 DisplayMetrics 很簡單就得到螢幕實際像素了
WindowManager 除了透過 Activity 的 getWindowManager()獲得之外
還可以透過 Context 的 getSystemService(Context.WINDOW_SERVICE) 取得
所以 code 也可以這樣改
1
2
3
4
5
6
7
8
| public static int [] getDisplayPixels(Context context){ DisplayMetrics displaymetrics = new DisplayMetrics(); WindowManager windowManager = (WindowManager) context.getSystemService(Context.WINDOW_SERVICE); windowManager.getDefaultDisplay().getMetrics(displaymetrics); int width = displaymetrics.widthPixels; int height = displaymetrics.heightPixels; return new int []{width, height}; } |
2015年4月20日 星期一
學習Apple Swift語言不可錯過的六個免費網路資源
學習Apple Swift語言不可錯過的六個免費網路資源
3 則迴響
Swift語言是Apple在2014年六月推出的一個新的程式語言,將取代舊有的Objective-C程式,成為iOS以及Mac OS X平台的標準語言,如果想儘快學習這門新語言,該如何開始呢?
以下我分享六個最實用的Swift網路學習資源,希望對你有所幫助:
1. Swift官方電子書(Apple官方提供)
你可以透過iTunes下載這本電子書到你的iPhone或iPad上,如果你想要用一般的PC來閱讀,它也有網頁版本,你可以透過網頁版本在你的PC上面瀏覽並學習。
*電子書下載連結(iTunes):The Swift Programming Language
2. Swift中文電子書(熱心網友翻譯)
Apple提供的Swift電子書雖然是官方釋出,但可惜是英文版本,許多人可能看到數百頁的英文電子書就要昏了… 好消息是,有中國的網友號召30多人把這本數百頁的英文電子書翻譯成中文了,只花了九天,相當了不起!
*Swift中文電子書:The Swift Programming Language 中文版
3. Swift官方部落格(提供最新消息,學習資訊)
Apple為了推廣Swift,特別建立了部落格來提供Swift程式語言的最新消息,以及學習的資訊。因為Swift是一個很新的語言,不免仍然會有一些語法上的修改,這個部落格時常將最新的Swift版本或語法更新在這裡發佈,建議想學習Swift的朋友也要常常關注這個部落格來學習最新的內容。
*Swift官方部落格:Swift部落格連結
4. 知名國外教學網站Ray Wenderlich
Ray Wenderlich是一個專業的國外教學網站,專注於iOS開發以及App遊戲設計,從2014年六月起,已經在他們網站上製作了不少Swift的相關教學文章(目前已有十多篇),他們的教學相當不賴,你可以在以下連結找到他們提供的Swift學習指導教學。
*Ray Wenderlich的Swift免費教學:Swift免費教學文章
5. 想找Swift範例程式碼?到GitHub上面找吧!
GitHub是一個程式碼版本控制網站,上面持續累積的Swift程式碼,已經高達9000個以上了,內容也經橫跨不同應用,十分地豐富,對於Swift已經有一些了解,想要找別人寫好的程式碼來學習的朋友,可以到GitHub上面找找看。
* GitHub上語言標記為Swift的程式搜尋結果:超過9000個以上的Swift程式範例
6. 有問題想問人該去哪裡問呢?Stack Overflow是首選!
Stack Overflow是一個國外知名的IT技術問答網站,從Swift發表到現在約三個多月,Stack Overflow上面關於Swift語言的問題已經累積達8500個以上,由於這個網站的聚集了許多程式設計方面的專家,如果在自學上遇到問題,也可以先來這裡看看是否已有這個問題的解答。
*Stack Overflow的Swift語言相關問題:Stack Overflow上的Swift程式相關問題
快速結論
學習Swift程式不可錯過的六個免費網路資源,除了Apple官方的Swift程式語言電子書,以及Swift官方部落格之外,還有網友合力翻譯的Swift中文電子書、國外Ray Wenderlich網站的專業教學、GitHub上的豐富程式碼資源,以及Stack Overflow的問答知識庫,這些資源都可以給你很大的學習幫助。
2015年3月12日 星期四
Android 禁止螢幕旋轉 & 螢幕旋轉不刷新 Activity & 動態更改螢幕方向
一、禁止螢幕旋轉:
打開工程中的 AndroidManifest.xml 檔,在 <activity> </activity> 中,添加一條屬性資訊:
android:screenOrientation="portrait" (強制豎屏)
android:screenOrientation="landscape" (強制橫屏)
二、螢幕旋轉不刷新 Activity:
當螢幕旋轉時,會重新執行 Activity 中的 onCreate() 方法,即刷新了 Activity 的顯示。若是不想刷新,可以用第一種方法鎖屏,也可以用以下方法:
1、打開工程中的 AndroidManifest.xml 檔,在 <activity> </activity> 中,添加一條屬性資訊:
android:configChanges=”orientation|keyboardHidden”
注:這個屬性指的是,當後邊屬性值代表的事件發生時,Activity 會執行某個函數,orientation 指的是當螢幕旋轉時,keyboardHidden 指的是鍵盤輔助功能改變。“|”為或符號,指這兩個中任意一個發生,就執行 Activity 某個函數。
注2:如果你的開發 API 等級等於或高於 13,你還需要設置 screenSize,因為 screenSize 會在螢幕旋轉時改變。
2、在對應 Activity 中重寫 onConfigurationChanged() 方法:
@Override
public void onConfigurationChanged(Configuration newConfig) {
// TODO Auto-generated method stub
super.onConfigurationChanged(newConfig);
if (newConfig.orientation == Configuration.ORIENTATION_LANDSCAPE) {
// 什麼都不用寫
}
else {
// 什麼都不用寫
}
}
public void onConfigurationChanged(Configuration newConfig) {
// TODO Auto-generated method stub
super.onConfigurationChanged(newConfig);
if (newConfig.orientation == Configuration.ORIENTATION_LANDSCAPE) {
// 什麼都不用寫
}
else {
// 什麼都不用寫
}
}
注:如果在 if、else 中,使用了 setContentView(R.layout.xxxx) 函數,那麼就可以實現:每次螢幕旋轉時,調用不同的佈局。
三、動態更改螢幕方向:
有些時候,我們不需要把程式寫死,需要在程式中有需要的時候旋轉螢幕,例如:在“設置”裏添加一個 ListView 項,可通過點擊選擇橫屏或豎屏。(比如:電子書軟體)
假設有一個按鈕,我們僅重寫 OnClick() 函數:
@Override
public void onClick(View v) {
public void onClick(View v) {
// 如果是豎排,則改為橫排
if (getRequestedOrientation() == ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE) {
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
}
if (getRequestedOrientation() == ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE) {
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
}
// 如果是橫排,則改為豎排
else if (getRequestedOrientation() == ActivityInfo.SCREEN_ORIENTATION_PORTRAIT) {
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
}
else if (getRequestedOrientation() == ActivityInfo.SCREEN_ORIENTATION_PORTRAIT) {
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE);
}
}
重點就是:getRequestedOrientation() 函數、setRequestedOrientation() 函數的使用。
注意:使用這種方法,必須事先在 AndroidManifest.xml 的 <activity> </activity> 中,添加android:screenOrientation 屬性值,不然 getRequestedOrientation() 可能會出問題。
訂閱:
文章 (Atom)