abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 00:22 | Nová verze

    Byla vydána verze 1.96.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    28.5. 20:33 | IT novinky

    Společnosti IBM a Red Hat představily Project Lightwell s investicí 5 miliard dolarů. Jedná se o důvěryhodné clearingové centrum pro bezpečnost open source softwaru a zabezpečení dodavatelských řetězců s novým AI modelem a globální skupinou více než 20 000 softwarových inženýrů. Služby centra budou dostupné prostřednictvím komerčních předplatných. Project Lightwell staví na iniciativách jako Anthropic Glasswing nebo OpenAI Trust Access for Cyber.

    Ladislav Hagara | Komentářů: 1
    28.5. 18:22 | Nová verze

    Open source 3D herní a simulační engine Open 3D Engine (O3DE) byl vydán v nové verzi 26.05. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    28.5. 11:44 | IT novinky

    Český stát by v budoucnu mohl provozovat vlastní alternativu ke komunikačním aplikacím typu WhatsApp, Signal, Telegram, Facebook Messenger a podobně. Cílem je zajistit bezpečnou datovou komunikaci pro stát a jeho důležité subjekty, jako jsou bezpečnostní složky, ministerstva a další organizace.

    Ladislav Hagara | Komentářů: 24
    28.5. 11:22 | Pozvánky

    Už za týden, ve čtvrtek 4. června, se v Národní technické knihovně v pražských Dejvicích uskuteční další konference věnovaná tématům spojeným s IPv6 - Den IPv6. Program akce a registrační formulář jsou k dispozici na webu akce. Kapacita konference je omezená, proto organizátoři doporučují, aby se vážní zájemci přihlásili včas (k dnešnímu dni zbývá přibližně 30 volných míst). Konferenci Den IPv6 2026 organizují i letos společně sdružení CESNET, CZ.NIC a NIX.CZ.

    VSladek | Komentářů: 1
    28.5. 05:22 | IT novinky

    Zařízení Steam Deck OLED bylo znovu naskladněno, ale vlivem rostoucích cen pamětí a úložišť má novou, vyšší cenovku. Steam Deck OLED 512 GB stojí nově 779 EUR (stál 569 EUR) a Steam Deck OLED 1 TB stojí 919 EUR (stál 679 EUR). Samotné zařízení se nijak nezměnilo a nové ceny tedy pouze odráží aktuální náklady na komponenty a další globální logistické výzvy, se kterými se potýká celá branže.

    Ladislav Hagara | Komentářů: 0
    27.5. 22:22 | IT novinky

    Český telekomunikační úřad zahajuje novou etapu využívání vysokofrekvenčního rádiového spektra v pásmu 26 GHz. Toto pásmo bude od 1. 7. 2026 otevřeno pro provoz moderních bezdrátových sítí, zejména sítí páté generace (5G), pevných bezdrátových přístupových sítí (FWA) a lokálních či průmyslových sítí určených například pro výrobní areály, logistická centra nebo technologické kampusy. Současně s otevřením pásma 26 GHz přistoupil ČTÚ ke zpřístupnění informací o využívání rádiových kmitočtů v tomto pásmu.

    Ladislav Hagara | Komentářů: 9
    27.5. 22:11 | IT novinky

    Logitech představil myš Signature Comfort Plus M850 L s polstrovanou opěrkou dlaně pro větší pohodlí a sadu s touto myší a klávesnicí s integrovanou opěrkou dlaní Signature Comfort Plus Combo MK880.

    Ladislav Hagara | Komentářů: 1
    27.5. 16:33 | IT novinky

    Gaël Duval se rozepsal o novinkách a plánech Murena a /e/OS. Počet uživatelů telefonů Murena a mobilního operačního systému /e/OS bez aplikací a služeb od Googlu se blíží 100 000. Ambicí je, aby se /e/OS stal třetí mobilní platformou v Evropě i na světě, s potenciálem dostat se i na PC. Blíží se vydání nové verze 4 s funkcemi zálohování a obnova, import e-mailů z Gmailu a rozpoznávání hlasu. Murena Workspace přinese videohovory, elektronický podpis a správu zařízení (MDM).

    Ladislav Hagara | Komentářů: 4
    27.5. 15:22 | Komunita

    Dnes a zítra probíhá Ubuntu Summit 26.04. Na programu je řada zajímavých přednášek. Sledovat je lze na YouTube. Úvodní slovo měli Mark Shuttleworth a Jon Seager.

    Ladislav Hagara | Komentářů: 1
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (15%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1757 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    PHP7 rozplizlý elipsoidní výřez z obrázku

    21.9.2019 14:14 | Přečteno: 2429× | linux | poslední úprava: 20.9.2019 14:15

    Jak vyříznout z obrázku elipsoid a rozpliznout tomu okraje - pokus

    Napadlo mně plácnout na stránku obrázek tak, aby to nebyl jen obrázek. Říkal jsem si, že rozpliznuté okraje by tomu daly trochu estetiky. Já tedy zrovna estét nejsem, ale napadlo mně to ...

    První možnost byla prostě ty obrázky upravit v GIMPu, ale ... zase možnost použít obrázky, které používám jinde, a efekt provést programově ... to by se mohlo ( mělo ) zkusit ...

    Protože tato oblast programování je mi cizí, měl jsem o pár dnů zkoušení postaráno... po mnoha slepých uličkách jsem skončil u php7 -Imagick rozšíření, a opět RTFM a testuj...

    Nakonec jsem zjistil, že docela dobře můžu použít jakousi masku ( opravdu, tohle není moje doména ) .. proběhl jsem dokumentaci a jeden z mála nalezených příkladů zkusil napasovat na můj požadavek. Výsledek se nakonec podstatně lišil od naznačené cesty, hlavně proto, že kolega programátor měl jiný (ale podobný) cíl.

    Výsledný obrázek cca 400x500 pixelů se ( včetně prvotního zmenšení originálu z podstatně většího 2.5k x 4k ) tvoří asi půl sekundy .. no je to dost ... Pokud máte lepší řešení, nechám se inspirovat.

    tady uvedu jen komentovaný zdroják, myslím, že je to docela srozumitelné ( až na ty grafické kejkle, které jsou pro mně prostě černá skříňka )..

    function transform_image( Imagick $image, $width ){
    
    	$xSize	= $image->getImageWidth();
    	$ySize	= $image->getImageHeight();
    	$imgWidth = $width*0.8;
    	$ratio = (float)$xSize / (float) $imgWidth;
    	$imgHeight = $ySize / $ratio;
    	$image->scaleImage( $imgWidth, $imgHeight );
    		
    	$image->setImageFormat( "png" );
    
    	$draw = new ImagickDraw();
    
    	//obrázek "maska"
    	$maska	= new Imagick();
    	// průsvitná bílá, nyní jen pro barvu pozadí nového maskovacího obrázku
    	$maska->newImage( $imgWidth, $imgHeight, new ImagickPixel("rgba( 100%, 100%, 100%, 0 )"), 'png' );
    		
    //trocha počítání .... 
    //počet kroků a "tloušťka" rozpliznutí
    	$step=2; $steps = 20;
    
    	//rozplizávací čáru trochu tlustší
     	$draw->setStrokeWidth( $step +2 );
    
    	//střed obrázku
     	$icx	=	$imgWidth/2;
    	$icy	=	$imgHeight/2;
    
    	//parametry centrální elipsy, která označí oblast 100% viditelnosti a nechá prostor pro rozpliznutí
     	$iw	= $imgWidth-(2*$steps*$step);
    	$ih	= $imgHeight-(2*$steps*$step);
    
    	//poloměry centrální elipsy
    	$iw2	= $iw/2;
    	$ih2	= $ih/2;
    	// setFillOpacity na elipsu nefunguje
    	$draw->setFillColor( new ImagickPixel( "rgba( 0%, 10%, 10%, 0 )" ) );
    	//elipsy tvořím od kraje "dovnitř"
    	for($i=$steps; $i>0 ;$i-- ){
     		$o	=  1-(float)($i/$steps) ;
     		$draw->setStrokeColor( new ImagickPixel("rgba( 0%, 0%, 0%, $o )") );
    		$draw->ellipse( $icx, $icy, $iw2+$i*$step, $ih2+$i*$step, 0, 360 );
    	}
    		
    	//a poslední "plnou" elipsu uvnitř
    	$strokecolor->setColor( "rgba( 0%, 0%, 0%, 1 )" );
     	$draw->setStrokeColor( $strokecolor );
     	//$draw->setFillOpacity( 1 );  setFillOpacity pro elipsu nefunguje (?), musí se nastavit v setFillColor
    	$draw->setFillColor( new ImagickPixel( 'black' ) );
    	$draw->ellipse( $icx, $icy, $iw2, $ih2, 0, 360 );
    
    	//vykreslíme masku - vznikne elipsa s rozplizlými okraji
    		
    	$maska->drawImage( $draw );
    		
    	// a na původní obrázek naneseme masku průhlednosti --- neptejte se mně jak to funguje, byl to google - pokus - omyl pořád dokolečka, až se povedlo
    	$image->compositeImage( $maska,Imagick::COMPOSITE_COPYOPACITY, 0, 0 );
    	// a šup s nim ven 
    	header('Content-Type: image/'.$image->getImageFormat());
    	$a = $image->getImageBlob(); //přímý výstup nefungoval, nevím proč .. obrázek měl vždy 0 B
    	//trigger_error( 'Dělka obrázku: '.strlen( $a ) );
    	echo $a;
    	die();
    	}

           

    Hodnocení: -

    zatím nehodnoceno
            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    21.9.2019 15:16 R
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Pouzi cache - po vygenerovani uloz vysledok na disk. A pri dalsej poziadavke najprv skontroluj, ci uz nahodou neexistuje.
    Max avatar 21.9.2019 17:09 Max | skóre: 73 | blog: Max_Devaine
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Hoď jsem screenshot final obrázku, jak to pak vypadá, ať se pokocháme nejen zdrojákem, ale i výtvorem.
    Zdar Max
    Měl jsem sen ... :(
    21.9.2019 17:29 _
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    A až budeš chtít změnit, jak to vypadá, tak budeš dělat co? Tohle má dělat CSS...
    21.9.2019 17:29 _
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    (myšleno že budeš všechny obrázky generovat znovu z originálu?)
    22.9.2019 09:42 Bubak | skóre: 16 | blog: Čtvrtá cenová
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Vymazne cache?
    ... máš jen mrtvou kočku a poškrábanýho jezevčíka ...
    Josef Kufner avatar 22.9.2019 10:54 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Takovéto věci CSS nikdy neudělá. A už jen kvůli velikosti původního obrázku to nemá smysl.

    Správné řešení je vygenerovat si ten obrázek do souboru při nasazení aplikace či prvním použití a klienta nasměrovat rovnou na vygenerovaný obrázek.

    Jsou v podstatě tři možnosti:
    1. Při nasazení aplikace vše vygenerovat. Obrázky budou statické soubory předem známého názvu, který je možno používat v aplikaci.
    2. Při generování stránky vygenerovat obrázek. Obrázek je pak statický soubor neznámého názvu, ten název však prozradí generující funkce, neboť ví, kam ho uložila. Uložené obrázky se použijí napřímo, takže při druhém přístupu už není žádná řežie navíc, krom zjištění názvu souboru.
    3. Obrázek je generován na vyžádání a výsledek je kešován. To umožní řízení přístupu k obrázku a pomocí X-SendFile je možné omezit režii webserveru na poskytnutí obrázku – PHP skript při dalších přístupech jen zkontroluje nakešovaný soubor a pomocí HTTP hlavičky v odpovědi řekne web serveru, ať ho pošle klientovi.
    Hello world ! Segmentation fault (core dumped)
    22.9.2019 13:50 jiwopene | skóre: 31 | blog: Od každého trochu…
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Pokud je server Apache, je asi nejlepší pomocí mod_rewrite poslat rovnou vygenerovaný obrázek a nespouštět PHP. Mělo by to být o trochu rychlejší a není třeba řešit cache v PHP. PHP se spustí jen když obrázek neexistuje a uloží ho na disk. Příště se odešle rovnou obrázek.
    .sig virus 3.2_cz: Prosím, okopírujte tento text do vaší patičky.
    Josef Kufner avatar 22.9.2019 14:27 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    To je ta možnost č. 2 a mod_rewrite na to nepotřebuješ.
    Hello world ! Segmentation fault (core dumped)
    23.9.2019 19:31  
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Takovéto věci CSS nikdy neudělá
    Co, inset box-shadow nebo border-radius?
    Josef Kufner avatar 25.9.2019 01:32 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Příloha:
    No, pokud chceš jen blur okraje do čistě bílého pozadí, tak to jde:
    <span class="blur-img">
    <img src="https://upload.wikimedia.org/wikipedia/commons/thumb/7/72/Ear-Spot_Squirrel.jpg/1200px-Ear-Spot_Squirrel.jpg">
    </span>
    
    .blur-img {
      box-sizing: border-box;
      display: block;
      width: 50%;
      margin: 10% auto;
      border-radius: 50%;
      box-shadow: inset 0px 0px 20px 20px #fff, inset 0px 0px 20px 20px #fff;
      overflow: hidden;
      position: relative;
    }
    
    .blur-img img {
      box-sizing: border-box;
      width: 100%;
      display: block;
      border-radius: 50%;
      border: 2px solid #fff;
      position: relative;
      z-index: -1;
    }
    
    Výsledek: https://jsfiddle.net/09maztw7/

    Na komplikovanější věci by se asi dalo použít SVG. Případně CSS filtry.

    Stejně ale musí na serveru pořešit zmenšení obrázku na správnou velikost. Přikreslení rámečku už je drobnost.
    Hello world ! Segmentation fault (core dumped)
    25.9.2019 13:16 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    No tak tohle je pecka ...

    Kupodivu, obrázek se scvrkne sám na potřebnou velikost .. tedy nezjistil jsem žádný problém s tímto ...

    Jak primitivní !

    Ale jak účinné !

    díky moc
    Josef Kufner avatar 25.9.2019 21:45 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Nescvrkne se sám. Pokud je moc velký, tak se uživatelům bude stahovat půl dne. Tak jako tak ho musíš zmenšit na rozumnou velikost.
    Hello world ! Segmentation fault (core dumped)
    21.9.2019 22:55 debian+
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Jak vyříznout z obrázku elipsoid a rozpliznout tomu okraje - pokus
    Co tak pouzit Cairo? Priklady ako vlastne kniznica logika jednoducho funguje. A verzia pre PHP.
    22.9.2019 10:50 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Příloha:
    Ahoj, Maxi, tole je výsledek ... ještě to není "venku", jen na "hřišti" a bude potřeba tomu doladit další drobnosti, které mám v hlavě, ale ten obrázek je skriptem vyříznutý z originálu
    22.9.2019 14:00 jiwopene | skóre: 31 | blog: Od každého trochu…
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Ty elipsy tam jsou moc vidět. Nešlo by to třeba řešit v prohlížeči pomocí SVG?
    .sig virus 3.2_cz: Prosím, okopírujte tento text do vaší patičky.
    Josef Kufner avatar 22.9.2019 14:34 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Spíš bych udělal oválnou masku a tu před aplikací rozostřil. Tedy něco jako příklad z setImageClipMask plus blurImage aplikovaný na masku.
    Hello world ! Segmentation fault (core dumped)
    24.9.2019 19:01 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Tohle vypadá velmi zajímavě ...
    24.9.2019 19:56 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Příloha:
    úpravou kódu :
     		$draw->setFillColor( new ImagickPixel( "rgba( 0%, 0%, 0%, 1 )" ) );
    		$draw->ellipse( $icx, $icy, $iw2, $ih2, 0, 360 );
    
    		$maska->drawImage( $draw );
    		$maska->blurImage( $step*$steps, $steps );
    

    dostávám to rozostření krásně hladké. Masku ještě uložím do souboru a pak jen načtu a přeškáluji na potřebný rozměr a aplikuji. Celé generování trvá 0.24s, což už je schůdné.

    Ten blur totiž docela trvá, a pokud jsem u prvního parametru odhadl "co a jak" ten druhý jsem prostě jen náhodně nastavil, nevím, jaký má přesně účel. Asi "sílu" rozmazání, nevím. Díky za popostrčení.

    Josef Kufner avatar 25.9.2019 01:26 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Masku neukládej, jak to budeš škálovat, bude to porůznu ošklivé. Navíc to ani nemá smysl ukládat, když je to tak snadné nakreslit.

    Ukládej hotový obrázek a nebudeš řešit půl sekundy na generování.
    Hello world ! Segmentation fault (core dumped)
    22.9.2019 14:37 citanus | skóre: 12 | Cork (Ireland)
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku

    tak vono ten imagick umi to stejny co browser a asi i vice, spis je otazka jestli to fakt resit. Chce to na web tak, bych na to pouzil fakt to css

    https://css-tricks.com/clipping-masking-css/

    https://codepen.io/chriscoyier/pen/41d6e36ac584ee0401064d1cdb88fc67

    ^ jen si pohrej s rx="45%" u masky a mas dost podobnej efekt tomu cemu se snazis docilit

    24.9.2019 20:00 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: PHP7 rozplizlý elipsoidní výřez z obrázku
    Tohle také může být cesta ... hm .. kolik toho vůbec nevím ..

    Díky

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.