La tela è forte! - pagina 24

 
Rafil Nurmukhametov:

Ciao@Nikolai Semko, potresti dirmi se è possibile fare un oggetto trasparente sopra il testo in un livello di canvas, vedi l'immagine? Il secondo cerchio trasparente è il secondo livello, questo oggetto non è un problema per me da rendere trasparente.

Un'altra domanda, come inserire un'immagine nel livello della tela o devo metterla come livello aggiuntivo? So che è una risorsa, ma non riesco a farlo funzionare, puoi mostrarmi un esempio di codice?

Se si usa la trasparenza (COLOR_FORMAT_ARGB_NORMALIZE), la trasparenza di due livelli tr1 e tr2 dovrebbe essere mescolata dalla formula

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

Esempio di uno script con cerchi casuali di colore casuale e trasparenza casuale:


#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;
  }
//+------------------------------------------------------------------+
 
Rafil Nurmukhametov:

@Nikolai Semko

Ho un'altra domanda: come inserire un'immagine nel livello della tela o devo metterla come livello aggiuntivo? Ho capito che in qualche modo attraverso una risorsa, ma non riesco a ottenere nulla, puoi mostrarmi un esempio di codice?

Potete vedere come lavorare con le immagini qui .
Dopo tutto, un'immagine è la stessa cosa di una matrice di punti.
Questo esempio mostra come convertire le risorse di due file bmp in array di uint BMP1[], BMP2[] e lavorare ulteriormente con questi array in un canvas.

 
Grazie mille Nikolai, finalmente ho risolto il problema
 
Rafil Nurmukhametov:
Grazie mille Nikolai, finalmente ho risolto il problema

Non c'è di che.

 

Primi esperimenti con l'orizzonte temporale dinamico.

EURUSD tutta la storia nella dinamica:

.

La frattura è evidente.
 
Nikolai Semko:

Primi esperimenti con l'orizzonte temporale dinamico.

EURUSD tutta la storia nella dinamica:

.

La frattura è evidente.
Ho visto il tuo post in inglese.
Per favore, pubblica di più in inglese, incluso CodaBase (la tua roba è molto popolare lì).
Per informazioni.
 
Sergey Golubev:
Ho visto il tuo post in inglese.
Voglio chiederti di postare di più nella parte inglese, incluso CodaBase (la tua roba è molto popolare lì).
Solo per informazione.
Grazie. Farò del mio meglio.
Tuttavia, mi è sembrato che nella parte anglofona del forum, la reazione ai miei post fosse vicina allo zero. La sensazione è sempre quella: "in silenzio a me stesso...".
 
Nikolai Semko:

Primi esperimenti con l'orizzonte temporale dinamico.

EURUSD tutta la storia nella dinamica:

.

La frattura è evidente.
Ben fatto!
 
Grande!
 
Nikolai Semko:

Primi esperimenti con l'orizzonte temporale dinamico.

EURUSD tutta la storia nella dinamica:

.

La frattura è evidente.

Piuttosto visivo, interessante.

Possiamo visualizzare le zecche anche in questo modo?