La toile est cool ! - page 24

 
Rafil Nurmukhametov:

Bonjour@Nikolai Semko, pourriez-vous me dire s'il est possible de faire un objet transparent sur du texte dans une couche de toile, voir l'image ? Le deuxième cercle transparent est la deuxième couche, cet objet n'est pas un problème pour moi de faire transparent.

Une autre question : comment insérer une image dans le calque de la toile ou dois-je la placer comme un calque supplémentaire ? Je sais que c'est une ressource, mais je n'arrive pas à la faire fonctionner, pouvez-vous me montrer un exemple de code ?

Si la transparence (COLOR_FORMAT_ARGB_NORMALIZE) est utilisée, la transparence de deux couches tr1 et tr2 doit être mélangée par la formule suivante

double tr=tr1+tr2-tr1*tr2; // где tr, tr1, tr1 меняются от нуля (абсолютная прозрачность) до 1(абсолютная непрозрачность) 

Exemple d'un script avec des cercles aléatoires de couleur et de transparence aléatoires :


#include <Canvas\iCanvas.mqh> //https://www.mql5.com/ru/code/22164
#define  Num 100
//+------------------------------------------------------------------+
//| Script program start function                                    |
//+------------------------------------------------------------------+
void OnStart()
  {
// инициализация случайных окружностей
   uint X[Num],Y[Num],sr[Num],clr[Num],Rmin[Num],Rmax[Num];
   double sx[Num],sy[Num];
   for(int i=0; i<Num; i++)
     {
      X[i]=rand()%3141;
      Y[i]=rand()%3141;
      sr[i]=rand()%3141;
      sx[i]=0.3+0.7*(double)rand()/32767.0;
      sy[i]=0.3+0.7*(double)rand()/32767.0;
      clr[i]=ARGB(rand()%256,rand()%256,rand()%256,rand()%256);
      int r2=5+rand()%100;
      int r1=5+rand()%100;
      Rmin[i]=(int)fmin(r1,r2);
      Rmax[i]=(int)fmax(r1,r2);
     }
// формирование изображения из Num (= 100) полупрозрачных кругов
   double j=0;
   while(!IsStopped())
     {
      Canvas.Erase();
      Canvas.CurentFont("Arial",30);
      Canvas.TextPosY=100;
      Canvas.Comm("Hello World!");
      for(int i=0; i<Num; i++)
        {
         Circle(W.Width/2*(1+sin((X[i]+sx[i]*j)*M_PI/1000)),
                W.Height/2*(1+sin((Y[i]+sy[i]*j)*M_PI/1000)),
                Rmin[i]+double(Rmax[i]-Rmin[i])/2*(1.0+cos((j+sr[i])*M_PI/1000)),clr[i]);
        }
      Canvas.Update();
      j+=0.3;
      Sleep(30);
     }
  }
//+------------------------------------------------------------------+

void Circle(double x,double y,double r,uint clr) 
  {
   double R2=r*r;
   for(int X=Round(x-r); X <=Round(x+r);X++)
      for(int Y=Round(y-r); Y<=Round(y+r);Y++)
         if(((x-X)*(x-X)+(y-Y)*(y-Y))<=R2) Canvas.PixelSet(X,Y,MixColor(clr,Canvas.PixelGet(X,Y)));
  }
//+------------------------------------------------------------------+

uint MixColor(uint clr,uint clrback)// смешиваем цвет и прозрачность clr c цветом и прозрачностью фона clrback
  {
   argb C,Bg;
   if(clrback==0) return clr;
   C.clr=clr;
   if(C.c[3]==255) return clr;
   Bg.clr=clrback;
   double tr=C.c[3]/255.0;
   double trb=Bg.c[3]/255.0;

   C.c[2]=uchar(Bg.c[2]+tr*(C.c[2]-Bg.c[2]));
   C.c[1]=uchar(Bg.c[1]+tr*(C.c[1]-Bg.c[1]));
   C.c[0]=uchar(Bg.c[0]+tr*(C.c[0]-Bg.c[0]));

   C.c[3]=uchar((trb+tr-trb*tr)*255.0+0.49999);
   return C.clr;
  }
//+------------------------------------------------------------------+
Dossiers :
 
Rafil Nurmukhametov:

@Nikolai Semko

J'ai une autre question : comment insérer une image dans le calque canvas ou dois-je la placer comme un calque supplémentaire ? Je comprends que d'une manière ou d'une autre à travers une ressource, mais je n'arrive à rien, pouvez-vous me montrer un exemple de code ?

Vous pouvez voir comment travailler avec des images ici .
Après tout, une image est la même chose qu'un tableau de points.
Cet exemple montre comment convertir les ressources de deux fichiers bmp en tableaux uint BMP1[], BMP2[] et travailler ensuite avec ces tableaux dans un seul canevas.

 
Merci beaucoup Nikolaï, j'ai enfin trouvé une solution.
 
Rafil Nurmukhametov:
Merci beaucoup Nikolaï, j'ai enfin trouvé une solution.

Vous êtes les bienvenus.

 

Premières expériences avec le cadre temporel dynamique.

EURUSD: toute l'histoire en dynamique :

.

La fractalité est évidente.
 
Nikolai Semko:

Premières expériences avec le cadre temporel dynamique.

EURUSD: toute l'histoire en dynamique :

.

La fractalité est évidente.
J'ai vu votre message en anglais.
S'il vous plaît, postez plus en anglais, y compris sur CodaBase (votre travail est très populaire là-bas).
Pour plus d'informations.
 
Sergey Golubev:
J'ai vu votre message en anglais.
Je veux vous demander de poster plus dans la partie anglaise, y compris sur KodaBase (votre travail est très populaire là-bas).
Juste pour info.
Merci. Je ferai de mon mieux.
Cependant, il m'a semblé que dans la partie anglophone du forum, la réaction à mes messages était proche de zéro. Le sentiment que j'éprouve tout le temps est celui de "me taire à moi-même...".
 
Nikolai Semko:

Premières expériences avec le cadre temporel dynamique.

EURUSD: toute l'histoire en dynamique :

.

La fractalité est évidente.
Bien joué !
 
Super !
 
Nikolai Semko:

Premières expériences avec le cadre temporel dynamique.

EURUSD: toute l'histoire en dynamique :

.

La fractalité est évidente.

Assez visuel, intéressant.

Pouvez-vous imaginer les tiques de cette façon aussi ?