summaryrefslogtreecommitdiff
path: root/ivi-layermanagement-examples/EGLWLInputEventExample/src/main.cpp
blob: 20c611f285b8e05890978ce4389dc8e1daa541e1 (plain)
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
/**************************************************************************
 *
 * Copyright 2010, 2011 BMW Car IT GmbH
 * Copyright (C) 2011 DENSO CORPORATION and Robert Bosch Car Multimedia Gmbh
 *
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *        http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 *
 ****************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <signal.h>
#include <unistd.h>
#include <getopt.h>
#include "WLContext.h"
#include "WLEGLSurface.h"
#include "WLEyes.h"
#include "WLEyesRenderer.h"

int gRunLoop = 0;
int gNeedRedraw = 0;
int gPointerX = 0;
int gPointerY = 0;


static void SigFunc(int)
{
    printf("Caught signal\n");
    gRunLoop = 0;
}

int main(int argc, char **argv)
{
    WLContext* wlContext;
    WLEGLSurface* eglSurface;
    WLEyes* eyes;
    t_ilm_surface surfaceId = 5100;

    argc = argc; // avoid warning
    argv = argv;


    // Get command-line options
    while (true){
        int c;
        static struct option opts[] = {
            {"surface", required_argument, NULL, 's'},
            {0, 0, 0, 0}
        };

        c = getopt_long(argc, argv, "s:", opts, NULL);

        if (c == -1)
            break;

        switch(c){
        case 's':
            surfaceId = strtol(optarg, NULL, 0);
            break;
        default:
            fprintf(stderr, "Unrecognized option '%s'\n", optarg);
        }
    }

    // signal handling
    signal(SIGINT,SigFunc);

    wlContext = new WLContext();
    wlContext->InitWLContext(&PointerListener, &KeyboardListener, &TouchListener);

    int const fd = wl_display_get_fd(wlContext->GetWLDisplay());

    ilmClient_init((t_ilm_nativedisplay)wlContext->GetWLDisplay());

    eglSurface = new WLEGLSurface(wlContext);
    eglSurface->CreateSurface(400, 240);
    eglSurface->CreateIlmSurface(&surfaceId, 400, 240);

    eyes = new WLEyes(400, 240);

    // initialize eyes renderer
    if (!InitRenderer()){
        fprintf(stderr, "Failed to init renderer\n");
        return -1;
    }

    // draw eyes once
    DrawEyes(eglSurface, eyes);

    // wait for input event
    gRunLoop = 1;
    gNeedRedraw = 0;
    while (gRunLoop){
        WaitForEvent(wlContext->GetWLDisplay(), fd);
        if (gNeedRedraw && gRunLoop){
            DrawEyes(eglSurface, eyes);
            gNeedRedraw = 0;
        }
    }

    TerminateRenderer();
    ilm_surfaceRemove(surfaceId);

    eglSurface->DestroyIlmSurface();

    ilmClient_destroy();
    delete eyes;
    delete eglSurface;
    delete wlContext;

    return 0;
}