2017年10月11日 星期三

台灣 支付寶 實名驗證圖文步驟 [身分證資訊填寫有誤處理方法]

台灣 支付寶 實名驗證圖文步驟 [身分證資訊填寫有誤處理方法]

先到 裡面開啟驗證信息
如果是白帳號這時候會要你設定支付密碼,記住千萬不能忘記!
再來會要你填入身分證信息
這裡要注意的是姓名要填簡體的,有些人簡體跟繁體一樣可以直接打就好會過;需要轉簡體的人提供一個APP可以輸入簡體。
如果有電腦,直接用google翻譯轉簡體傳FB或其他通訊軟體給自己就好了。
有些人拿到的卡,明明依照信息填入卻還是出現 身分證資訊填寫有誤 ,處理方式就是年分 -1 ,比如說我拿到的 2022 到期,先填入一次正確的出現錯誤之後再填入 2021 ,就可以過了。
輸入完畢之後下一關選人臉驗證,進去之後依照指示對著鏡頭眨眼就成功了。

2017年10月6日 星期五

Windwos10 開機自動啟動程式 資料夾位置

Windwos10 開機自動啟動程式 資料夾位置

傳統的XP只要到開始裡面尋找,啟動這個資料夾把捷徑放進去就可以自動啟動了,到了Win10之後這個資料夾就不見了。
其實他還在而且還有兩個位置,一個是公用的一個是使用者的,下面是使用者的位置,放在使用者裡面,只會影響該使用者,放在公用裡面則是這台電腦任何人登入都有。
這裡是啟動的路徑:
%APPDATA%\Microsoft\Windows\Start Menu\Programs\Startup
隨便開一個資料夾,把路徑複製貼上之後把你要的捷徑複製進去就好了。捷徑怎麼獲得可以直接從開始裡面搜尋,找到之後按右鍵開啟檔案位置,就可以複製了,記得用複製的用拉的會變成剪下,你的開始裡面就不見了。

Windows10 多使用者,刪除桌面圖示其他使用者跟著被刪除

Windows10 多使用者,刪除桌面圖示其他使用者跟著被刪除

這個問題主要是因為有些軟體放置的捷徑路徑不是放在使用者內,而是放在公用資料夾內,有在注意的人看安裝訊息的人應該看過會讓你決定是要替所有使用者安裝,還是只替當前使用者安裝,這句話的意思就是要安裝到公用資料夾還是個人資料夾。
所有使用者的桌面或開始程式集裡面都會包含公用使用者
這就是問題所在拉~導致你在A使用者砍掉圖示之後B使用者開上圖示捷徑也跟著不見,解決就是去公用資料夾,把圖示移動到自己的桌面就好。
下面分別給當前使用者與公用使用者的路徑,路徑是相對直徑直接貼上即可自動對應到你的使用者名稱。
公用桌面:%SystemDrive%\Users\Public\Desktop
當前使用者桌面:%USERPROFILE%\Desktop

2017年10月4日 星期三

C++ 影像處理如何畫線與畫箭頭

C++ 影像處理如何畫線與畫箭頭

花了一些時間做,放上部分的函式上來,有些沒有給的需要你自己更換或補上。
代碼
// 畫線RGB
void Draw::drawLineRGB_p(ImgRaw& img, int y, int x, int y2, int x2) {
    // 兩點之間的距離差
    float dx = x2-x;
    float dy = y2-y;
    // 以Y軸為主
    float sita=fastAtan2f(dy, dx);
    if (sita>45 and sita<135 or sita>225 and sita<315) {
        float slopeY = dx/dy; // 斜率
        for (int i = 0; i < abs(dy); i++) {
            int iFix = dy>0? i:-i;
            int currPos = iFix*slopeY + x;

            int distX = currPos;
            int distY = y+iFix;

            if (distX<0 or distX>=img.width or distY<0 or distY>=img.height) {
                return;
            }
            size_t posi = distY*img.width + distX;
            img.raw_img[posi*3 + 0] = 1;
            img.raw_img[posi*3 + 1] = 0;
            img.raw_img[posi*3 + 2] = 0;
        }
    } 
    // 以X軸為主
    else {
        float slopeX = dy/dx; // 斜率
        for (int i = 0; i < abs(dx); i++) {
            int iFix = dx>0? i:-i;
            int currPos = iFix*slopeX + y;

            int distX = x+iFix;
            int distY = currPos;

            if (distX<0 or distX>=img.width or distY<0 or distY>=img.height) {
                return;
            }
            size_t posi = distY*img.width + distX;
            img.raw_img[posi*3 + 0] = 1;
            img.raw_img[posi*3 + 1] = 0;
            img.raw_img[posi*3 + 2] = 0;
        }
    }
}
void Draw::drawLineRGB_s(ImgRaw& img, int y, int x, float line_len, float sg) {
    float value = 200 /255.0;
    float endvalue = 255 /255.0;
    // 防呆
    if (line_len < 0) {
        return;
    }
    if (line_len==1) {
        img.at2d(x, y) = value;
        return;
    }
    // 算頭尾
    int x2 = x + line_len*cos(sg * M_PI/180);
    int y2 = y + line_len*sin(sg * M_PI/180);
    // 畫線
    drawLineRGB_p(img, y, x, y2, x2);
}
void Draw::draw_arrowRGB(ImgRaw& img, int y, int x, float line_len, float sg) {
    float value = 200 /255.0;
    float endvalue = 255 /255.0;
    // 防呆
    if (line_len < 0) {
        return;
    }
    if (line_len==1) {
        img.at2d(x, y) = value;
        return;
    }
    // 算頭尾
    int x2 = x + line_len*cos(sg * M_PI/180);
    int y2 = y + line_len*sin(sg * M_PI/180);
    // 畫線
    drawLineRGB_p(img, y, x, y2, x2);
    // 畫頭
    drawLineRGB_s(img, y2, x2, 10, sg-150);
    drawLineRGB_s(img, y2, x2, 10, sg+150);
}
其中有一些是沒有補上的,在自己修一下。
  • ImgRaw帶有圖像資訊、長、寬
  • fastAtan2f是從OpenCV複製出來的可以參考站內文這裡


如何使用

drawLine有兩個,一個是給定兩個點,把他們連起來,另一個是給定原點, 長度, 角度,也就是給極值的方式畫線。
主要是給定的兩個點的函式,剩下兩個只是帶入這個函式使用而已。
    ImgRaw img_lineRGB(1280, 720, 24);
    for (size_t i = 0; i < 36; i++) {
        Draw::draw_arrowRGB(img_lineRGB, 200, 200, 100.f*sqrt(2), i*10);
    } img_lineRGB.bmp("lineRGB.bmp");
ImgRaw 做的事情很簡單只是開一個 vector(1280*720*3) 然後儲存他的長1280和寬720和位元數24,這裡位元數24bit是彩圖,灰階圖是8bit。
你在自己看著代碼補一下,或乾脆改成vector輸入,函式引數額再外輸入寬也可以。
畫一圈的箭頭

原理

主要是利用斜率去算的,假設有兩個點,分別是 (0, 0) 與 (40,50) 斜率的公式,其中b是偏移量暫時不管她。
y=ax+b;
斜率就只是相減而已
dy=50-0;
dx=40-0;

m=dy/dx;
既然已知斜率那就用for迴圈去跑x的範圍 0~40 就可以得出y的位置了
不過這會遇到一個問題是當直線是上下的時候 for 迴圈跑的次數是0畫不出線,其次可以發現這種畫法當線條比較偏上的時候,45~135度的範圍會明顯斷線的感覺,因此這時候要變成以y為主,for迴圈去跑y反向計算出x。
這樣就可以畫出上圖比較好看一些的線條了。

atan() 計算的時候如何得知正確角度;fastAtan2f() 快速計算方法

atan() 計算的時候如何得知正確角度;fastAtan2f() 快速計算方法

atan() 在計算的時候是沒有把dx和dy的正負號考慮進去的,也就是說在第3象限的時候會被當作第一象限來處理。
解決方法很容易,有一個已經幫你處好的函式是 atan2() 可以直接輸入 atan2(dy, dx) 計算出正確的結果,不過出來的角度是 -PI~PI 逕度還需要處理一下轉為角度。
這裡提供一個已經處理好上述而且速度更快的方法,是來自於OpenCV內的函式複製出來的相當實用。
static inline float fastAtan2f(float dy, float dx){
    // 快速atan運算
    static const float atan2_p1 = 0.9997878412794807f*(float)(180/M_PI);
    static const float atan2_p3 = -0.3258083974640975f*(float)(180/M_PI);
    static const float atan2_p5 = 0.1555786518463281f*(float)(180/M_PI);
    static const float atan2_p7 = -0.04432655554792128f*(float)(180/M_PI);
    static const float atan2_DBL_EPSILON = 2.2204460492503131e-016;

    float ax = std::abs(dx), ay = std::abs(dy);
    float a, c, c2;
    if (ax >= ay) {
        c = ay/(ax + static_cast<float>(atan2_DBL_EPSILON));
        c2 = c*c;
        a = (((atan2_p7*c2 + atan2_p5)*c2 + atan2_p3)*c2 + atan2_p1)*c;
    } else {
        c = ax/(ay + static_cast<float>(atan2_DBL_EPSILON));
        c2 = c*c;
        a = 90.f - (((atan2_p7*c2 + atan2_p5)*c2 + atan2_p3)*c2 + atan2_p1)*c;
    }
    if (dx < 0)
        a = 180.f - a;
    if (dy < 0)
        a = 360.f - a;
    return a;
}
fastAtan2f() 計算出來就是 0~360 度的角度了,如果需要逕度從代碼內把轉換的移除即可。
M_PI 可能需要自己定義一下,或者引入cmath並啟用宏定義(啟用是一行宏定義的代碼需要再自己查)。
如果只是單單需要拍自己定一個比較快~
#define M_PI 3.14159265358979323846

2017年9月29日 星期五

電腦休眠睡眠之後莫名其妙或動到滑鼠自己喚醒

電腦休眠睡眠之後莫名其妙或動到滑鼠自己喚醒

很多時候之所以不關電腦僅僅只是因為這樣方便,開啟的程序在明天之後又可以直接開始,其實也不用這麼特別費電,除非是需要連網的程式,不然使用休眠或睡眠就可幫你保持當前狀態,並且關閉電腦。
睡眠跟休眠差異不大,差異在於睡眠不會將記憶體斷電,記憶體一旦斷電資料就全沒了,所以睡眠的喚醒速度會快很多;但是如果遇到停電,比如說把插頭拔掉,那麼記憶體的東西就全沒,會變成休眠狀態記憶體的副本在你進入睡眠的時候會移併複製一份;比較簡單的分辨方法就是電源燈與硬碟燈會慢速閃爍。
至於更古老以前的XP所有的待機那又是另一回事。
新版的Win10已經沒有休眠這個選項了,剛剛也有提到其實睡眠也包含休眠,不過如果是在自己的房間睡覺的時候一閃一閃的也是很受不了。
要開啟休眠可以到控制台的電源選項
然後可以從這裡開出來

自動喚醒

不過在用的人應該不少人有這樣的困擾,為什麼休眠中的電腦會突然自己喚醒,或是動到滑鼠就喚醒了(撞到桌子連動感應到滑鼠),印題出自於以下
  • 滑鼠喚醒
  • 網路喚醒
網卡一般預設應該是關掉的,但是如果你確定沒動到滑鼠還是自己開機或是筆電連上wifi就自己開機,八成是網卡惹的禍。
對著左下的win按右鍵,找到裝置管理員可以打開他,然後找到你的網卡打勾
只允許 magic 封裝喚醒電腦
不然你會因為一堆莫名其妙的原因導致網卡啟動電腦。

滑鼠

再來處理滑鼠,可以透過這個指令查看那些裝置具有喚醒權限
powercfg -DEVICEQUERY wake_armed
看不爽的都停掉也是個辦法,我自己是有留鍵盤方便開機。
值得注意的是,有些滑鼠會有兩個以上的裝置!比如說羅技有3個,有太陽的無線接收器可能是因為可以接收6個裝置,所以同時有了鍵盤與滑鼠2個,3個都要關掉,不然滑鼠動到還是會喚醒。
關掉的方法如下。
至於有幾個妳就把滑鼠拔掉看看少幾個就知道,然後可以從ID去看說到底是哪一個。
這樣就不會在莫名其妙自己喚醒了。

2017年9月24日 星期日

Onedrive 已同步的綠色打勾消失不見

Onedrive 已同步的綠色打勾消失不見

我的電腦已經不見許久,不見的原因是因為系統還原過,最近新增了第二個Onedrive帳戶,沒想到新增完畢之後綠色就打勾就自己修復了!
從這裡新增第二個帳戶
新增完畢之後需要重新啟動電腦
可能會遇到的問題是系統變數 %onedrive% 會變成第二個帳戶,解決方法也很容易,自己到環境變數內修改即可。
更改回你要的位置
困擾了好久,意外解決了QuQ