86

カラーホイール、カラーピッカー、カラーマッチャーのWebアプリは非常にたくさんあるようです。ここでは、1つの色を指定すると、他の2つの色を見つけて、組み合わせて使用​​すると調和のとれたレイアウトが作成されます。ただし、それらのほとんどは背景色のみに焦点を当てており、各背景色に印刷されるテキスト(プレビューでテキストが印刷される場合)は黒または白のいずれかです。

私の問題は違います。テキスト領域に使用したい背景色を知っています。私が助けを必要としているのは、この背景のフォントの色として使用できるいくつかの色(多ければ多いほど楽しい)を選択することです。最も重要なのは、色によってフォントが読みやすくなること(コントラストが低すぎないこと、また、目が強調されないように高すぎないこと)、そしてもちろん前景と背景の組み合わせが見栄えがすることです。

そのようなアプリケーションを知っている人はいますか?ダウンロードするものよりもWebアプリケーションの方がいいです。ありがとう。

4

9 に答える 9

39

アルゴリズムが必要な場合は、これを試してください: 色を RGB 空間から HSV 空間 (色相、彩度、値) に変換します。UI フレームワークでそれができない場合は、次の記事を確認してください: http://en.wikipedia.org/wiki/HSL_and_HSV#Conversion_from_RGB_to_HSL_or_HSV

色相は [0,360) です。「反対」の色 (カラーホイールを考えてください) を見つけるには、180 度を追加するだけです。

h = (h + 180) % 360;

彩度と値については、それらを反転します。

l = 1.0 - l;
v = 1.0 - v;

RGB に変換します。ほとんどの組み合わせは見栄えが悪いですが、これにより常に高いコントラストが得られます。

「醜い」部分を避けたい場合は、いくつかの「良い」組み合わせでテーブルを作成し、違いが最も少ないものを見つけます

def q(x):
    return x*x
def diff(col1, col2):
    return math.sqrt(q(col1.r-col2.r) + q(col1.g-col2.g) + q(col1.b-col2.b))

そしてそれを使用します。

于 2008-11-19T14:49:55.593 に答える
4

わかりました、これはまだ最善の解決策ではありませんが、開始するには良いポイントです。2 つの色のコントラスト比を計算し、5:1 以上の比率の色のみを処理する小さな Java アプリを作成しました。この比率と私が使用する式は W3C によってリリースされており、おそらく現在の推奨事項 (私は非常に限られていると考えています)。現在の作業ディレクトリに「chosen-font-colors.html」という名前のファイルが作成され、選択した背景色と、この W3C テストに合格したすべての色のテキスト行が含まれます。背景色である単一の引数が必要です。

たとえば、次のように呼び出すことができます

java FontColorChooser 33FFB4

次に、選択したブラウザで生成された HTML ファイルを開き、リストから色を選択します。指定されたすべての色は、この背景色の W3C テストに合格しました。5 を任意の数値に置き換えることでカットオフを変更できます (数値が小さいほどコントラストが弱くなります。たとえば、3 はコントラストが 3:1 になるだけで、10 は少なくとも 10:1 になるようになります)。コントラストが高すぎるのを避けるためにカットオフします (特定の数よりも小さいことを確認することにより)。

|| cDiff > 18.0

コントラストが極端すぎると目が疲れる可能性があるため、if 句にコントラストが極端にならないようにします。これがコードです。少し遊んで楽しんでください:-)

import java.io.*;

/* For text being readable, it must have a good contrast difference. Why?
 * Your eye has receptors for brightness and receptors for each of the colors
 * red, green and blue. However, it has much more receptors for brightness
 * than for color. If you only change the color, but both colors have the
 * same contrast, your eye must distinguish fore- and background by the
 * color only and this stresses the brain a lot over the time, because it
 * can only use the very small amount of signals it gets from the color
 * receptors, since the breightness receptors won't note a difference.
 * Actually contrast is so much more important than color that you don't
 * have to change the color at all. E.g. light red on dark red reads nicely
 * even though both are the same color, red.
 */


public class FontColorChooser {
    int bred;
    int bgreen;
    int bblue;

    public FontColorChooser(String hexColor) throws NumberFormatException {
        int i;

        i = Integer.parseInt(hexColor, 16);
        bred = (i >> 16);
        bgreen = (i >> 8) & 0xFF;
        bblue = i & 0xFF;
    }

    public static void main(String[] args) {
        FontColorChooser fcc;

        if (args.length == 0) {
            System.out.println("Missing argument!");
            System.out.println(
                "The first argument must be the background" +
                "color in hex notation."
            );
            System.out.println(
                "E.g. \"FFFFFF\" for white or \"000000\" for black."
            );
            return;
        }
        try {
            fcc = new FontColorChooser(args[0]);
        } catch (Exception e) {
            System.out.println(
                args[0] + " is no valid hex color!"
            );
            return;
        }
        try {
            fcc.start();
        } catch (IOException e) {
            System.out.println("Failed to write output file!");
        }
    }

    public void start() throws IOException {
        int r;
        int b;
        int g;
        OutputStreamWriter out;

        out = new OutputStreamWriter(
            new FileOutputStream("chosen-font-colors.html"),
            "UTF-8"
        );

        // simple, not W3C comform (most browsers won't care), HTML header
        out.write("<html><head><title>\n");
        out.write("</title><style type=\"text/css\">\n");
        out.write("body { background-color:#");
        out.write(rgb2hex(bred, bgreen, bblue));
        out.write("; }\n</style></head>\n<body>\n");

        // try 4096 colors
        for (r = 0; r <= 15; r++) {
            for (g = 0; g <= 15; g++) {
                for (b = 0; b <= 15; b++) {
                    int red;
                    int blue;
                    int green;
                    double cDiff;

                    // brightness increasse like this: 00, 11,22, ..., ff
                    red = (r << 4) | r;
                    blue = (b << 4) | b;
                    green = (g << 4) | g;

                    cDiff = contrastDiff(
                        red, green, blue,
                        bred, bgreen, bblue
                    );
                    if (cDiff < 5.0) continue;
                    writeDiv(red, green, blue, out);
                }
            }
        }

        // finalize HTML document
        out.write("</body></html>");

        out.close();
    }

    private void writeDiv(int r, int g, int b, OutputStreamWriter out)
        throws IOException
    {
        String hex;

        hex = rgb2hex(r, g, b);
        out.write("<div style=\"color:#" + hex + "\">");
        out.write("This is a sample text for color " + hex + "</div>\n");
    }

    private double contrastDiff(
        int r1, int g1, int b1, int r2, int g2, int b2
    ) {
        double l1;
        double l2;

        l1 = ( 
            0.2126 * Math.pow((double)r1/255.0, 2.2) +
            0.7152 * Math.pow((double)g1/255.0, 2.2) +
            0.0722 * Math.pow((double)b1/255.0, 2.2) +
            0.05
        );
        l2 = ( 
            0.2126 * Math.pow((double)r2/255.0, 2.2) +
            0.7152 * Math.pow((double)g2/255.0, 2.2) +
            0.0722 * Math.pow((double)b2/255.0, 2.2) +
            0.05
        );

        return (l1 > l2) ? (l1 / l2) : (l2 / l1);
    }

    private String rgb2hex(int r, int g, int b) {
        String rs = Integer.toHexString(r);
        String gs = Integer.toHexString(g);
        String bs = Integer.toHexString(b);
        if (rs.length() == 1) rs = "0" + rs;
        if (gs.length() == 1) gs = "0" + gs;
        if (bs.length() == 1) bs = "0" + bs;
        return (rs + gs + bs);
    }
}
于 2008-11-19T19:00:01.987 に答える
2

これは興味深い質問ですが、実際には不可能だと思います。2色が背景色と前景色に「適合する」かどうかは、ディスプレイテクノロジーと人間の視覚の生理学的特性に依存しますが、最も重要なのは、経験によって形成された個人的な好みに依存します。MySpaceをざっと見てみると、すべての人間が同じように色を認識しているわけではないことがはっきりとわかります。許容できる一致する色の巨大なデータベースがどこかにあるかもしれませんが、これはアルゴリズム的に解決できる問題ではないと思います。

于 2008-11-19T13:31:04.660 に答える
2

別の理由で似たようなものを実装しました。これは、エンド ユーザーが選択した前景色と背景色が判読不能なテキストになるかどうかをエンド ユーザーに伝えるためのコードでした。これを行うには、RGB 値を調べるのではなく、色の値を HSL/HSV に変換してから、fg 値と bg 値を比較するときに読みやすさのカットオフ ポイントを実験によって決定しました。これは、検討したい/検討する必要があるものです。

于 2008-11-21T18:49:18.573 に答える
2

最近作成したアプリケーションでは、反転した色を使用しました。r、g、b の値が手元にあれば、計算するだけです (この例では、色の範囲は 0 から 255 まで変化します)。

r = 127-(r-127) and so on.
于 2016-01-11T04:47:29.167 に答える
1

私自身の質問に答えるのは奇妙かもしれませんが、これまでに見たことのない本当にクールなカラー ピッカーがもう 1 つあります。それは私の問題も解決しません:-((((しかし、私がすでに知っているこれらよりもはるかにクールだと思います.

http://www.colorjack.com/

右側のツールの下で、非常に強力でカスタマイズ可能な球体である「Color Sphere」を選択します (上部のポップアップで何ができるかを確認してください)、「Color Galaxy」、これがどのように機能するかはまだわかりませんが、見た目はかっこよくて「カラースタジオ」もいいですね。さらに、あらゆる種類の形式 (Illustrator や Photoshop など) にエクスポートできます。

これはどうですか、そこで背景色を選択し、(最初のポップアップから) 補色を作成させます - これは最高のコントラストを持ち、したがって最も読みやすいはずです。次に補色をメインカラーとして選択し、ニュートラルを選択しますか? うーん... あまり良くはありませんが、良くなっています;-)

于 2008-11-19T15:04:22.803 に答える
0

アプリケーションのユーザーが独自の配色を選択できるようにすることを検討しましたか? あなたの選択で必ずすべてのユーザーを満足させることはできませんが、ユーザーが満足するものを見つけられるようにすることはできます。

于 2008-11-19T13:48:41.303 に答える
0

@Aaron Digullaの提案と同様に、グラフィックデザインツールを提案し、ベースカラー、この場合は背景色を選択してから、色相、彩度、および値を調整します。これを使用すると、非常に簡単に色見本を作成できます。Paint.Net は無料で、私はこれを常に使用しています。また、有料のツールもこれを行います。

于 2008-11-19T19:11:12.180 に答える
0

個人的には、背景色を指定して最も一致するテキストの色を計算するアルゴリズムを見つけることはできないと思います。

現在、アーティストは読みの質の高い色のペアのリストを持っている必要があると思います。それらをテーブルに追加し、これらのペアのいずれかをランダムに読みのテーマとして設定できます...

これは非常に合理的であり、醜い色のペアを取得することはありません....

于 2012-01-01T18:13:53.237 に答える