2016年7月24日 星期日

[教學][android] OpenGL ES 繪製座標軸






















































大家安安~
今天不專業宅妹來做一個簡單的OpenGL ES教學
(一直懶得研究OpenGL ES 2.0聽說極度麻煩

主題簡單而言
就是繪製出xyz軸,並且能夠旋轉畫面.


layout部分就是~~~~什麼都不用

1
2
3
4
5
6
7
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="${relativePackage}.${activityClass}" >

</RelativeLayout>


然後你的package裡面會有兩個class,
分別是
MainActivity.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package com.example.gl_lines_test;
/*
 * References:
 * http://www.developer.com/ws/android/programming/opengl-es-for-android-graphics-programming.html
 * 
 */
import android.app.Activity;
import android.opengl.GLSurfaceView;
import android.os.Bundle;
import android.view.MotionEvent;

public class MainActivity extends Activity {
    private GLSurfaceView mView; 
    private MyRenderer mRenderer; 

    @Override
    protected void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState); 
          mView = new GLSurfaceView(this); 
          mRenderer = new MyRenderer(this); 
          mView.setRenderer(mRenderer);
          setContentView(mView); 
//        super.onCreate(savedInstanceState);
//        setContentView(R.layout.activity_main);
        }

        public boolean onTouchEvent(MotionEvent event) {
          return mRenderer.onTouchEvent(event); 
        }
}

這邊會收TouchEvent並傳給MyRenderer,去處理相關事件.





MyRenderer.java

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
package com.example.gl_lines_test;

import java.nio.ByteBuffer;
import java.nio.ByteOrder;
import java.nio.FloatBuffer;
import java.nio.ShortBuffer;

import javax.microedition.khronos.egl.EGLConfig;
import javax.microedition.khronos.opengles.GL10;

import android.content.Context;
import android.opengl.GLSurfaceView.Renderer;
import android.view.MotionEvent;

public class MyRenderer implements Renderer{
    private Context mContext; 
    private FloatBuffer mVertexBuffer = null; 
    private ShortBuffer mTriangleBorderIndicesBuffer = null; 
    private int mNumOfTriangleBorderIndices = 0;   
  
    public float mAngleX = 0.0f; 
    public float mAngleY = 0.0f; 
    public float mAngleZ = 0.0f; 
    private float mPreviousX; 
    private float mPreviousY; 
    private final float TOUCH_SCALE_FACTOR = 0.6f;
    private final float AXIS_SCALE_FACTOR = 1.5f;
    private final int AXIS_WIDTH = 10;
    private final float POINT_WIDTH = 10f;
  
    public MyRenderer(Context context) { 
      mContext = context; 
    } 

    public void onDrawFrame(GL10 gl) { 
      gl.glClear(GL10.GL_COLOR_BUFFER_BIT | GL10.GL_DEPTH_BUFFER_BIT); 
      gl.glMatrixMode(GL10.GL_MODELVIEW); 
      gl.glLoadIdentity();
  
      gl.glTranslatef(0.0f, 0.0f, -3.0f); 
      gl.glRotatef(mAngleX, 1, 0, 0); 
      gl.glRotatef(mAngleY, 0, 1, 0); 
      gl.glRotatef(mAngleZ, 0, 0, 1); 
      gl.glScalef(AXIS_SCALE_FACTOR, AXIS_SCALE_FACTOR, AXIS_SCALE_FACTOR);
  
      gl.glVertexPointer(3, GL10.GL_FLOAT, 0, mVertexBuffer); 
  
      gl.glLineWidth(AXIS_WIDTH);

      // Draw x line
      // Set line color to green     
      gl.glColor4f(0.0f, 1.0f, 0.0f, 1.0f); 
      gl.glDrawArrays(GL10.GL_LINES, 0, 2);
      gl.glDrawArrays(GL10.GL_LINES, 9, 2);
      gl.glDrawArrays(GL10.GL_LINES, 11, 2);

      // Draw y line
      // Set line color to red
      gl.glColor4f(1.0f, 0.0f, 0.0f, 1.0f);
      gl.glDrawArrays(GL10.GL_LINES, 2, 2);
      gl.glDrawArrays(GL10.GL_LINES, 13, 2);
      gl.glDrawArrays(GL10.GL_LINES, 15, 2);

      // Draw z lines
      // Set line color to blue
      gl.glColor4f(0.0f, 0.0f, 1.0f, 1.0f);
      gl.glDrawArrays(GL10.GL_LINES, 4, 2);
      gl.glDrawArrays(GL10.GL_LINES, 17, 2);
      gl.glDrawArrays(GL10.GL_LINES, 19, 2);

      gl.glPointSize(POINT_WIDTH);
      gl.glColor4f(1.0f, 0.0f, 1.0f, 1.0f);
      gl.glDrawArrays(GL10.GL_POINTS, 5, 3);
    } 

    public void onSurfaceCreated(GL10 gl, EGLConfig config) { 
      gl.glClearColor(0.0f, 0.0f, 0.0f, 0.0f); 
      gl.glHint(GL10.GL_PERSPECTIVE_CORRECTION_HINT, GL10.GL_NICEST); 
      gl.glEnable(GL10.GL_DEPTH_TEST); 
  
      gl.glEnableClientState(GL10.GL_VERTEX_ARRAY); 
  
      // Get all the buffers ready
      setAllBuffers();
    } 

    public void onSurfaceChanged(GL10 gl, int width, int height) { 
      gl.glViewport(0, 0, width, height); 
      float aspect = (float)width / height; 
      gl.glMatrixMode(GL10.GL_PROJECTION); 
      gl.glLoadIdentity();
      gl.glFrustumf(-aspect, aspect, -1.0f, 1.0f, 1.0f, 10.0f); 
    } 
  
    private void setAllBuffers(){
          // Set vertex buffer
          float vertexlist[] = { 
           -1.0f, 0.0f, 0.0f,   //0 X-axis
            1.0f, 0.0f, 0.0f,   //1 X-axis
            0.0f, 1.0f, 0.0f,   //2 Y-axis
            0.0f,-1.0f, 0.0f,   //3 Y-axis
            0.0f, 0.0f, 1.0f,   //4 Z-axis
            0.0f, 0.0f,-1.0f,   //5 Z-axis
            -0.5f , -0.5f, 0.0f ,   //6 point 1
            0.5f, -0.5f, 0.0f ,    //7 point 2
            0.0f , 0.5f, 0.0f ,      //8 point 3
            0.9f, 0.1f, 0.0f,    //9  X-axis
            1.0f, 0.0f, 0.0f,    //10 X-axis
            0.9f,-0.1f, 0.0f,    //11 X-axis
            1.0f, 0.0f, 0.0f,    //12 X-axis
            -0.1f, 0.9f, 0.0f,   //13 Y-axis
            0.0f, 1.0f, 0.0f,    //14 Y-axis
            0.1f, 0.9f, 0.0f,     //15 Y-axis
            0.0f, 1.0f, 0.0f,    //16 Y-axis
            0.1f, 0.0f, 0.9f,    //17 Z-axis
            0.0f, 0.0f, 1.0f,    //18 Z-axis
            -0.1f,0.0f, 0.9f,    //19 Z-axis
            0.0f, 0.0f, 1.0f,    //20 Z-axis
          };

          ByteBuffer vbb = ByteBuffer.allocateDirect(vertexlist.length * 4); 
          vbb.order(ByteOrder.nativeOrder());
          mVertexBuffer = vbb.asFloatBuffer();
          mVertexBuffer.put(vertexlist); 
          mVertexBuffer.position(0); 
      } 

    public boolean onTouchEvent(MotionEvent e) { 
      float x = e.getX();
      float y = e.getY();
      switch (e.getAction()) { 
       case MotionEvent.ACTION_MOVE: 
          float dx = x - mPreviousX; 
          float dy = y - mPreviousY; 
          mAngleY = (mAngleY + (int)(dx * TOUCH_SCALE_FACTOR) + 360) % 360; 
          mAngleX = (mAngleX + (int)(dy * TOUCH_SCALE_FACTOR) + 360) % 360; 
          break; 
      } 
      mPreviousX = x; 
      mPreviousY = y; 
      return true; 
    } 
}


好,因為我不知道怎麼把程式碼分開貼,
所以大概挑幾個部分講 XD

1. import有兩行被我標了黃色
那是一個容易import錯library的地方,
如果你的code一直有問題,
可能可以看看是不是選錯library.


2. 為了改code跟視覺上調整方便,
建議座標範圍都正規劃,再用factor、scale去做調整.


3.  拿繪製 x軸來講
      // Draw x line
      // Set line color to green     
      gl.glColor4f(0.0f, 1.0f, 0.0f, 1.0f); 
      gl.glDrawArrays(GL10.GL_LINES, 0, 2);
      gl.glDrawArrays(GL10.GL_LINES, 9, 2);
      gl.glDrawArrays(GL10.GL_LINES, 11, 2);

glColor4f是指定顏色,有興趣可以看一下android developers的介紹
gl.glDrawArrays(GL10.GL_LINES, 0, 2);
第一個欄位是指定要畫的型態是什麼,可以指定點啊、線blablabla,
然後 "0, 2"是指:
vertexlist[0]開始數2個element進行繪製,
換言之這邊會繪製vertexlist[0]與vertexlist[1].


規則大概就是這樣~
我想應該還有些其他的繪製方式,
但如果只是要畫三軸的話這樣很快!
下次來寫畫球好了.
掰掰~~~




Reference: OpenGL ES for Android Graphics Programming



2016年7月14日 星期四

[教學] 早上如何輕鬆起床不賴床

大家安安~
這篇是為了我的摯友 親親寫的,
但我覺得看完你們可會覺得我是瘋子,
如果你正在暗戀我,
求你不要看這篇好ㄇ ?





-------------------- 防雷 --------------------







早上起床第一個念頭最重要惹~

因為我從小就很會幻想+聯想,
你用文字稍微形容一些場景我腦中就馬上會有動態畫面XD
so我都會用一些幻想的方法讓自己不會有起床氣.

1. 假裝妳是一台電腦

































媽媽/鬧鐘叫我起床的動作我會想成是按下開機鍵,
睜開眼之後我就開始背誦開機流程XDDDDDD
好不浪漫喔這就是職業病啊!!!

有時候太晚睡腦筋昏昏意識沒那麼快回來,
我會跟自己說 喔 今天這台電腦開機速度比較慢不是Zenbook之類的.




2. 假裝妳是一隻松鼠或狗

姐小時候看很多迪士尼卡通,
常常會幻想自己也是他們森林裡的好朋友,
我好像沒看過小動物有起床氣,
所以我有時候會想,
"噢~等等要到大安森林公園奔跑玩球"
"噢~等等要去採松果"
之類的.

這個幻想法就是要幻想自己是可愛的,
然後專注在等等要做的開心事上面(先忘了你要上班ㄅ
起床氣就會不見惹~






3. 假裝妳是遊戲角色,現在在模擬市民的遊戲中

我真的覺得玩遊戲可以學習到很多XDDD
當你幻想你是模擬市民裡面的主角時,
會覺得自己是被程式控制的... so根本沒有任何情感,
當你有任何情緒一出來的時候,
下一秒要相呼叫clear這個function一樣、把情緒清掉.







所以,
要怎麼樣好好的起床不賴床沒有起床氣呢?

催眠你自己~~~~~~
一切都用幻想的就對了~~~~~








打完收工:^P







2016年7月11日 星期一

[教學] 如何幫Facebook粉絲專頁打廣告?(instagram篇)

大家安安~
今天來試用一下instagram的廣告功能
雖然我自己很討厭看到ig廣告




1. 先到粉絲頁後台,選擇 "Settings"























2. 選擇 "Instagram Ads"






























3. 輸入你的ig帳戶



























4. 這樣就有將facebook fanpage跟instagram account bind在一起了~



























5. 回到粉專首頁,選擇左下角 "Promote"
































6. 選擇最下面的 "Go to Ads Manager"




























7. 選擇" +Create Campaign"

























8. 選擇 "Send people to your website"





9. 編輯你的廣告對象,可以編輯地區、年齡、有興趣的主題...等






































10. 選擇要放置廣告的地方~這次我想試試看只放ig,所以只勾了他























11. 接著再選一些細項,像是一天的預算多少~以及開始跟結束日期(是Pacific Time唷!)





12. Format的部分也可以選一下,我想選單張圖片~






      Media的欄位則是能夠選擇想要呈現的圖.





13. 都填得差不多之後,就可以按Place Order囉!







14. 這樣就好囉~





15. 此時後台就會有資訊了! 關於這些分析的資訊大家可以再研究一下XD









打完收工~~~
希望對大家有幫助唷:D