summaryrefslogblamecommitdiff
path: root/src/bin/cxx/image_blend_border.cc
blob: b6c37f40b230b43c40ceef10af968059e8fa8629 (plain) (tree)
1
2
3
4
5
6
7
8
           



                    


                 



                  


                              
                                    
 
 
                                           






                    

                                         
      
                                                
                            
                                                








                                 
                  







                                  
                                                                           








                                                                                
 
                                 
                                           

















                                                              
// XXX DONE
#ifdef HAVE_CONFIG_H
# include <config.h>
#endif

#include "Eo.h"
#include "Evas.h"

#include "Eo.hh"
#include "Eina.hh"
#include "Evas.hh"

#include "main.h"

#define EXPEDITE_CXX_TEST_IMPL
#include "image_blend_border_capi.h"


static efl::eina::list<evas::image> images;

/* standard var */
static int done = 0;

/* setup */
static void _setup()
{
   evas::canvas canvas(::eo_ref(G_evas));
   for (int i = 0; i < OBNUM; i++)
     {
        evas::image o(efl::eo::parent = canvas);
        images.push_back(o);
        o.file_set(::build_path("bar.png"), "");
        o.border_set(6, 6, 6, 6);
        o.visibility_set(true);
     }
   done = 0;
}

/* cleanup */
static void _cleanup()
{
   images.clear();
}

/* loop - do things */
static void _loop(double t, int f)
{
   int i = 0;
   Evas_Coord x, y, w, h, w0, h0;

   for (auto it = images.begin(), end = images.end(); it != end; it++, i++)
     {
        w0 = 80;
        h0 = 80;
        w = 5 + ((1.0 + cos((double)(f + (i * 10)) / (7.4 * SLOW) )) * w0 * 2);
        h = 5 + ((1.0 + sin((double)(f + (i * 19)) / (12.6 * SLOW) )) * h0 * 2);
        x = (win_w / 2) - (w / 2);
        x += sin((double)(f + (i * 13)) / (36.7 * SLOW)) * (w0 / 2);
        y = (win_h / 2) - (h / 2);
        y += cos((double)(f + (i * 28)) / (43.8 * SLOW)) * (h0 / 2);

        (*it).position_set(x, y);
        (*it).evas::object::size_set(w, h);
        (*it).fill_set(0, 0, w, h);
     }

   FPS_STD(NAME);
}

/* prepend special key handlers if interactive (before STD) */
static void _key(char *key)
{
   KEY_STD;
}

extern "C" void FNAME(void)
{
   ui_func_set(_key, _loop);
   _setup();
}