Skip to content

Instantly share code, notes, and snippets.

View Char2sGu's full-sized avatar

Charles Char2sGu

View GitHub Profile
@Char2sGu
Char2sGu / concat.cmd
Created November 27, 2025 22:27
FFMPEG
ffmpeg -f concat -safe 0 -i ".\concat.txt" -c copy ".\<path_to_video_output>"
// Declare dialog input and output types on the dialog class.
@Component({/*...*/})
class MyDialog extends DialogIoTypes<
{ someData: object }, // Input type
{ someResult: object } // Output type
> {}
@Component({/*...*/})
class HostComponent {
private myDialog = useDialog(MyDialog, { disableClose: true });
import { Dialog, DialogConfig, DialogRef } from '@angular/cdk/dialog';
import { Component, inject, Injector, Type } from '@angular/core';
const TYPES = Symbol('TYPES');
export abstract class DialogIoTypes<Input, Output> {
[TYPES]?: [Input, Output];
}
export type DialogInputOf<T extends DialogIoTypes<any, any>> =
啊阿埃挨哎唉哀皑癌蔼矮艾碍爱隘鞍氨安俺按暗岸胺案肮昂盎凹敖熬翱袄傲奥懊澳芭捌扒叭
吧笆八疤巴拔跋靶把耙坝霸罢爸白柏百摆佰败拜稗斑班搬扳般颁板版扮拌伴瓣半办绊邦帮梆
榜膀绑棒磅蚌镑傍谤苞胞包褒剥薄雹保堡饱宝抱报暴豹鲍爆杯碑悲卑北辈背贝钡倍狈备惫焙
被奔苯本笨崩绷甭泵蹦迸逼鼻比鄙笔彼碧蓖蔽毕毙毖币庇痹闭敝弊必辟壁臂避陛鞭边编贬扁
便变卞辨辩辫遍标彪膘表鳖憋别瘪彬斌濒滨宾摈兵冰柄丙秉饼炳病并玻菠播拨钵波博勃搏铂
箔伯帛舶脖膊渤泊驳捕卜哺补埠不布步簿部怖擦猜裁材才财睬踩采彩菜蔡餐参蚕残惭惨灿苍
舱仓沧藏操糙槽曹草厕策侧册测层蹭插叉茬茶查碴搽察岔差诧拆柴豺搀掺蝉馋谗缠铲产阐颤
昌猖场尝常长偿肠厂敞畅唱倡超抄钞朝嘲潮巢吵炒车扯撤掣彻澈郴臣辰尘晨忱沉陈趁衬撑称
城橙成呈乘程惩澄诚承逞骋秤吃痴持匙池迟弛驰耻齿侈尺赤翅斥炽充冲虫崇宠抽酬畴踌稠愁
筹仇绸瞅丑臭初出橱厨躇锄雏滁除楚础储矗搐触处揣川穿椽传船喘串疮窗幢床闯创吹炊捶锤

Layout projection: A method for animating browser layouts at 60fps

Introduction

Animating layout is hard. Prohibitively so; how many ambitious designers have provided dev teams dazzling videos of app-quality UI animations, only to be rebuffed?

If you're a web developer, what would your reaction be if asked to realise this kind of App Store-style interaction, where an item opens into a full-screen view when clicked:

Y2Mate.is.-.Inside.Framer.Motion.s.Layout.Animations.-.Matt.Perry-5-JIu0u42Jc-1080p-1651813013467.online-video-cutter.com.mp4